]> git.saurik.com Git - apple/icu.git/blame - icuSources/layout/ExtensionSubtables.cpp
ICU-511.27.tar.gz
[apple/icu.git] / icuSources / layout / ExtensionSubtables.cpp
CommitLineData
b75a7d8f
A
1/*
2 * %W% %E%
3 *
4388f060 4 * (C) Copyright IBM Corp. 2008-2011 - All Rights Reserved
b75a7d8f
A
5 *
6 */
7
8#include "LETypes.h"
9#include "OpenTypeTables.h"
10#include "GlyphSubstitutionTables.h"
11#include "LookupProcessor.h"
12#include "ExtensionSubtables.h"
13#include "GlyphIterator.h"
14#include "LESwaps.h"
15
16U_NAMESPACE_BEGIN
17
729e4ab9 18// read a 32-bit value that might only be 16-bit-aligned in memory
4388f060
A
19static inline le_uint32 READ_LONG(le_uint32 code) {
20 le_uint16* first = ((le_uint16*)&code);
21 le_uint16* second = (((le_uint16*)&code) + 1);
22 return (le_uint32)((SWAPW(*first) << 16) + SWAPW(*second));
23}
b75a7d8f
A
24
25// FIXME: should look at the format too... maybe have a sub-class for it?
26le_uint32 ExtensionSubtable::process(const LookupProcessor *lookupProcessor, le_uint16 lookupType,
729e4ab9 27 GlyphIterator *glyphIterator, const LEFontInstance *fontInstance, LEErrorCode& success) const
b75a7d8f 28{
729e4ab9
A
29 if (LE_FAILURE(success)) {
30 return 0;
31 }
32
b75a7d8f
A
33 le_uint16 elt = SWAPW(extensionLookupType);
34
4388f060 35 if (elt != lookupType) {
729e4ab9 36 le_uint32 extOffset = READ_LONG(extensionOffset);
b75a7d8f
A
37 LookupSubtable *subtable = (LookupSubtable *) ((char *) this + extOffset);
38
729e4ab9 39 return lookupProcessor->applySubtable(subtable, elt, glyphIterator, fontInstance, success);
b75a7d8f
A
40 }
41
42 return 0;
43}
44
45U_NAMESPACE_END