本文整理汇总了C++中SynGram::languages方法的典型用法代码示例。如果您正苦于以下问题:C++ SynGram::languages方法的具体用法?C++ SynGram::languages怎么用?C++ SynGram::languages使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SynGram
的用法示例。
在下文中一共展示了SynGram::languages方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: SG
CasingCoder::CasingCoder( SynGram &sg )
: SG(sg)
{
default_xlat = new XLAT();
default_xlat->use_unicode = true;
GraphGram &gg = sg.GetDict().GetGraphGram();
LexicalAutomat &la = sg.GetDict().GetLexAuto();
Lower=UNKNOWN; FirstCapitalized=UNKNOWN; Upper=UNKNOWN; EachLexemCapitalized=UNKNOWN;
UnknownEntries_ekey=UNKNOWN;
icoord_casing = sg.FindCoord( L"CharCasing" ).GetIndex();
if( icoord_casing!=UNKNOWN )
{
const Solarix::GramCoord &c = sg.coords()[icoord_casing];
Lower = c.FindState( L"Lower" );
FirstCapitalized = c.FindState(L"FirstCapitalized");
Upper = c.FindState(L"Upper");
EachLexemCapitalized = c.FindState(L"EachLexemCapitalized");
UnknownEntries_ekey = la.GetUnknownEntryKey();
// ------
//lem::FString msg = lem::format_str( "icoord_casing=%d Lower=%d FirstCapitalized=%d Upper=%d", icoord_casing, Lower, FirstCapitalized, Upper );
//MessageBox( NULL, msg.c_str(), "DEBUG-2", MB_OK );
// ------
}
// Определим языки вывода по-умолчанию
sg.GetLanguageUsage().GetOutputLanguages(default_xlat->id_langs);
// Для каждого языка смотрим имена таблиц для перевода в верхний и нижний регистры.
for( lem::Container::size_type i=0; i<default_xlat->id_langs.size(); ++i )
{
const int id_lang = default_xlat->id_langs[i];
const SG_Language &lang = sg.languages()[id_lang];
const int iparam_l = lang.FindParam( L"LowerCase", 0 );
if( iparam_l!=UNKNOWN )
{
const lem::UFString &xlat_name = lang.params[iparam_l]->values.front();
const GG_CharOperation *xlat = gg.GetCharOperations()[xlat_name.c_str()];
default_xlat->lower_xlat.push_back(xlat);
}
const int iparam_u = lang.FindParam( L"UpperCase", 0 );
if( iparam_u!=UNKNOWN )
{
const lem::UFString &xlat_name = lang.params[iparam_u]->GetValue();
const GG_CharOperation *xlat = gg.GetCharOperations()[xlat_name.c_str()];
default_xlat->upper_xlat.push_back(xlat);
}
}
if( !default_xlat->upper_xlat.empty() && !default_xlat->lower_xlat.empty() )
default_xlat->use_unicode = false;
for( lem::Container::size_type i=0; i<default_xlat->id_langs.size(); ++i )
lang2xlat.insert( std::make_pair( default_xlat->id_langs[i], default_xlat ) );
return;
}