ISpLexicon::GetGenerationChange (Windows Embedded CE 6.0)
1/6/2010
This method gets a list of words that have changed between the current generation and a specified generation.
Syntax
HRESULT GetGenerationChange(
DWORD dwFlags,
DWORD* pdwGeneration,
SPWORDLIST* pWordList
);
Parameters
- dwFlags
[in] Lexicon category. Possible values are defined by the SPLEXICONTYPE enumeration. Currently the value chosen must be zero for the SpLexicon (container lexicon) class. It must be the correct flag for the SpUnCompressedLexicon class, either eLEXTYPE_USER or eLEXTYPE_APP.
- pdwGeneration
[in, out] Pointer to the generation identifier. On input, the identifier is for the client. On output, the current current generation identifier is provided.
- pWordList
[in, out] Pointer to an SPWORDLIST structure containing the word list and its related information.
Return Value
The following table shows the possible return values.
Value | Description |
---|---|
S_OK |
Function completed successfully. |
SP_LEX_NOTHING_TO_SYNC |
Nothing changed because the passed in generation identifier. |
SPERR_LEX_VERY_OUT_OF_SYNC |
There are too many changes because the passed in generation identifier, so that a change history is not available. It could also be returned after installation/uninstallation of an application lexicon. Use ISpLexicon::GetWords if GetGenerationChange returns SPERR_LEX_VERY_OUT_OF_SYNC to regenerate an entire list of words based on the current generation. |
E_POINTER |
pdwGeneration or pWordList is not a valid write pointer. |
E_INVALIDARG |
dwFlags is invalid. |
SPERR_UNINITIALIZED |
Interface has not been initialized. |
E_OUTOFMEMORY |
Exceeded available memory. |
FAILED(hr) |
Appropriate error message. |
Remarks
This method and ISpLexicon::GetGeneration can be used when an application wants to determine what it has done to the lexicon over a given period of time (for example, to remove changes it has made due to a user cancel). To do this, the application calls ISpLexicon::GetGeneration before it starts modifying the lexicon, and stores that generation identifier. Later, when the application must determine the words in the lexicon it has modified, it calls ISpLexicon::GetGenerationChange with the stored identifier. This can only be done for small changes as SPERR_LEX_VERY_OUT_OF_SYNC will be returned once sufficient changes have been made.
Example
The following is an example of this method.
for (;;)
{
hr = pISpLexicon->GetGenerationChange(eLEXTYPE_USER,
&m_dwGeneration,
&spwordlist);
// If, for example, a new application lexicon was added,
// rebuild from scratch.
if (hr == SPERR_LEX_VERY_OUT_OF_SYNC)
{
Rebuild(); // Call GetWords
}
else if (FAILED(hr))
{
DealWithOtherErrors();
}
else
{
// Loop through the changed words, and their new pronunciations
for (SPWORD *pword = spwordlist.pFirstWord;
pword != NULL;
pword = pword->pNextWord)
{
for (SPWORDPRON pwordpron = pword->pFirstWordPron;
pwordpron != NULL;
pwordpron = pwordpron->pNextWordPron)
{
if(pword->eWordType == eWORDTYPE_ADDED)
{
AddPronunciationToEngineDataStructures(
pword->pszWord,
pwordpron->ePartOfSpeech,
pwordpron->pszPronIPA);
}
else // pword->eWordType == eWORDTYPE_DELETED
{
RemovePronunciationFromEngineDataStructures(
pword->pszWord,
pwordpron->ePartOfSpeech,
pwordpron->pszPronIPA);
}
}
}
}
}
Requirements
Header | sapi.h, sapi.idl |
Library | sapilib.lib |
Windows Embedded CE | Windows CE .NET 4.1 and later |