wine-wine/include/sapi.idl

1094 lines
33 KiB
Plaintext

/*
* Speech API (SAPI) IDL file.
*
* Copyright (C) 2017 Huw Davies
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
import "oaidl.idl";
import "ocidl.idl";
#ifndef __WIDL__
#define threading(model)
#define progid(str)
#define vi_progid(str)
#endif
cpp_quote("#if 0")
typedef [restricted, hidden] struct WAVEFORMATEX
{
WORD wFormatTag;
WORD nChannels;
DWORD nSamplesPerSec;
DWORD nAvgBytesPerSec;
WORD nBlockAlign;
WORD wBitsPerSample;
WORD cbSize;
} WAVEFORMATEX;
cpp_quote("#else")
cpp_quote("#include <mmsystem.h>")
cpp_quote("#endif")
cpp_quote("#if defined(__cplusplus)")
cpp_quote("interface ISpNotifyCallback")
cpp_quote("{")
cpp_quote("virtual HRESULT STDMETHODCALLTYPE NotifyCallback(WPARAM wParam, LPARAM lParam) = 0;")
cpp_quote("};")
cpp_quote("#else")
typedef void * ISpNotifyCallback;
cpp_quote("#endif")
cpp_quote("#if 0")
typedef void * SPNOTIFYCALLBACK;
typedef void * SPSTATEHANDLE;
cpp_quote("#endif")
typedef [restricted, hidden] struct SPEVENT
{
WORD eEventId;
WORD elParamType;
ULONG ulStreamNum;
ULONGLONG ullAudioStreamOffset;
WPARAM wParam;
LPARAM lParam;
} SPEVENT;
cpp_quote("typedef void __stdcall SPNOTIFYCALLBACK(WPARAM wParam, LPARAM lParam);")
cpp_quote("DECLARE_HANDLE(SPSTATEHANDLE);")
const ULONG SP_MAX_LANGIDS = 20;
typedef [restricted, hidden] struct SPEVENTSOURCEINFO
{
ULONGLONG ullEventInterest;
ULONGLONG ullQueuedInterest;
ULONG ulCount;
} SPEVENTSOURCEINFO;
typedef [hidden] enum SPGRAMMARWORDTYPE
{
SPWT_DISPLAY,
SPWT_LEXICAL,
SPWT_PRONUNCIATION,
SPWT_LEXICAL_NO_SPECIAL_CHARS
} SPGRAMMARWORDTYPE;
typedef [hidden] struct tagSPPROPERTYINFO
{
const WCHAR *pszName;
ULONG ulId;
const WCHAR *pszValue;
VARIANT vValue;
} SPPROPERTYINFO;
typedef [hidden] enum SPDATAKEYLOCATION
{
SPDKL_DefaultLocation = 0,
SPDKL_CurrentUser = 1,
SPDKL_LocalMachine = 2,
SPDKL_CurrentConfig = 5
} SPDATAKEYLOCATION;
typedef [hidden] enum SPLOADOPTIONS
{
SPLO_STATIC,
SPLO_DYNAMIC
} SPLOADOPTIONS;
typedef [hidden] enum SPRULESTATE
{
SPRS_INACTIVE = 0,
SPRS_ACTIVE = 1,
SPRS_ACTIVE_WITH_AUTO_PAUSE = 3,
SPRS_ACTIVE_USER_DELIMITED = 4
} SPRULESTATE;
typedef [hidden] enum SPGRAMMARSTATE
{
SPGS_DISABLED = 0,
SPGS_ENABLED = 1,
SPGS_EXCLUSIVE = 3
} SPGRAMMARSTATE;
typedef [hidden] struct SPBINARYGRAMMAR
{
ULONG ulTotalSerializedSize;
} SPBINARYGRAMMAR;
typedef [hidden] struct tagSPTEXTSELECTIONINFO
{
ULONG ulStartActiveOffset;
ULONG cchActiveChars;
ULONG ulStartSelection;
ULONG cchSelection;
} SPTEXTSELECTIONINFO;
typedef [hidden] enum SPWORDPRONOUNCEABLE
{
SPWP_UNKNOWN_WORD_UNPRONOUNCEABLE,
SPWP_UNKNOWN_WORD_PRONOUNCEABLE,
SPWP_KNOWN_WORD_PRONOUNCEABLE
} SPWORDPRONOUNCEABLE;
typedef [hidden] enum SPINTERFERENCE
{
SPINTERFERENCE_NONE,
SPINTERFERENCE_NOISE,
SPINTERFERENCE_NOSIGNAL,
SPINTERFERENCE_TOOLOUD,
SPINTERFERENCE_TOOQUIET,
SPINTERFERENCE_TOOFAST,
SPINTERFERENCE_TOOSLOW
} SPINTERFERENCE;
typedef [hidden] enum SPVISEMES
{
SP_VISEME_0 = 0,
SP_VISEME_1,
SP_VISEME_2,
SP_VISEME_3,
SP_VISEME_4,
SP_VISEME_5,
SP_VISEME_6,
SP_VISEME_7,
SP_VISEME_8,
SP_VISEME_9,
SP_VISEME_10,
SP_VISEME_11,
SP_VISEME_12,
SP_VISEME_13,
SP_VISEME_14,
SP_VISEME_15,
SP_VISEME_16,
SP_VISEME_17,
SP_VISEME_18,
SP_VISEME_19,
SP_VISEME_20,
SP_VISEME_21,
} SPVISEMES;
typedef [hidden] enum SPEVENTENUM
{
SPEI_UNDEFINED = 0,
SPEI_START_INPUT_STREAM = 1,
SPEI_END_INPUT_STREAM = 2,
SPEI_VOICE_CHANGE = 3,
SPEI_TTS_BOOKMARK = 4,
SPEI_WORD_BOUNDARY = 5,
SPEI_PHONEME = 6,
SPEI_SENTENCE_BOUNDARY = 7,
SPEI_VISEME = 8,
SPEI_TTS_AUDIO_LEVEL = 9,
SPEI_TTS_PRIVATE = 15,
SPEI_MIN_TTS = 1,
SPEI_MAX_TTS = 15,
SPEI_END_SR_STREAM = 34,
SPEI_SOUND_START = 35,
SPEI_SOUND_END = 36,
SPEI_PHRASE_START = 37,
SPEI_RECOGNITION = 38,
SPEI_HYPOTHESIS = 39,
SPEI_SR_BOOKMARK = 40,
SPEI_PROPERTY_NUM_CHANGE = 41,
SPEI_PROPERTY_STRING_CHANGE = 42,
SPEI_FALSE_RECOGNITION = 43,
SPEI_INTERFERENCE = 44,
SPEI_REQUEST_UI = 45,
SPEI_RECO_STATE_CHANGE = 46,
SPEI_ADAPTATION = 47,
SPEI_START_SR_STREAM = 48,
SPEI_RECO_OTHER_CONTEXT = 49,
SPEI_SR_AUDIO_LEVEL = 50,
SPEI_SR_RETAINEDAUDIO = 51,
SPEI_SR_PRIVATE = 52,
SPEI_ACTIVE_CATEGORY_CHANGED = 53,
SPEI_MIN_SR = 34,
SPEI_MAX_SR = 55,
SPEI_RESERVED1 = 30,
SPEI_RESERVED2 = 33,
SPEI_RESERVED3 = 63
} SPEVENTENUM;
typedef [hidden] enum SPCONTEXTSTATE
{
SPCS_DISABLED = 0,
SPCS_ENABLED = 1,
} SPCONTEXTSTATE;
typedef [hidden] enum SPVPRIORITY
{
SPVPRI_NORMAL = 0,
SPVPRI_ALERT = 1,
SPVPRI_OVER = 2
} SPVPRIORITY;
typedef [hidden] enum SPRECOSTATE
{
SPRST_INACTIVE,
SPRST_ACTIVE,
SPRST_ACTIVE_ALWAYS,
SPRST_INACTIVE_WITH_PURGE,
SPRST_NUM_STATES
} SPRECOSTATE;
typedef [hidden] enum SPWAVEFORMATTYPE
{
SPWF_INPUT,
SPWF_SRENGINE
} SPSTREAMFORMATTYPE;
typedef [restricted, hidden] struct SPRECOCONTEXTSTATUS
{
SPINTERFERENCE eInterference;
WCHAR szRequestTypeOfUI[255];
DWORD dwReserved1;
DWORD dwReserved2;
} SPRECOCONTEXTSTATUS;
typedef [hidden] enum SPAUDIOOPTIONS
{
SPAO_NONE,
SPAO_RETAIN_AUDIO
} SPAUDIOOPTIONS;
typedef [hidden] struct SPSERIALIZEDRESULT
{
ULONG ulSerializedSize;
} SPSERIALIZEDRESULT;
typedef [hidden] enum SPDISPLYATTRIBUTES
{
SPAF_ONE_TRAILING_SPACE = 0x02,
SPAF_TWO_TRAILING_SPACES = 0x04,
SPAF_CONSUME_LEADING_SPACES = 0x08,
SPAF_ALL = 0x0f
} SPDISPLAYATTRIBUTES;
typedef [hidden] enum SPBOOKMARKOPTIONS
{
SPBO_NONE,
SPBO_PAUSE
} SPBOOKMARKOPTIONS;
typedef [hidden] enum _SPAUDIOSTATE
{
SPAS_CLOSED,
SPAS_STOP,
SPAS_PAUSE,
SPAS_RUN
} SPAUDIOSTATE;
typedef [hidden] enum SPRUNSTATE
{
SPRS_DONE = (1L << 0),
SPRS_IS_SPEAKING = (1L << 1)
} SPRUNSTATE;
typedef [hidden] enum SPEAKFLAGS
{
SPF_DEFAULT = 0,
SPF_ASYNC = (1L << 0),
SPF_PURGEBEFORESPEAK = (1L << 1),
SPF_IS_FILENAME = (1L << 2),
SPF_IS_XML = (1L << 3),
SPF_IS_NOT_XML = (1L << 4),
SPF_PERSIST_XML = (1L << 5),
SPF_NLP_SPEAK_PUNC = (1L << 6),
SPF_PARSE_SAPI = (1L << 7),
SPF_PARSE_SSML = (1L << 8),
SPF_PARSE_AUTODETECT = 0,
SPF_NLP_MASK = (SPF_NLP_SPEAK_PUNC),
SPF_PARSE_MASK = (SPF_PARSE_SAPI|SPF_PARSE_SSML),
SPF_VOICE_MASK = (SPF_ASYNC|SPF_PURGEBEFORESPEAK|SPF_IS_FILENAME|SPF_IS_XML|SPF_IS_NOT_XML|SPF_NLP_MASK|SPF_PERSIST_XML|SPF_PARSE_MASK),
SPF_UNUSED_FLAGS = ~(SPF_VOICE_MASK)
} SPEAKFLAGS;
typedef [hidden] enum SPCFGRULEATTRIBUTES
{
SPRAF_TopLevel = (1 << 0),
SPRAF_Active = (1 << 1),
SPRAF_Export = (1 << 2),
SPRAF_Import = (1 << 3),
SPRAF_Interpreter = (1 << 4),
SPRAF_Dynamic = (1 << 5),
SPRAF_Root = (1 << 6),
SPRAF_AutoPause = (1 << 16),
SPRAF_UserDelimited = (1 << 17)
} SPCFGRULEATTRIBUTES;
typedef [hidden] enum SPPHRASERNG
{
SPPR_ALL_ELEMENTS = -1
} SPPHRASERNG;
typedef [hidden] enum SPVALUETYPE
{
SPDF_PROPERTY = 0x00000001,
SPDF_REPLACEMENT = 0x00000002,
SPDF_RULE = 0x00000004,
SPDF_DISPLAYTEXT = 0x00000008,
SPDF_LEXICALFORM = 0x00000010,
SPDF_PRONUNCIATION = 0x00000020,
SPDF_AUDIO = 0x00000040,
SPDF_ALTERNATES = 0x00000080,
SPDF_ALL = 0x000000ff
} SPVALUETYPE;
typedef unsigned short SPPHONEID;
typedef [restricted, hidden] struct SPPHRASEELEMENT
{
ULONG ulAudioTimeOffset;
ULONG ulAudioSizeTime;
ULONG ulAudioStreamOffset;
ULONG ulAudioSizeBytes;
ULONG ulRetainedStreamOffset;
ULONG ulRetainedSizeBytes;
const WCHAR *pszDisplayText;
const WCHAR *pszLexicalForm;
const SPPHONEID *pszPronunciation;
BYTE bDisplayAttributes;
signed char RequiredConfidence;
signed char ActualConfidence;
BYTE Reserved;
float SREngineConfidence;
} SPPHRASEELEMENT;
typedef [restricted, hidden] struct SPVOICESTATUS
{
ULONG ulCurrentStream;
ULONG ulLastStreamQueued;
HRESULT hrLastResult;
DWORD dwRunningState;
ULONG ulInputWordPos;
ULONG ulInputWordLen;
ULONG ulInputSentPos;
ULONG ulInputSentLen;
LONG lBookmarkId;
SPPHONEID PhonemeId;
SPVISEMES VisemeId;
DWORD dwReserved1;
DWORD dwReserved2;
} SPVOICESTATUS;
typedef [restricted, hidden] struct SPAUDIOSTATUS
{
long cbFreeBuffSpace;
ULONG cbNonBlockingIO;
SPAUDIOSTATE State;
ULONGLONG CurSeekPos;
ULONGLONG CurDevicePos;
DWORD dwAudioLevel;
DWORD dwReserved2;
} SPAUDIOSTATUS;
typedef [restricted, hidden] struct SPRECOGNIZERSTATUS
{
SPAUDIOSTATUS AudioStatus;
ULONGLONG ullRecognitionStreamPos;
ULONG ulStreamNumber;
ULONG ulNumActive;
CLSID clsidEngine;
ULONG cLangIDs;
LANGID aLangID[SP_MAX_LANGIDS];
ULONGLONG ullRecognitionStreamTime;
} SPRECOGNIZERSTATUS;
typedef [restricted, hidden] struct SPPHRASERULE SPPHRASERULE;
struct SPPHRASERULE
{
LPCWSTR pszName;
ULONG ulId;
ULONG ulFirstElement;
ULONG ulCountOfElements;
const SPPHRASERULE* pNextSibling;
const SPPHRASERULE* pFirstChild;
float SREngineConfidence;
signed char Confidence;
};
typedef [restricted, hidden] struct SPPHRASEPROPERTY SPPHRASEPROPERTY;
struct SPPHRASEPROPERTY
{
const WCHAR *pszName;
ULONG ulId;
const WCHAR *pszValue;
VARIANT vValue;
ULONG ulFirstElement;
ULONG ulCountOfElements;
const SPPHRASEPROPERTY *pNextSibling;
const SPPHRASEPROPERTY *pFirstChild;
float SREngineConfidence;
signed char Confidence;
};
typedef [restricted, hidden] struct SPPHRASEREPLACEMENT
{
BYTE bDisplayAttributes;
const WCHAR *pszReplacementText;
ULONG ulFirstElement;
ULONG ulCountOfElements;
} SPPHRASEREPLACEMENT;
typedef [restricted, hidden] struct SPPHRASE
{
ULONG cbSize;
LANGID LangID;
WORD wReserved;
ULONGLONG ullGrammarID;
ULONGLONG ftStartTime;
ULONGLONG ullAudioStreamPosition;
ULONG ulAudioSizeBytes;
ULONG ulRetainedSizeBytes;
ULONG ulAudioSizeTime;
SPPHRASERULE Rule;
const SPPHRASEPROPERTY *pProperties;
const SPPHRASEELEMENT *pElements;
ULONG cReplacements;
const SPPHRASEREPLACEMENT *pReplacements;
GUID SREngineID;
ULONG ulSREnginePrivateDataSize;
const BYTE *pSREnginePrivateData;
} SPPHRASE;
typedef [restricted, hidden] struct SPSERIALIZEDPHRASE
{
ULONG ulSerializedSize;
} SPSERIALIZEDPHRASE;
typedef [restricted, hidden] struct SPRECORESULTTIMES
{
FILETIME ftStreamTime;
ULONGLONG ullLength;
DWORD dwTickCount;
ULONGLONG ullStart;
} SPRECORESULTTIMES;
typedef [hidden] enum SPFILEMODE
{
SPFM_OPEN_READONLY,
SPFM_OPEN_READWRITE,
SPFM_CREATE,
SPFM_CREATE_ALWAYS,
SPFM_NUM_MODES
} SPFILEMODE;
cpp_quote("#if defined(__GNUC__)")
cpp_quote("#define SPCAT_AUDIOOUT (const WCHAR []){ 'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','A','u','d','i','o','O','u','t','p','u','t',0 }")
cpp_quote("#define SPCAT_AUDIOIN (const WCHAR []){ 'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','A','u','d','i','o','I','n','p','u','t',0 }")
cpp_quote("#define SPCAT_VOICES (const WCHAR []){ 'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','V','o','i','c','e','s',0 }")
cpp_quote("#elif defined(_MSC_VER)")
cpp_quote("#define SPCAT_AUDIOOUT L\"HKEY_LOCAL_MACHINE\\\\SOFTWARE\\\\Microsoft\\\\Speech\\\\AudioOutput\"")
cpp_quote("#define SPCAT_AUDIOIN L\"HKEY_LOCAL_MACHINE\\\\SOFTWARE\\\\Microsoft\\\\Speech\\\\AudioInput\"")
cpp_quote("#define SPCAT_VOICES L\"HKEY_LOCAL_MACHINE\\\\SOFTWARE\\\\Microsoft\\\\Speech\\\\Voices\"")
cpp_quote("#else")
cpp_quote("static const WCHAR SPCAT_AUDIOOUT[] = {'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','A','u','d','i','o','O','u','t','p','u','t',0};")
cpp_quote("static const WCHAR SPCAT_AUDIOIN[] = {'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','A','u','d','i','o','I','n','p','u','t',0};")
cpp_quote("static const WCHAR SPCAT_VOICES[] = {'H','K','E','Y','_','L','O','C','A','L','_','M','A','C','H','I','N','E','\\\\','S','O','F','T','W','A','R','E','\\\\','M','i','c','r','o','s','o','f','t','\\\\','S','p','e','e','c','h','\\\\','V','o','i','c','e','s',0};")
cpp_quote("#endif")
interface IEnumSpObjectTokens;
interface ISpEventSource;
interface ISpRecoContext;
interface ISpRecognizer;
interface ISpStreamFormat;
[
object,
uuid(14056581-e16c-11d2-bb90-00c04f8ee6c0),
helpstring("ISpDataKey"),
pointer_default(unique),
local,
restricted
]
interface ISpDataKey : IUnknown
{
HRESULT SetData([in] LPCWSTR pszValueName,
[in] ULONG cbData,
[in] const BYTE *pData);
HRESULT GetData([in] LPCWSTR pszValueName,
[in] ULONG *pcbData,
[out] BYTE *pData);
HRESULT SetStringValue([in] LPCWSTR pszValueName,
[in] LPCWSTR pszValue);
HRESULT GetStringValue([in] LPCWSTR pszValueName,
[out] LPWSTR *ppszValue);
HRESULT SetDWORD([in] LPCWSTR pszValueName,
[in] DWORD dwValue);
HRESULT GetDWORD([in] LPCWSTR pszValueName,
[out] DWORD *pdwValue);
HRESULT OpenKey([in] LPCWSTR pszSubKeyName,
[out] ISpDataKey **ppSubKey);
HRESULT CreateKey([in] LPCWSTR pszSubKey,
[out] ISpDataKey **ppSubKey);
HRESULT DeleteKey([in] LPCWSTR pszSubKey);
HRESULT DeleteValue([in] LPCWSTR pszValueName);
HRESULT EnumKeys([in] ULONG Index,
[out] LPWSTR *ppszSubKeyName);
HRESULT EnumValues([in] ULONG Index,
[out] LPWSTR *ppszValueName);
}
[
object,
uuid(92a66e2b-c830-4149-83df-6fc2ba1e7a5b),
helpstring("ISpRegDataKey"),
pointer_default(unique),
restricted
]
interface ISpRegDataKey : ISpDataKey
{
[local] HRESULT SetKey([in] HKEY hkey, [in] BOOL fReadOnly);
}
[
object,
uuid(2d3d3845-39af-4850-bbf9-40b49780011d),
helpstring("ISpObjectTokenCategory"),
pointer_default(unique),
local,
restricted
]
interface ISpObjectTokenCategory : ISpDataKey
{
HRESULT SetId([in] LPCWSTR pszCategoryId,
[in] BOOL fCreateIfNotExist);
HRESULT GetId([out] LPWSTR *ppszCoMemCategoryId);
HRESULT GetDataKey([in] SPDATAKEYLOCATION spdkl,
[out] ISpDataKey **ppDataKey);
HRESULT EnumTokens([in, string] LPCWSTR pszReqAttribs,
[in, string] LPCWSTR pszOptAttribs,
[out] IEnumSpObjectTokens **ppEnum);
HRESULT SetDefaultTokenId([in] LPCWSTR pszTokenId);
HRESULT GetDefaultTokenId([out] LPWSTR *ppszCoMemTokenId);
}
[
object,
uuid(14056589-e16c-11d2-bb90-00c04f8ee6c0),
helpstring("ISpObjectToken"),
pointer_default(unique),
local,
restricted
]
interface ISpObjectToken : ISpDataKey
{
HRESULT SetId(/*[in]*/ LPCWSTR pszCategoryId,
[in] LPCWSTR pszTokenId,
[in] BOOL fCreateIfNotExist);
HRESULT GetId([out] LPWSTR *ppszCoMemTokenId);
HRESULT GetCategory([out] ISpObjectTokenCategory **ppTokenCategory);
HRESULT CreateInstance([in] IUnknown *pUnkOuter,
[in] DWORD dwClsContext,
[in] REFIID riid,
[out, iid_is(riid)] void **ppvObject);
HRESULT GetStorageFileName([in] REFCLSID clsidCaller,
[in] LPCWSTR pszValueName,
[in, string] LPCWSTR pszFileNameSpecifier,
[in] ULONG nFolder,
[out] LPWSTR *ppszFilePath);
HRESULT RemoveStorageFileName([in] REFCLSID clsidCaller,
[in] LPCWSTR pszKeyName,
[in] BOOL fDeleteFile);
HRESULT Remove(/*[in]*/ const CLSID *pclsidCaller);
[local] HRESULT IsUISupported([in] LPCWSTR pszTypeOfUI,
[in] void *pvExtraData,
[in] ULONG cbExtraData,
[in] IUnknown *punkObject,
[out] BOOL *pfSupported);
[local] HRESULT DisplayUI([in] HWND hwndParent,
[in] LPCWSTR pszTitle,
[in] LPCWSTR pszTypeOfUI,
[in] void *pvExtraData,
[in] ULONG cbExtraData,
[in] IUnknown *punkObject);
HRESULT MatchesAttributes([in] LPCWSTR pszAttributes,
[out] BOOL *pfMatches);
}
[
object,
uuid(06b64f9e-7fda-11d2-b4f2-00c04f797396),
helpstring("IEnumSpObjectTokens"),
pointer_default(unique),
local,
restricted
]
interface IEnumSpObjectTokens : IUnknown
{
HRESULT Next([in] ULONG celt,
[out, size_is(celt), length_is(*pceltFetched)] ISpObjectToken **pelt,
[out] ULONG *pceltFetched);
HRESULT Skip([in] ULONG celt);
HRESULT Reset(void);
HRESULT Clone([out] IEnumSpObjectTokens **ppEnum);
HRESULT Item([in] ULONG Index,
[out] ISpObjectToken **ppToken);
HRESULT GetCount([out] ULONG *pCount);
}
[
object,
uuid(1a5c0354-b621-4b5a-8791-d306ed379e53),
local,
pointer_default(unique),
restricted
]
interface ISpPhrase : IUnknown
{
HRESULT GetPhrase([out] SPPHRASE **phrase);
HRESULT GetSerializedPhrase([out] SPSERIALIZEDPHRASE **phrase);
HRESULT GetText([in] ULONG start, [in] ULONG count, [in] BOOL replacements,
[out] WCHAR **text, [out] BYTE *attributes);
HRESULT Discard([in] DWORD types);
};
[
object,
uuid(8fcebc98-4e49-4067-9c6c-d86a0e092e3d),
local,
pointer_default(unique),
restricted
]
interface ISpPhraseAlt : ISpPhrase
{
HRESULT GetAltInfo(ISpPhrase **parent, ULONG *start, ULONG *count,
ULONG *elements);
HRESULT Commit();
};
[
object,
uuid(20b053be-e235-43cd-9a2a-8d17a48b7842),
pointer_default(unique),
local,
restricted
]
interface ISpRecoResult : ISpPhrase
{
HRESULT GetResultTimes([out] SPRECORESULTTIMES *times);
HRESULT GetAlternates(
[in] ULONG start,
[in] ULONG elements,
[in] ULONG count,
[out] ISpPhraseAlt **phrases,
[out] ULONG *returned);
HRESULT GetAudio(
[in] ULONG start,
[in] ULONG elements,
[out] ISpStreamFormat **stream);
HRESULT SpeakAudio(
[in] ULONG start,
[in] ULONG elements,
[in] DWORD flags,
[out] ULONG *number);
HRESULT Serialize([out] SPSERIALIZEDRESULT **result);
HRESULT ScaleAudio([in] const GUID *format, [in] const WAVEFORMATEX *wave);
HRESULT GetRecoContext([out] ISpRecoContext *context);
};
[
object,
uuid(8137828f-591a-4a42-be58-49ea7ebaac68),
helpstring("ISpGrammarBuilder Interface"),
pointer_default(unique),
restricted,
local
]
interface ISpGrammarBuilder : IUnknown
{
HRESULT ResetGrammar([in] LANGID language);
HRESULT GetRule([in] const WCHAR *rule,
[in] DWORD id,
[in] DWORD attributes,
[in] BOOL should_create,
[out] SPSTATEHANDLE *state);
HRESULT ClearRule(SPSTATEHANDLE state);
HRESULT CreateNewState(
[in] SPSTATEHANDLE instate,
[out] SPSTATEHANDLE *outstate);
HRESULT AddWordTransition(
[in] SPSTATEHANDLE from_state,
[in] SPSTATEHANDLE to_state,
[in] const WCHAR *value,
[in] const WCHAR *separators,
[in] SPGRAMMARWORDTYPE type,
[in] float weight,
[in] const SPPROPERTYINFO *info);
HRESULT AddRuleTransition(
[in] SPSTATEHANDLE from_state,
[in] SPSTATEHANDLE to_state,
[in] SPSTATEHANDLE rule,
[in] float weight,
[in] const SPPROPERTYINFO *info);
HRESULT AddResource([in] SPSTATEHANDLE state,
[in] const WCHAR *name,
[in] const WCHAR *value);
HRESULT Commit([in] DWORD reserved);
};
[
object,
uuid(2177db29-7f45-47d0-8554-067e91c80502),
pointer_default(unique),
restricted,
local
]
interface ISpRecoGrammar : ISpGrammarBuilder
{
HRESULT GetGrammarId([out] ULONGLONG *grammar);
HRESULT GetRecoContext([out] ISpRecoContext **context);
HRESULT LoadCmdFromFile([in, string] const WCHAR * pszFileName, [in] SPLOADOPTIONS options);
HRESULT LoadCmdFromObject([in] REFCLSID rcid, [in, string] const WCHAR * pszGrammarName, [in] SPLOADOPTIONS options);
HRESULT LoadCmdFromResource([in] HMODULE hmod,
[in, string] const WCHAR *name,
[in, string] const WCHAR *type,
[in] WORD language,
[in] SPLOADOPTIONS options);
HRESULT LoadCmdFromMemory([in] const SPBINARYGRAMMAR *grammar, [in] SPLOADOPTIONS options);
HRESULT LoadCmdFromProprietaryGrammar(
[in] REFGUID guid,
[in, string] const WCHAR *param,
[in] const void *data,
[in] ULONG size,
[in] SPLOADOPTIONS options);
HRESULT SetRuleState([in, string] const WCHAR *name, [in] void *reserved,
[in] SPRULESTATE state);
HRESULT SetRuleIdState([in] ULONG rule, [in] SPRULESTATE state);
HRESULT LoadDictation([in, string] const WCHAR *name, [in] SPLOADOPTIONS options);
HRESULT UnloadDictation();
HRESULT SetDictationState([in] SPRULESTATE state);
HRESULT SetWordSequenceData([in] const WCHAR *text, [in] ULONG count, [in] const SPTEXTSELECTIONINFO *info);
HRESULT SetTextSelection([in] const SPTEXTSELECTIONINFO *info);
HRESULT IsPronounceable([in, string] const WCHAR *word, [out] SPWORDPRONOUNCEABLE *pronounceable);
HRESULT SetGrammarState([in] SPGRAMMARSTATE state);
HRESULT SaveCmd([in] IStream *stream, [out, optional] WCHAR **error);
HRESULT GetGrammarState([out] SPGRAMMARSTATE *state);
};
[
object,
uuid(259684dc-37c3-11d2-9603-00c04f8ee628),
pointer_default(unique),
restricted
]
interface ISpNotifySink : IUnknown
{
HRESULT Notify(void);
}
[
object,
uuid(6c44df74-72b9-4992-a1ec-ef996e0422d4),
pointer_default(unique),
restricted
]
interface ISpVoice : ISpEventSource
{
HRESULT SetOutput([in] IUnknown *unk, [in] BOOL changes);
HRESULT GetOutputObjectToken([out] ISpObjectToken **token);
HRESULT GetOutputStream([out] ISpStreamFormat **stream);
HRESULT Pause(void);
HRESULT Resume(void);
HRESULT SetVoice([in] ISpObjectToken *token);
HRESULT GetVoice([out] ISpObjectToken **token);
HRESULT Speak([in, string] const WCHAR *pwcs,
[in] DWORD flags,
[out] ULONG *number);
HRESULT SpeakStream([in] IStream *stream,
[in] DWORD flags,
[out] ULONG *number);
HRESULT GetStatus(
[out] SPVOICESTATUS *status,
[out, string] WCHAR **bookmark);
HRESULT Skip([in,string] const WCHAR *type, [in] long items, [out] ULONG *skipped);
HRESULT SetPriority([in] SPVPRIORITY priority);
HRESULT GetPriority([out] SPVPRIORITY* priority);
HRESULT SetAlertBoundary([in] SPEVENTENUM boundary);
HRESULT GetAlertBoundary([out] SPEVENTENUM* boundary);
HRESULT SetRate([in] long adjust);
HRESULT GetRate([out] long *adjust);
HRESULT SetVolume([in] USHORT volume);
HRESULT GetVolume([out] USHORT *volume);
HRESULT WaitUntilDone([in] ULONG timeout);
HRESULT SetSyncSpeakTimeout([in] ULONG timeout);
HRESULT GetSyncSpeakTimeout([out] ULONG *timeout);
[local] HANDLE SpeakCompleteEvent();
[local] HRESULT IsUISupported(
[in] const WCHAR *type,
[in] void * extra,
[in] ULONG count,
[out] BOOL *supported);
[local] HRESULT DisplayUI(
[in] HWND parent,
[in] const WCHAR *title,
[in] const WCHAR *type,
[in] void *extra,
[in] ULONG count);
};
[
object,
uuid(5eff4aef-8487-11d2-961c-00c04f8ee628),
pointer_default(unique),
restricted
]
interface ISpNotifySource : IUnknown
{
HRESULT SetNotifySink([in] ISpNotifySink *sink);
[local] HRESULT SetNotifyWindowMessage(
[in] HWND hwnd,
[in] UINT msg,
[in] WPARAM wparam,
[in] LPARAM lparam);
[local] HRESULT SetNotifyCallbackFunction(
[in] SPNOTIFYCALLBACK *callback,
[in] WPARAM wparam,
[in] LPARAM lparam);
[local] HRESULT SetNotifyCallbackInterface(
[in] ISpNotifyCallback *callback,
[in] WPARAM wparam,
[in] LPARAM lparam);
[local] HRESULT SetNotifyWin32Event(void);
[local] HRESULT WaitForNotifyEvent([in] DWORD milliseconds);
[local] HANDLE GetNotifyEventHandle();
}
[
object,
uuid(be7a9cce-5f9e-11d2-960f-00c04f8ee628),
pointer_default(unique),
local,
restricted
]
interface ISpEventSource : ISpNotifySource
{
HRESULT SetInterest([in] ULONGLONG event, [in] ULONGLONG queued);
HRESULT GetEvents([in] ULONG count,
[out, size_is(count)] SPEVENT *array,
[out] ULONG *fetched);
HRESULT GetInfo([out] SPEVENTSOURCEINFO *info);
};
[
object,
uuid(f740a62f-7c15-489e-8234-940a33d9272d),
pointer_default(unique),
local,
restricted
]
interface ISpRecoContext : ISpEventSource
{
HRESULT GetRecognizer([out] ISpRecognizer **recognizer);
HRESULT CreateGrammar([in] ULONGLONG grammar, [out] ISpRecoGrammar **spgrammar);
HRESULT GetStatus([out] SPRECOCONTEXTSTATUS *status);
HRESULT GetMaxAlternates([in] ULONG *alternates);
HRESULT SetMaxAlternates([in] ULONG alternates);
HRESULT SetAudioOptions([in] SPAUDIOOPTIONS options, [in] const GUID *format, [in] const WAVEFORMATEX *wave);
HRESULT GetAudioOptions([in] SPAUDIOOPTIONS *options, [out] GUID *format, [out] WAVEFORMATEX **wave);
HRESULT DeserializeResult([in] const SPSERIALIZEDRESULT *serialized, [out] ISpRecoResult **result);
HRESULT Bookmark([in] SPBOOKMARKOPTIONS options, [in] ULONGLONG position, [in] LPARAM event);
HRESULT SetAdaptationData([in, string] const WCHAR *data, [in] const ULONG count);
HRESULT Pause(DWORD reserved);
HRESULT Resume(DWORD reserved);
HRESULT SetVoice([in] ISpVoice *voice, [in] BOOL changes);
HRESULT GetVoice([out] ISpVoice **voice);
HRESULT SetVoicePurgeEvent([in] ULONGLONG interest);
HRESULT GetVoicePurgeEvent([out] ULONGLONG *interest);
HRESULT SetContextState([in] SPCONTEXTSTATE state);
HRESULT GetContextState([in] SPCONTEXTSTATE *state);
};
[
object,
uuid(bed530be-2606-4f4d-a1c0-54c5cda5566f),
pointer_default(unique),
restricted
]
interface ISpStreamFormat : IStream
{
HRESULT GetFormat(GUID *format, WAVEFORMATEX **wave);
}
[
object,
uuid(5b4fb971-b115-4de1-ad97-e482e3bf6ee4),
pointer_default(unique),
local,
restricted
]
interface ISpProperties : IUnknown
{
HRESULT SetPropertyNum([in] const WCHAR *name, [in] long value);
HRESULT GetPropertyNum([in] const WCHAR *name, [out] long *value);
HRESULT SetPropertyString([in] const WCHAR *name, [in] const WCHAR *value);
HRESULT GetPropertyString([in] const WCHAR *name, [out] WCHAR **value);
};
[
object,
uuid(c2b5f241-daa0-4507-9e16-5a1eaa2b7a5c),
pointer_default(unique),
restricted
]
interface ISpRecognizer : ISpProperties
{
HRESULT SetRecognizer([in] ISpObjectToken *recognizer);
HRESULT GetRecognizer([out] ISpObjectToken **recognizer);
HRESULT SetInput([in] IUnknown *input, [in] BOOL changes);
HRESULT GetInputObjectToken([out] ISpObjectToken **token);
HRESULT GetInputStream( [out] ISpStreamFormat **stream);
HRESULT CreateRecoContext([out] ISpRecoContext **cxt);
HRESULT GetRecoProfile([out] ISpObjectToken **token);
HRESULT SetRecoProfile([in] ISpObjectToken *token);
HRESULT IsSharedInstance(void);
HRESULT GetRecoState([out] SPRECOSTATE *state);
HRESULT SetRecoState([in] SPRECOSTATE state);
HRESULT GetStatus([out] SPRECOGNIZERSTATUS *status);
HRESULT GetFormat([in] SPSTREAMFORMATTYPE type, [out] GUID *format, [out] WAVEFORMATEX **wave);
[local] HRESULT IsUISupported([in] const WCHAR *type, [in] void *extra, [in] ULONG count,
[out] BOOL *supported);
[local] HRESULT DisplayUI([in] HWND hwnd,[in] const WCHAR *title, [in] const WCHAR *type,
[in] void *extra, [in] ULONG cnt);
HRESULT EmulateRecognition([in] ISpPhrase *phrase);
};
[
object,
uuid(12e3cca9-7518-44c5-a5e7-ba5a79cb929e),
pointer_default(unique),
local,
restricted
]
interface ISpStream : ISpStreamFormat
{
HRESULT SetBaseStream([in] IStream *stream, [in] REFGUID format, [in] const WAVEFORMATEX *wave);
HRESULT GetBaseStream([out] IStream **stream);
HRESULT BindToFile([in] LPCWSTR filename, [in] SPFILEMODE mode, [in] const GUID *format,
const WAVEFORMATEX *wave, [in] ULONGLONG interest);
HRESULT Close();
}
[
helpstring("Speech Object Library"),
uuid(c866ca3a-32f7-11d2-9602-00c04f8ee628),
version(5.4)
]
library SpeechLib
{
importlib("stdole2.tlb");
#include "sapiaut.idl"
[
uuid(a910187f-0c7a-45ac-92cc-59edafb77b53),
helpstring("SpObjectTokenCategory Class"),
progid("SAPI.SpObjectTokenCategory.1"),
vi_progid("SAPI.SpObjectTokenCategory"),
threading(both)
]
coclass SpObjectTokenCategory
{
interface ISpObjectTokenCategory;
}
[
uuid(3bee4890-4fe9-4a37-8c1e-5e7e12791c1f)
]
coclass SpSharedRecognizer
{
/*[default] interface ISpeechRecognizer;*/
interface ISpRecognizer;
};
[
uuid(96749377-3391-11d2-9ee3-00c04f797396)
]
coclass SpVoice
{
interface ISpVoice;
[default] interface ISpeechVoice;
};
[
uuid(947812b3-2ae1-4644-ba86-9e90ded7ec91),
]
coclass SpFileStream
{
interface ISpStream;
[default] interface ISpeechFileStream;
};
}