golden hour
/opt/alt/libicu65/usr/share/doc/alt-libicu65-devel-65.1/samples/layout
⬆️ Go Up
Upload
File/Folder
Size
Actions
FontMap.GDI
426 B
Del
OK
FontMap.Gnome
392 B
Del
OK
FontMap.cpp
7.34 KB
Del
OK
FontMap.h
1.84 KB
Del
OK
FontTableCache.cpp
2.37 KB
Del
OK
FontTableCache.h
1.06 KB
Del
OK
GDIFontInstance.cpp
9.6 KB
Del
OK
GDIFontInstance.h
3.6 KB
Del
OK
GDIFontMap.cpp
1.32 KB
Del
OK
GDIFontMap.h
1.23 KB
Del
OK
GDIGUISupport.cpp
862 B
Del
OK
GDIGUISupport.h
949 B
Del
OK
GUISupport.h
890 B
Del
OK
GnomeFontInstance.cpp
5.43 KB
Del
OK
GnomeFontInstance.h
3.79 KB
Del
OK
GnomeFontMap.cpp
1.39 KB
Del
OK
GnomeFontMap.h
1.21 KB
Del
OK
GnomeGUISupport.cpp
1.05 KB
Del
OK
GnomeGUISupport.h
961 B
Del
OK
LayoutSample.rc
3.37 KB
Del
OK
Makefile
2.92 KB
Del
OK
Makefile.in
2.92 KB
Del
OK
RenderingSurface.h
1.09 KB
Del
OK
Sample.txt
1.66 KB
Del
OK
ScriptCompositeFontInstance.cpp
3.2 KB
Del
OK
ScriptCompositeFontInstance.h
6.15 KB
Del
OK
Surface.cpp
892 B
Del
OK
Surface.h
519 B
Del
OK
UnicodeReader.cpp
4.1 KB
Del
OK
UnicodeReader.h
999 B
Del
OK
arraymem.h
646 B
Del
OK
cgnomelayout.c
8.45 KB
Del
OK
clayout.c
9.82 KB
Del
OK
cmaps.cpp
5.3 KB
Del
OK
cmaps.h
2.06 KB
Del
OK
gdiglue.cpp
1.67 KB
Del
OK
gdiglue.h
983 B
Del
OK
gnomeglue.cpp
1.64 KB
Del
OK
gnomeglue.h
986 B
Del
OK
gnomelayout.cpp
8.5 KB
Del
OK
gsupport.h
370 B
Del
OK
layout.cpp
9.8 KB
Del
OK
layout.sln
1.17 KB
Del
OK
layout.vcxproj
12.92 KB
Del
OK
layout.vcxproj.filters
3.06 KB
Del
OK
paragraph.cpp
7.58 KB
Del
OK
paragraph.h
2.18 KB
Del
OK
pflow.c
9.27 KB
Del
OK
pflow.h
940 B
Del
OK
readme.html
7.32 KB
Del
OK
resource.h
907 B
Del
OK
rsurface.cpp
712 B
Del
OK
rsurface.h
528 B
Del
OK
sfnt.h
4.9 KB
Del
OK
ucreader.cpp
509 B
Del
OK
ucreader.h
422 B
Del
OK
Edit: cmaps.cpp
/* ******************************************************************************* * * © 2016 and later: Unicode, Inc. and others. * License & terms of use: http://www.unicode.org/copyright.html#License * ******************************************************************************* ****************************************************************************** * * * Copyright (C) 1999-2003, International Business Machines * Corporation and others. All Rights Reserved. * ****************************************************************************** * * file name: cmaps.cpp * * created on: ??/??/2001 * created by: Eric R. Mader */ #include "layout/LETypes.h" #include "layout/LESwaps.h" #include "sfnt.h" #include "cmaps.h" #define SWAPU16(code) ((LEUnicode16) SWAPW(code)) #define SWAPU32(code) ((LEUnicode32) SWAPL(code)) // // Finds the high bit by binary searching // through the bits in value. // le_uint8 highBit(le_uint32 value) { le_uint8 bit = 0; if (value >= 1 << 16) { value >>= 16; bit += 16; } if (value >= 1 << 8) { value >>= 8; bit += 8; } if (value >= 1 << 4) { value >>= 4; bit += 4; } if (value >= 1 << 2) { value >>= 2; bit += 2; } if (value >= 1 << 1) { value >>= 1; bit += 1; } return bit; } CMAPMapper *CMAPMapper::createUnicodeMapper(const CMAPTable *cmap) { le_uint16 i; le_uint16 nSubtables = SWAPW(cmap->numberSubtables); const CMAPEncodingSubtable *subtable = NULL; le_uint32 offset1 = 0, offset10 = 0; for (i = 0; i < nSubtables; i += 1) { const CMAPEncodingSubtableHeader *esh = &cmap->encodingSubtableHeaders[i]; if (SWAPW(esh->platformID) == 3) { switch (SWAPW(esh->platformSpecificID)) { case 1: offset1 = SWAPL(esh->encodingOffset); break; case 10: offset10 = SWAPL(esh->encodingOffset); break; } } } if (offset10 != 0) { subtable = (const CMAPEncodingSubtable *) ((const char *) cmap + offset10); } else if (offset1 != 0) { subtable = (const CMAPEncodingSubtable *) ((const char *) cmap + offset1); } else { return NULL; } switch (SWAPW(subtable->format)) { case 4: return new CMAPFormat4Mapper(cmap, (const CMAPFormat4Encoding *) subtable); case 12: { const CMAPFormat12Encoding *encoding = (const CMAPFormat12Encoding *) subtable; return new CMAPGroupMapper(cmap, encoding->groups, SWAPL(encoding->nGroups)); } default: break; } return NULL; } CMAPFormat4Mapper::CMAPFormat4Mapper(const CMAPTable *cmap, const CMAPFormat4Encoding *header) : CMAPMapper(cmap) { le_uint16 segCount = SWAPW(header->segCountX2) / 2; fEntrySelector = SWAPW(header->entrySelector); fRangeShift = SWAPW(header->rangeShift) / 2; fEndCodes = &header->endCodes[0]; fStartCodes = &header->endCodes[segCount + 1]; // + 1 for reservedPad... fIdDelta = &fStartCodes[segCount]; fIdRangeOffset = &fIdDelta[segCount]; } LEGlyphID CMAPFormat4Mapper::unicodeToGlyph(LEUnicode32 unicode32) const { if (unicode32 >= 0x10000) { return 0; } LEUnicode16 unicode = (LEUnicode16) unicode32; le_uint16 index = 0; le_uint16 probe = 1 << fEntrySelector; TTGlyphID result = 0; if (SWAPU16(fStartCodes[fRangeShift]) <= unicode) { index = fRangeShift; } while (probe > (1 << 0)) { probe >>= 1; if (SWAPU16(fStartCodes[index + probe]) <= unicode) { index += probe; } } if (unicode >= SWAPU16(fStartCodes[index]) && unicode <= SWAPU16(fEndCodes[index])) { if (fIdRangeOffset[index] == 0) { result = (TTGlyphID) unicode; } else { le_uint16 offset = unicode - SWAPU16(fStartCodes[index]); le_uint16 rangeOffset = SWAPW(fIdRangeOffset[index]); le_uint16 *glyphIndexTable = (le_uint16 *) ((char *) &fIdRangeOffset[index] + rangeOffset); result = SWAPW(glyphIndexTable[offset]); } result += SWAPW(fIdDelta[index]); } else { result = 0; } return LE_SET_GLYPH(0, result); } CMAPFormat4Mapper::~CMAPFormat4Mapper() { // parent destructor does it all } CMAPGroupMapper::CMAPGroupMapper(const CMAPTable *cmap, const CMAPGroup *groups, le_uint32 nGroups) : CMAPMapper(cmap), fGroups(groups) { le_uint8 bit = highBit(nGroups); fPower = 1 << bit; fRangeOffset = nGroups - fPower; } LEGlyphID CMAPGroupMapper::unicodeToGlyph(LEUnicode32 unicode32) const { le_int32 probe = fPower; le_int32 range = 0; if (SWAPU32(fGroups[fRangeOffset].startCharCode) <= unicode32) { range = fRangeOffset; } while (probe > (1 << 0)) { probe >>= 1; if (SWAPU32(fGroups[range + probe].startCharCode) <= unicode32) { range += probe; } } if (SWAPU32(fGroups[range].startCharCode) <= unicode32 && SWAPU32(fGroups[range].endCharCode) >= unicode32) { return (LEGlyphID) (SWAPU32(fGroups[range].startGlyphCode) + unicode32 - SWAPU32(fGroups[range].startCharCode)); } return 0; } CMAPGroupMapper::~CMAPGroupMapper() { // parent destructor does it all }
Save