author | sl@SLION-WIN7.fritz.box |
Fri, 15 Jun 2012 03:10:57 +0200 | |
changeset 0 | bde4ae8d615e |
permissions | -rw-r--r-- |
sl@0 | 1 |
/* |
sl@0 | 2 |
* |
sl@0 | 3 |
* (C) Copyright IBM Corp. 1998-2004 - All Rights Reserved |
sl@0 | 4 |
* |
sl@0 | 5 |
*/ |
sl@0 | 6 |
|
sl@0 | 7 |
#include "LETypes.h" |
sl@0 | 8 |
#include "OpenTypeTables.h" |
sl@0 | 9 |
#include "OpenTypeUtilities.h" |
sl@0 | 10 |
#include "CoverageTables.h" |
sl@0 | 11 |
#include "LESwaps.h" |
sl@0 | 12 |
|
sl@0 | 13 |
U_NAMESPACE_BEGIN |
sl@0 | 14 |
|
sl@0 | 15 |
le_int32 CoverageTable::getGlyphCoverage(LEGlyphID glyphID) const |
sl@0 | 16 |
{ |
sl@0 | 17 |
switch(SWAPW(coverageFormat)) |
sl@0 | 18 |
{ |
sl@0 | 19 |
case 0: |
sl@0 | 20 |
return -1; |
sl@0 | 21 |
|
sl@0 | 22 |
case 1: |
sl@0 | 23 |
{ |
sl@0 | 24 |
const CoverageFormat1Table *f1Table = (const CoverageFormat1Table *) this; |
sl@0 | 25 |
|
sl@0 | 26 |
return f1Table->getGlyphCoverage(glyphID); |
sl@0 | 27 |
} |
sl@0 | 28 |
|
sl@0 | 29 |
case 2: |
sl@0 | 30 |
{ |
sl@0 | 31 |
const CoverageFormat2Table *f2Table = (const CoverageFormat2Table *) this; |
sl@0 | 32 |
|
sl@0 | 33 |
return f2Table->getGlyphCoverage(glyphID); |
sl@0 | 34 |
} |
sl@0 | 35 |
|
sl@0 | 36 |
default: |
sl@0 | 37 |
return -1; |
sl@0 | 38 |
} |
sl@0 | 39 |
} |
sl@0 | 40 |
|
sl@0 | 41 |
le_int32 CoverageFormat1Table::getGlyphCoverage(LEGlyphID glyphID) const |
sl@0 | 42 |
{ |
sl@0 | 43 |
TTGlyphID ttGlyphID = (TTGlyphID) LE_GET_GLYPH(glyphID); |
sl@0 | 44 |
le_uint16 count = SWAPW(glyphCount); |
sl@0 | 45 |
le_uint8 bit = OpenTypeUtilities::highBit(count); |
sl@0 | 46 |
le_uint16 power = 1 << bit; |
sl@0 | 47 |
le_uint16 extra = count - power; |
sl@0 | 48 |
le_uint16 probe = power; |
sl@0 | 49 |
le_uint16 index = 0; |
sl@0 | 50 |
|
sl@0 | 51 |
if (SWAPW(glyphArray[extra]) <= ttGlyphID) { |
sl@0 | 52 |
index = extra; |
sl@0 | 53 |
} |
sl@0 | 54 |
|
sl@0 | 55 |
while (probe > (1 << 0)) { |
sl@0 | 56 |
probe >>= 1; |
sl@0 | 57 |
|
sl@0 | 58 |
if (SWAPW(glyphArray[index + probe]) <= ttGlyphID) { |
sl@0 | 59 |
index += probe; |
sl@0 | 60 |
} |
sl@0 | 61 |
} |
sl@0 | 62 |
|
sl@0 | 63 |
if (SWAPW(glyphArray[index]) == ttGlyphID) { |
sl@0 | 64 |
return index; |
sl@0 | 65 |
} |
sl@0 | 66 |
|
sl@0 | 67 |
return -1; |
sl@0 | 68 |
} |
sl@0 | 69 |
|
sl@0 | 70 |
le_int32 CoverageFormat2Table::getGlyphCoverage(LEGlyphID glyphID) const |
sl@0 | 71 |
{ |
sl@0 | 72 |
TTGlyphID ttGlyphID = (TTGlyphID) LE_GET_GLYPH(glyphID); |
sl@0 | 73 |
le_uint16 count = SWAPW(rangeCount); |
sl@0 | 74 |
le_int32 rangeIndex = |
sl@0 | 75 |
OpenTypeUtilities::getGlyphRangeIndex(ttGlyphID, rangeRecordArray, count); |
sl@0 | 76 |
|
sl@0 | 77 |
if (rangeIndex < 0) { |
sl@0 | 78 |
return -1; |
sl@0 | 79 |
} |
sl@0 | 80 |
|
sl@0 | 81 |
TTGlyphID firstInRange = SWAPW(rangeRecordArray[rangeIndex].firstGlyph); |
sl@0 | 82 |
le_uint16 startCoverageIndex = SWAPW(rangeRecordArray[rangeIndex].rangeValue); |
sl@0 | 83 |
|
sl@0 | 84 |
return startCoverageIndex + (ttGlyphID - firstInRange); |
sl@0 | 85 |
} |
sl@0 | 86 |
|
sl@0 | 87 |
U_NAMESPACE_END |