X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/374ca955a76ecab1204ca8bfa63ff9238d998416..b801cf366c7671a99bdcef84d1e9c0ec64b36723:/icuSources/layout/HanLayoutEngine.cpp diff --git a/icuSources/layout/HanLayoutEngine.cpp b/icuSources/layout/HanLayoutEngine.cpp index d319b1c5..25652bc1 100644 --- a/icuSources/layout/HanLayoutEngine.cpp +++ b/icuSources/layout/HanLayoutEngine.cpp @@ -1,7 +1,7 @@ /* * HanLayoutEngine.cpp: OpenType processing for Han fonts. * - * (C) Copyright IBM Corp. 1998-2004 - All Rights Reserved. + * (C) Copyright IBM Corp. 1998-2013 - All Rights Reserved. */ #include "LETypes.h" @@ -13,16 +13,37 @@ #include "HanLayoutEngine.h" #include "ScriptAndLanguageTags.h" #include "LEGlyphStorage.h" +#include "OpenTypeTables.h" U_NAMESPACE_BEGIN UOBJECT_DEFINE_RTTI_IMPLEMENTATION(HanOpenTypeLayoutEngine) +#define loclFeatureTag LE_LOCL_FEATURE_TAG +#define smplFeatureTag LE_SMPL_FEATURE_TAG +#define tradFeatureTag LE_TRAD_FEATURE_TAG + +#define loclFeatureMask 0x80000000UL +#define smplFeatureMask 0x40000000UL +#define tradFeatureMask 0x20000000UL + +static const FeatureMap featureMap[] = +{ + {loclFeatureTag, loclFeatureMask}, + {smplFeatureTag, smplFeatureMask}, + {tradFeatureTag, tradFeatureMask} +}; + +static const le_int32 featureMapCount = LE_ARRAY_SIZE(featureMap); + +#define features (loclFeatureMask) + HanOpenTypeLayoutEngine::HanOpenTypeLayoutEngine(const LEFontInstance *fontInstance, le_int32 scriptCode, le_int32 languageCode, - const GlyphSubstitutionTableHeader *gsubTable) - : OpenTypeLayoutEngine(fontInstance, scriptCode, languageCode, gsubTable) + le_int32 typoFlags, const LEReferenceTo &gsubTable, LEErrorCode &success) + : OpenTypeLayoutEngine(fontInstance, scriptCode, languageCode, typoFlags, gsubTable, success) { - // nothing else to do... + fFeatureMap = featureMap; + fFeatureMapCount = featureMapCount; } HanOpenTypeLayoutEngine::~HanOpenTypeLayoutEngine() @@ -30,14 +51,6 @@ HanOpenTypeLayoutEngine::~HanOpenTypeLayoutEngine() // nothing to do } -static const LETag emptyTag = 0x00000000; - -static const LETag loclFeatureTag = LE_LOCL_FEATURE_TAG; -static const LETag smplFeatureTag = LE_SMPL_FEATURE_TAG; -static const LETag tradFeatureTag = LE_TRAD_FEATURE_TAG; - -static const LETag features[] = {loclFeatureTag, emptyTag}; - le_int32 HanOpenTypeLayoutEngine::characterProcessing(const LEUnicode chars[], le_int32 offset, le_int32 count, le_int32 max, le_bool /*rightToLeft*/, LEUnicode *&/*outChars*/, LEGlyphStorage &glyphStorage, LEErrorCode &success) { @@ -62,7 +75,7 @@ le_int32 HanOpenTypeLayoutEngine::characterProcessing(const LEUnicode chars[], l // flag from the language tag lookups, so we can use these features // with the default LangSys... for (le_int32 i = 0; i < count; i += 1) { - glyphStorage.setAuxData(i, (void *) features, success); + glyphStorage.setAuxData(i, features, success); } return count;