Skip to content

Commit

Permalink
sapi: Implement ISpeechVoice::{get/putref}_Voice.
Browse files Browse the repository at this point in the history
  • Loading branch information
shaunren authored and julliard committed Mar 4, 2024
1 parent 7c384f3 commit 43220a6
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 5 deletions.
22 changes: 21 additions & 1 deletion dlls/sapi/tests/tts.c
Original file line number Diff line number Diff line change
Expand Up @@ -424,7 +424,7 @@ static void test_spvoice(void)
IUnknown *dummy;
ISpMMSysAudio *audio_out;
ISpObjectTokenCategory *token_cat;
ISpObjectToken *token;
ISpObjectToken *token, *token2;
WCHAR *token_id = NULL, *default_token_id = NULL;
ISpDataKey *attrs_key;
LONG rate;
Expand All @@ -435,6 +435,7 @@ static void test_spvoice(void)
ISpeechVoice *speech_voice;
ISpeechObjectTokens *speech_tokens;
LONG count, volume_long;
ISpeechObjectToken *speech_token;
BSTR req = NULL, opt = NULL;
UINT info_count;
ITypeInfo *typeinfo;
Expand Down Expand Up @@ -724,6 +725,25 @@ static void test_spvoice(void)
ok(hr == S_OK, "got %#lx.\n", hr);
ok(volume_long == 80, "got %ld.\n", volume_long);

hr = ISpObjectToken_QueryInterface(token, &IID_ISpeechObjectToken, (void **)&speech_token);
ok(hr == S_OK, "got %#lx.\n", hr);
hr = ISpeechVoice_putref_Voice(speech_voice, speech_token);
ok(hr == S_OK, "got %#lx.\n", hr);
ISpeechObjectToken_Release(speech_token);

speech_token = (ISpeechObjectToken *)0xdeadbeef;
hr = ISpeechVoice_get_Voice(speech_voice, &speech_token);
ok(hr == S_OK, "got %#lx.\n", hr);
ok(speech_token && speech_token != (ISpeechObjectToken *)0xdeadbeef, "got %p.\n", speech_token);
hr = ISpeechObjectToken_QueryInterface(speech_token, &IID_ISpObjectToken, (void **)&token2);
ok(hr == S_OK, "got %#lx.\n", hr);
token_id = NULL;
hr = ISpObjectToken_GetId(token2, &token_id);
ok(hr == S_OK, "got %#lx.\n", hr);
ok(!wcscmp(token_id, test_token_id), "got %s.\n", wine_dbgstr_w(token_id));
CoTaskMemFree(token_id);
ISpObjectToken_Release(token2);

hr = ISpeechVoice_Speak(speech_voice, NULL, SVSFPurgeBeforeSpeak, NULL);
ok(hr == S_OK, "got %#lx.\n", hr);

Expand Down
26 changes: 22 additions & 4 deletions dlls/sapi/tts.c
Original file line number Diff line number Diff line change
Expand Up @@ -235,16 +235,34 @@ static HRESULT WINAPI speech_voice_get_Status(ISpeechVoice *iface, ISpeechVoiceS

static HRESULT WINAPI speech_voice_get_Voice(ISpeechVoice *iface, ISpeechObjectToken **voice)
{
FIXME("(%p, %p): stub.\n", iface, voice);
struct speech_voice *This = impl_from_ISpeechVoice(iface);
ISpObjectToken *token;
HRESULT hr;

return E_NOTIMPL;
TRACE("(%p, %p).\n", iface, voice);

if (!voice) return E_POINTER;
if (FAILED(hr = ISpVoice_GetVoice(&This->ISpVoice_iface, &token)))
return hr;
hr = ISpObjectToken_QueryInterface(token, &IID_ISpeechObjectToken, (void **)voice);
ISpObjectToken_Release(token);
return hr;
}

static HRESULT WINAPI speech_voice_putref_Voice(ISpeechVoice *iface, ISpeechObjectToken *voice)
{
FIXME("(%p, %p): stub.\n", iface, voice);
struct speech_voice *This = impl_from_ISpeechVoice(iface);
ISpObjectToken *token;
HRESULT hr;

return E_NOTIMPL;
TRACE("(%p, %p).\n", iface, voice);

if (!voice) return E_INVALIDARG;
if (FAILED(hr = ISpeechObjectToken_QueryInterface(voice, &IID_ISpObjectToken, (void **)&token)))
return hr;
hr = ISpVoice_SetVoice(&This->ISpVoice_iface, token);
ISpObjectToken_Release(token);
return hr;
}

static HRESULT WINAPI speech_voice_get_AudioOutput(ISpeechVoice *iface, ISpeechObjectToken **output)
Expand Down

0 comments on commit 43220a6

Please sign in to comment.