X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/b75a7d8f3b4adbae880cab104ce2c6a50eee4db2..fd0068a84e9996f225edba706498f6ed413d0673:/icuSources/layout/TrimmedArrayProcessor.cpp diff --git a/icuSources/layout/TrimmedArrayProcessor.cpp b/icuSources/layout/TrimmedArrayProcessor.cpp index 90e7850a..a68c0562 100644 --- a/icuSources/layout/TrimmedArrayProcessor.cpp +++ b/icuSources/layout/TrimmedArrayProcessor.cpp @@ -1,7 +1,6 @@ /* - * @(#)TrimmedArrayProcessor.cpp 1.6 00/03/15 * - * (C) Copyright IBM Corp. 1998-2003 - All Rights Reserved + * (C) Copyright IBM Corp. 1998-2004 - All Rights Reserved * */ @@ -11,11 +10,12 @@ #include "NonContextualGlyphSubst.h" #include "NonContextualGlyphSubstProc.h" #include "TrimmedArrayProcessor.h" +#include "LEGlyphStorage.h" #include "LESwaps.h" U_NAMESPACE_BEGIN -const char TrimmedArrayProcessor::fgClassID=0; +UOBJECT_DEFINE_RTTI_IMPLEMENTATION(TrimmedArrayProcessor) TrimmedArrayProcessor::TrimmedArrayProcessor() { @@ -35,17 +35,19 @@ TrimmedArrayProcessor::~TrimmedArrayProcessor() { } -void TrimmedArrayProcessor::process(LEGlyphID *glyphs, le_int32 * /*charIndices*/, le_int32 glyphCount) +void TrimmedArrayProcessor::process(LEGlyphStorage &glyphStorage) { + le_int32 glyphCount = glyphStorage.getGlyphCount(); le_int32 glyph; for (glyph = 0; glyph < glyphCount; glyph += 1) { - TTGlyphID ttGlyph = (TTGlyphID) LE_GET_GLYPH(glyphs[glyph]); + LEGlyphID thisGlyph = glyphStorage[glyph]; + TTGlyphID ttGlyph = (TTGlyphID) LE_GET_GLYPH(thisGlyph); if ((ttGlyph > firstGlyph) && (ttGlyph < lastGlyph)) { TTGlyphID newGlyph = SWAPW(trimmedArrayLookupTable->valueArray[ttGlyph - firstGlyph]); - glyphs[glyph] = LE_SET_GLYPH(glyphs[glyph], newGlyph); + glyphStorage[glyph] = LE_SET_GLYPH(thisGlyph, newGlyph); } } }