Compartilhar via


ISpRecoContext::CreateGrammar (Windows Embedded CE 6.0)

1/6/2010

This method creates a grammar.

Syntax

HRESULT CreateGrammar(
  ULONGLONG ullGrammarId,
  ISpRecoGrammar** ppGrammar
);

Parameters

  • ullGrammarId
    [in] Grammar identifier. The identifier is used by the application and is not required. This identifier is associated with all result objects from the grammar, as defined by an SPPHRASE structure (ullGrammarID member).
  • ppGrammar
    [out] Address of a pointer to an object implementing ISpRecoGrammar. The application must call IUnknown::Release on the object when finished using it.

Return Value

The following table shows the possible return values.

Value Description

S_OK

Function completed successfully.

E_POINTER

ppGrammar is invalid.

E_OUTOFMEMORY

Not enough system memory to create a grammar object.

SPERR_SR_ENGINE_EXCEPTION

An exception was thrown by the SR engine during OnCreateGrammar.

FAILED(hr)

Appropriate error message.

Example

The following code snippet illustrates the use of this method.

HRESULT hr = S_OK;
hr = cpRecoContext->CreateGrammar(GRAM_ID, &cpRecoGrammar);
// Check hr
// load a cfg from a file
hr = cpRecoGrammar->LoadCmdFromFile(MY_CFG_FILENAME, SPLO_STATIC);
// Check hr
// start the top-level rules
hr = cpRecoGrammar->SetRuleState(NULL, NULL, SPRS_ACTIVE);
// Check hr
// get a recognition
// ...
// get the recognized phrase from the recognition result object
hr = cpRecoResult->GetPhrase(&pPhrase);
// Check hr
// check the grammar identifier of the recognition result
SPDBG_ASSERT(GRAM_ID == pPhrase->ullGrammarID);

Requirements

Header sapi.h, sapi.idl
Library sapilib.lib
Windows Embedded CE Windows CE .NET 4.1 and later

See Also

Reference

ISpRecoContext
SAPI Interfaces