3 * (C) Copyright IBM Corp. and others 1998-2015 - All Rights Reserved
8 #include "MorphTables.h"
9 #include "SubtableProcessor2.h"
10 #include "NonContextualGlyphSubst.h"
11 #include "NonContextualGlyphSubstProc2.h"
12 #include "SegmentArrayProcessor2.h"
13 #include "LEGlyphStorage.h"
18 UOBJECT_DEFINE_RTTI_IMPLEMENTATION(SegmentArrayProcessor2
)
20 SegmentArrayProcessor2::SegmentArrayProcessor2()
24 SegmentArrayProcessor2::SegmentArrayProcessor2(const LEReferenceTo
<MorphSubtableHeader2
> &morphSubtableHeader
, LEErrorCode
&success
)
25 : NonContextualGlyphSubstitutionProcessor2(morphSubtableHeader
, success
)
27 const LEReferenceTo
<NonContextualGlyphSubstitutionHeader2
> header(morphSubtableHeader
, success
);
28 segmentArrayLookupTable
= LEReferenceTo
<SegmentArrayLookupTable
>(morphSubtableHeader
, success
, &header
->table
); // don't parent to 'header' as it is on the stack
31 SegmentArrayProcessor2::~SegmentArrayProcessor2()
35 void SegmentArrayProcessor2::process(LEGlyphStorage
&glyphStorage
, LEErrorCode
&success
)
37 const LookupSegment
*segments
= segmentArrayLookupTable
->segments
;
38 le_int32 glyphCount
= glyphStorage
.getGlyphCount();
41 if (LE_FAILURE(success
)) return;
43 for (glyph
= 0; glyph
< glyphCount
; glyph
+= 1) {
44 LEGlyphID thisGlyph
= glyphStorage
[glyph
];
45 const LookupSegment
*lookupSegment
= segmentArrayLookupTable
->lookupSegment(segmentArrayLookupTable
, segments
, thisGlyph
, success
);
47 if (lookupSegment
!= NULL
) {
48 TTGlyphID firstGlyph
= SWAPW(lookupSegment
->firstGlyph
);
49 le_int16 offset
= SWAPW(lookupSegment
->value
);
52 TTGlyphID
*glyphArray
= (TTGlyphID
*) ((char *) subtableHeader
.getAliasRAW() + offset
);
53 TTGlyphID newGlyph
= SWAPW(glyphArray
[LE_GET_GLYPH(thisGlyph
) - firstGlyph
]);
55 glyphStorage
[glyph
] = LE_SET_GLYPH(thisGlyph
, newGlyph
);