pango 3.1.0-x86-mingw32 → 3.1.1-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +9 -4
- data/ext/pango/rbpangolayoutline.c +6 -2
- data/lib/2.2/pango.so +0 -0
- data/lib/2.3/pango.so +0 -0
- data/lib/2.4/pango.so +0 -0
- data/sample/layout.rb +1 -1
- data/vendor/local/bin/derb.exe +0 -0
- data/vendor/local/bin/genbrk.exe +0 -0
- data/vendor/local/bin/genccode.exe +0 -0
- data/vendor/local/bin/gencfu.exe +0 -0
- data/vendor/local/bin/gencmn.exe +0 -0
- data/vendor/local/bin/gencnval.exe +0 -0
- data/vendor/local/bin/gendict.exe +0 -0
- data/vendor/local/bin/gennorm2.exe +0 -0
- data/vendor/local/bin/genrb.exe +0 -0
- data/vendor/local/bin/gensprep.exe +0 -0
- data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
- data/vendor/local/bin/hb-shape.exe +0 -0
- data/vendor/local/bin/hb-view.exe +0 -0
- data/vendor/local/bin/icu-config +18 -13
- data/vendor/local/bin/icuinfo.exe +0 -0
- data/vendor/local/bin/icupkg.exe +0 -0
- data/vendor/local/bin/libharfbuzz-0.dll +0 -0
- data/vendor/local/bin/libpango-1.0-0.dll +0 -0
- data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
- data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
- data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
- data/vendor/local/bin/makeconv.exe +0 -0
- data/vendor/local/bin/pango-view.exe +0 -0
- data/vendor/local/bin/pkgdata.exe +0 -0
- data/vendor/local/bin/uconv.exe +0 -0
- data/vendor/local/include/harfbuzz/hb-font.h +5 -0
- data/vendor/local/include/harfbuzz/hb-glib.h +2 -1
- data/vendor/local/include/harfbuzz/hb-ot-layout.h +19 -0
- data/vendor/local/include/harfbuzz/hb-shape-plan.h +19 -0
- data/vendor/local/include/harfbuzz/hb-version.h +3 -3
- data/vendor/local/include/unicode/alphaindex.h +2 -0
- data/vendor/local/include/unicode/appendable.h +2 -0
- data/vendor/local/include/unicode/basictz.h +2 -0
- data/vendor/local/include/unicode/brkiter.h +7 -0
- data/vendor/local/include/unicode/bytestream.h +2 -0
- data/vendor/local/include/unicode/bytestrie.h +3 -2
- data/vendor/local/include/unicode/bytestriebuilder.h +4 -4
- data/vendor/local/include/unicode/calendar.h +2 -0
- data/vendor/local/include/unicode/caniter.h +2 -0
- data/vendor/local/include/unicode/chariter.h +2 -0
- data/vendor/local/include/unicode/choicfmt.h +2 -0
- data/vendor/local/include/unicode/coleitr.h +2 -0
- data/vendor/local/include/unicode/coll.h +2 -0
- data/vendor/local/include/unicode/compactdecimalformat.h +4 -3
- data/vendor/local/include/unicode/curramt.h +2 -0
- data/vendor/local/include/unicode/currpinf.h +2 -0
- data/vendor/local/include/unicode/currunit.h +2 -0
- data/vendor/local/include/unicode/datefmt.h +2 -0
- data/vendor/local/include/unicode/dbbi.h +2 -0
- data/vendor/local/include/unicode/dcfmtsym.h +2 -0
- data/vendor/local/include/unicode/decimfmt.h +9 -5
- data/vendor/local/include/unicode/docmain.h +3 -1
- data/vendor/local/include/unicode/dtfmtsym.h +26 -14
- data/vendor/local/include/unicode/dtintrv.h +2 -0
- data/vendor/local/include/unicode/dtitvfmt.h +2 -0
- data/vendor/local/include/unicode/dtitvinf.h +8 -3
- data/vendor/local/include/unicode/dtptngen.h +13 -9
- data/vendor/local/include/unicode/dtrule.h +2 -0
- data/vendor/local/include/unicode/enumset.h +2 -0
- data/vendor/local/include/unicode/errorcode.h +2 -0
- data/vendor/local/include/unicode/fieldpos.h +5 -2
- data/vendor/local/include/unicode/filteredbrk.h +10 -12
- data/vendor/local/include/unicode/fmtable.h +4 -2
- data/vendor/local/include/unicode/format.h +2 -0
- data/vendor/local/include/unicode/fpositer.h +2 -0
- data/vendor/local/include/unicode/gender.h +2 -0
- data/vendor/local/include/unicode/gregocal.h +2 -0
- data/vendor/local/include/unicode/icudataver.h +2 -0
- data/vendor/local/include/unicode/icuplug.h +12 -2
- data/vendor/local/include/unicode/idna.h +6 -4
- data/vendor/local/include/unicode/listformatter.h +2 -0
- data/vendor/local/include/unicode/localpointer.h +19 -28
- data/vendor/local/include/unicode/locdspnm.h +2 -0
- data/vendor/local/include/unicode/locid.h +2 -0
- data/vendor/local/include/unicode/measfmt.h +21 -2
- data/vendor/local/include/unicode/measunit.h +50 -24
- data/vendor/local/include/unicode/measure.h +2 -0
- data/vendor/local/include/unicode/messagepattern.h +2 -0
- data/vendor/local/include/unicode/msgfmt.h +2 -0
- data/vendor/local/include/unicode/normalizer2.h +2 -0
- data/vendor/local/include/unicode/normlzr.h +4 -4
- data/vendor/local/include/unicode/numfmt.h +8 -6
- data/vendor/local/include/unicode/numsys.h +2 -0
- data/vendor/local/include/unicode/parseerr.h +2 -0
- data/vendor/local/include/unicode/parsepos.h +2 -0
- data/vendor/local/include/unicode/platform.h +8 -0
- data/vendor/local/include/unicode/plurfmt.h +2 -0
- data/vendor/local/include/unicode/plurrule.h +2 -0
- data/vendor/local/include/unicode/ptypes.h +2 -0
- data/vendor/local/include/unicode/putil.h +2 -0
- data/vendor/local/include/unicode/rbbi.h +18 -66
- data/vendor/local/include/unicode/rbnf.h +8 -0
- data/vendor/local/include/unicode/rbtz.h +2 -0
- data/vendor/local/include/unicode/regex.h +2 -0
- data/vendor/local/include/unicode/region.h +3 -1
- data/vendor/local/include/unicode/reldatefmt.h +19 -9
- data/vendor/local/include/unicode/rep.h +2 -0
- data/vendor/local/include/unicode/resbund.h +2 -0
- data/vendor/local/include/unicode/schriter.h +2 -0
- data/vendor/local/include/unicode/scientificnumberformatter.h +2 -0
- data/vendor/local/include/unicode/search.h +2 -0
- data/vendor/local/include/unicode/selfmt.h +2 -0
- data/vendor/local/include/unicode/simpleformatter.h +2 -0
- data/vendor/local/include/unicode/simpletz.h +2 -0
- data/vendor/local/include/unicode/smpdtfmt.h +9 -1
- data/vendor/local/include/unicode/sortkey.h +2 -0
- data/vendor/local/include/unicode/std_string.h +2 -0
- data/vendor/local/include/unicode/strenum.h +2 -0
- data/vendor/local/include/unicode/stringpiece.h +5 -3
- data/vendor/local/include/unicode/stringtriebuilder.h +13 -1
- data/vendor/local/include/unicode/stsearch.h +2 -0
- data/vendor/local/include/unicode/symtable.h +2 -0
- data/vendor/local/include/unicode/tblcoll.h +3 -1
- data/vendor/local/include/unicode/timezone.h +2 -0
- data/vendor/local/include/unicode/tmunit.h +8 -0
- data/vendor/local/include/unicode/tmutamt.h +2 -0
- data/vendor/local/include/unicode/tmutfmt.h +5 -0
- data/vendor/local/include/unicode/translit.h +2 -0
- data/vendor/local/include/unicode/tzfmt.h +2 -0
- data/vendor/local/include/unicode/tznames.h +16 -2
- data/vendor/local/include/unicode/tzrule.h +2 -0
- data/vendor/local/include/unicode/tztrans.h +2 -0
- data/vendor/local/include/unicode/ubidi.h +20 -8
- data/vendor/local/include/unicode/ubiditransform.h +321 -0
- data/vendor/local/include/unicode/ubrk.h +26 -7
- data/vendor/local/include/unicode/ucal.h +8 -4
- data/vendor/local/include/unicode/ucasemap.h +2 -0
- data/vendor/local/include/unicode/ucat.h +2 -0
- data/vendor/local/include/unicode/uchar.h +244 -17
- data/vendor/local/include/unicode/ucharstrie.h +2 -0
- data/vendor/local/include/unicode/ucharstriebuilder.h +2 -0
- data/vendor/local/include/unicode/uchriter.h +2 -0
- data/vendor/local/include/unicode/uclean.h +2 -0
- data/vendor/local/include/unicode/ucnv.h +8 -1
- data/vendor/local/include/unicode/ucnv_cb.h +2 -0
- data/vendor/local/include/unicode/ucnv_err.h +2 -0
- data/vendor/local/include/unicode/ucnvsel.h +2 -0
- data/vendor/local/include/unicode/ucol.h +28 -11
- data/vendor/local/include/unicode/ucoleitr.h +2 -0
- data/vendor/local/include/unicode/uconfig.h +2 -0
- data/vendor/local/include/unicode/ucsdet.h +2 -0
- data/vendor/local/include/unicode/ucurr.h +5 -1
- data/vendor/local/include/unicode/udat.h +13 -11
- data/vendor/local/include/unicode/udata.h +8 -1
- data/vendor/local/include/unicode/udateintervalformat.h +2 -0
- data/vendor/local/include/unicode/udatpg.h +15 -2
- data/vendor/local/include/unicode/udisplaycontext.h +34 -2
- data/vendor/local/include/unicode/uenum.h +2 -0
- data/vendor/local/include/unicode/ufieldpositer.h +4 -2
- data/vendor/local/include/unicode/uformattable.h +9 -1
- data/vendor/local/include/unicode/ugender.h +2 -0
- data/vendor/local/include/unicode/uidna.h +2 -0
- data/vendor/local/include/unicode/uiter.h +2 -0
- data/vendor/local/include/unicode/uldnames.h +2 -0
- data/vendor/local/include/unicode/ulistformatter.h +2 -0
- data/vendor/local/include/unicode/uloc.h +9 -3
- data/vendor/local/include/unicode/ulocdata.h +20 -2
- data/vendor/local/include/unicode/umachine.h +25 -0
- data/vendor/local/include/unicode/umisc.h +2 -0
- data/vendor/local/include/unicode/umsg.h +2 -0
- data/vendor/local/include/unicode/unifilt.h +2 -0
- data/vendor/local/include/unicode/unifunct.h +2 -0
- data/vendor/local/include/unicode/unimatch.h +2 -0
- data/vendor/local/include/unicode/unirepl.h +2 -0
- data/vendor/local/include/unicode/uniset.h +3 -1
- data/vendor/local/include/unicode/unistr.h +12 -14
- data/vendor/local/include/unicode/unorm.h +6 -2
- data/vendor/local/include/unicode/unorm2.h +2 -0
- data/vendor/local/include/unicode/unum.h +28 -10
- data/vendor/local/include/unicode/unumsys.h +2 -0
- data/vendor/local/include/unicode/uobject.h +2 -0
- data/vendor/local/include/unicode/upluralrules.h +6 -2
- data/vendor/local/include/unicode/uregex.h +2 -0
- data/vendor/local/include/unicode/uregion.h +6 -2
- data/vendor/local/include/unicode/ureldatefmt.h +13 -7
- data/vendor/local/include/unicode/urename.h +16 -4
- data/vendor/local/include/unicode/urep.h +2 -0
- data/vendor/local/include/unicode/ures.h +7 -1
- data/vendor/local/include/unicode/uscript.h +41 -29
- data/vendor/local/include/unicode/usearch.h +10 -4
- data/vendor/local/include/unicode/uset.h +5 -1
- data/vendor/local/include/unicode/usetiter.h +2 -0
- data/vendor/local/include/unicode/ushape.h +2 -0
- data/vendor/local/include/unicode/uspoof.h +876 -363
- data/vendor/local/include/unicode/usprep.h +2 -0
- data/vendor/local/include/unicode/ustdio.h +2 -0
- data/vendor/local/include/unicode/ustream.h +2 -0
- data/vendor/local/include/unicode/ustring.h +2 -0
- data/vendor/local/include/unicode/ustringtrie.h +2 -0
- data/vendor/local/include/unicode/utext.h +2 -0
- data/vendor/local/include/unicode/utf.h +2 -0
- data/vendor/local/include/unicode/utf16.h +2 -0
- data/vendor/local/include/unicode/utf32.h +2 -0
- data/vendor/local/include/unicode/utf8.h +2 -0
- data/vendor/local/include/unicode/utf_old.h +2 -0
- data/vendor/local/include/unicode/utmscale.h +2 -0
- data/vendor/local/include/unicode/utrace.h +20 -0
- data/vendor/local/include/unicode/utrans.h +2 -0
- data/vendor/local/include/unicode/utypes.h +71 -97
- data/vendor/local/include/unicode/uvernum.h +13 -12
- data/vendor/local/include/unicode/uversion.h +2 -0
- data/vendor/local/include/unicode/vtzone.h +2 -0
- data/vendor/local/lib/icu/{57.1 → 58.2}/Makefile.inc +8 -9
- data/vendor/local/lib/icu/{57.1 → 58.2}/pkgdata.inc +3 -3
- data/vendor/local/lib/icu/Makefile.inc +8 -9
- data/vendor/local/lib/icu/pkgdata.inc +3 -3
- data/vendor/local/lib/icudt.dll +0 -0
- data/vendor/local/lib/icudt58.dll +0 -0
- data/vendor/local/lib/icuin.dll +0 -0
- data/vendor/local/lib/icuin58.dll +0 -0
- data/vendor/local/lib/icuio.dll +0 -0
- data/vendor/local/lib/icuio58.dll +0 -0
- data/vendor/local/lib/icutest.dll +0 -0
- data/vendor/local/lib/{icutest57.dll → icutest58.dll} +0 -0
- data/vendor/local/lib/icutu.dll +0 -0
- data/vendor/local/lib/icutu58.dll +0 -0
- data/vendor/local/lib/icuuc.dll +0 -0
- data/vendor/local/lib/icuuc58.dll +0 -0
- data/vendor/local/lib/libharfbuzz-icu.a +0 -0
- data/vendor/local/lib/libharfbuzz-icu.la +4 -4
- data/vendor/local/lib/libharfbuzz.dll.a +0 -0
- data/vendor/local/lib/libharfbuzz.la +3 -3
- data/vendor/local/lib/libicudt.dll.a +0 -0
- data/vendor/local/lib/{icudt57.dll → libicudt58.dll} +0 -0
- data/vendor/local/lib/libicuin.dll.a +0 -0
- data/vendor/local/lib/libicuio.dll.a +0 -0
- data/vendor/local/lib/libicutest.dll.a +0 -0
- data/vendor/local/lib/libicutu.dll.a +0 -0
- data/vendor/local/lib/libicuuc.dll.a +0 -0
- data/vendor/local/lib/libpango-1.0.dll.a +0 -0
- data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
- data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
- data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +1 -1
- data/vendor/local/lib/pkgconfig/harfbuzz.pc +2 -2
- data/vendor/local/lib/pkgconfig/icu-i18n.pc +8 -6
- data/vendor/local/lib/pkgconfig/icu-io.pc +8 -6
- data/vendor/local/lib/pkgconfig/icu-uc.pc +8 -6
- data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +3 -3
- data/vendor/local/share/gtk-doc/html/harfbuzz/pt02.html +1 -1
- data/vendor/local/share/icu/{57.1 → 58.2}/LICENSE +52 -60
- data/vendor/local/share/icu/{57.1 → 58.2}/config/mh-mingw +4 -2
- data/vendor/local/share/icu/{57.1 → 58.2}/install-sh +0 -0
- data/vendor/local/share/icu/{57.1 → 58.2}/mkinstalldirs +2 -0
- data/vendor/local/share/man/man1/derb.1 +4 -2
- data/vendor/local/share/man/man1/genbrk.1 +4 -2
- data/vendor/local/share/man/man1/gencfu.1 +3 -1
- data/vendor/local/share/man/man1/gencnval.1 +5 -3
- data/vendor/local/share/man/man1/gendict.1 +4 -2
- data/vendor/local/share/man/man1/genrb.1 +5 -3
- data/vendor/local/share/man/man1/icu-config.1 +4 -5
- data/vendor/local/share/man/man1/makeconv.1 +5 -3
- data/vendor/local/share/man/man1/pkgdata.1 +4 -2
- data/vendor/local/share/man/man1/uconv.1 +4 -2
- data/vendor/local/share/man/man8/genccode.8 +4 -2
- data/vendor/local/share/man/man8/gencmn.8 +5 -3
- data/vendor/local/share/man/man8/gensprep.8 +5 -3
- data/vendor/local/share/man/man8/icupkg.8 +3 -1
- metadata +23 -40
- data/vendor/local/include/layout/LEFontInstance.h +0 -524
- data/vendor/local/include/layout/LEGlyphFilter.h +0 -45
- data/vendor/local/include/layout/LEGlyphStorage.h +0 -546
- data/vendor/local/include/layout/LEInsertionList.h +0 -177
- data/vendor/local/include/layout/LELanguages.h +0 -109
- data/vendor/local/include/layout/LEScripts.h +0 -204
- data/vendor/local/include/layout/LESwaps.h +0 -100
- data/vendor/local/include/layout/LETableReference.h +0 -435
- data/vendor/local/include/layout/LETypes.h +0 -728
- data/vendor/local/include/layout/LayoutEngine.h +0 -518
- data/vendor/local/include/layout/ParagraphLayout.h +0 -747
- data/vendor/local/include/layout/RunArrays.h +0 -676
- data/vendor/local/include/layout/loengine.h +0 -225
- data/vendor/local/include/layout/playout.h +0 -466
- data/vendor/local/include/layout/plruns.h +0 -441
- data/vendor/local/lib/icuin57.dll +0 -0
- data/vendor/local/lib/icuio57.dll +0 -0
- data/vendor/local/lib/icule.dll +0 -0
- data/vendor/local/lib/icule57.dll +0 -0
- data/vendor/local/lib/iculx.dll +0 -0
- data/vendor/local/lib/iculx57.dll +0 -0
- data/vendor/local/lib/icutu57.dll +0 -0
- data/vendor/local/lib/icuuc57.dll +0 -0
- data/vendor/local/lib/libicule.dll.a +0 -0
- data/vendor/local/lib/libiculx.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/icu-le.pc +0 -38
- data/vendor/local/lib/pkgconfig/icu-lx.pc +0 -38
@@ -1,100 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
*
|
3
|
-
* (C) Copyright IBM Corp. 1998-2014 - All Rights Reserved
|
4
|
-
*
|
5
|
-
*/
|
6
|
-
|
7
|
-
#ifndef __LESWAPS_H
|
8
|
-
#define __LESWAPS_H
|
9
|
-
|
10
|
-
#include "LETypes.h"
|
11
|
-
|
12
|
-
/**
|
13
|
-
* \file
|
14
|
-
* \brief C++ API: Endian independent access to data for LayoutEngine
|
15
|
-
*/
|
16
|
-
|
17
|
-
U_NAMESPACE_BEGIN
|
18
|
-
|
19
|
-
/**
|
20
|
-
* A convenience macro which invokes the swapWord member function
|
21
|
-
* from a concise call.
|
22
|
-
*
|
23
|
-
* @deprecated ICU 54. See {@link icu::LayoutEngine}
|
24
|
-
*/
|
25
|
-
#define SWAPW(value) LESwaps::swapWord((le_uint16)(value))
|
26
|
-
|
27
|
-
/**
|
28
|
-
* A convenience macro which invokes the swapLong member function
|
29
|
-
* from a concise call.
|
30
|
-
*
|
31
|
-
* @deprecated ICU 54. See {@link icu::LayoutEngine}
|
32
|
-
*/
|
33
|
-
#define SWAPL(value) LESwaps::swapLong((le_uint32)(value))
|
34
|
-
|
35
|
-
/**
|
36
|
-
* This class is used to access data which stored in big endian order
|
37
|
-
* regardless of the conventions of the platform.
|
38
|
-
*
|
39
|
-
* All methods are static and inline in an attempt to induce the compiler
|
40
|
-
* to do most of the calculations at compile time.
|
41
|
-
*
|
42
|
-
* @deprecated ICU 54. See {@link icu::LayoutEngine}
|
43
|
-
*/
|
44
|
-
class U_LAYOUT_API LESwaps /* not : public UObject because all methods are static */ {
|
45
|
-
public:
|
46
|
-
|
47
|
-
/**
|
48
|
-
* Reads a big-endian 16-bit word and returns a native-endian value.
|
49
|
-
* No-op on a big-endian platform, byte-swaps on a little-endian platform.
|
50
|
-
*
|
51
|
-
* @param value - the word to be byte swapped
|
52
|
-
*
|
53
|
-
* @return the byte swapped word
|
54
|
-
*
|
55
|
-
* @deprecated ICU 54. See {@link icu::LayoutEngine}
|
56
|
-
*/
|
57
|
-
static le_uint16 swapWord(le_uint16 value)
|
58
|
-
{
|
59
|
-
#if (defined(U_IS_BIG_ENDIAN) && U_IS_BIG_ENDIAN) || \
|
60
|
-
(defined(BYTE_ORDER) && defined(BIG_ENDIAN) && (BYTE_ORDER == BIG_ENDIAN)) || \
|
61
|
-
defined(__BIG_ENDIAN__)
|
62
|
-
// Fastpath when we know that the platform is big-endian.
|
63
|
-
return value;
|
64
|
-
#else
|
65
|
-
// Reads a big-endian value on any platform.
|
66
|
-
const le_uint8 *p = reinterpret_cast<const le_uint8 *>(&value);
|
67
|
-
return (le_uint16)((p[0] << 8) | p[1]);
|
68
|
-
#endif
|
69
|
-
};
|
70
|
-
|
71
|
-
/**
|
72
|
-
* Reads a big-endian 32-bit word and returns a native-endian value.
|
73
|
-
* No-op on a big-endian platform, byte-swaps on a little-endian platform.
|
74
|
-
*
|
75
|
-
* @param value - the long to be byte swapped
|
76
|
-
*
|
77
|
-
* @return the byte swapped long
|
78
|
-
*
|
79
|
-
* @deprecated ICU 54. See {@link icu::LayoutEngine}
|
80
|
-
*/
|
81
|
-
static le_uint32 swapLong(le_uint32 value)
|
82
|
-
{
|
83
|
-
#if (defined(U_IS_BIG_ENDIAN) && U_IS_BIG_ENDIAN) || \
|
84
|
-
(defined(BYTE_ORDER) && defined(BIG_ENDIAN) && (BYTE_ORDER == BIG_ENDIAN)) || \
|
85
|
-
defined(__BIG_ENDIAN__)
|
86
|
-
// Fastpath when we know that the platform is big-endian.
|
87
|
-
return value;
|
88
|
-
#else
|
89
|
-
// Reads a big-endian value on any platform.
|
90
|
-
const le_uint8 *p = reinterpret_cast<const le_uint8 *>(&value);
|
91
|
-
return (le_uint32)((p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3]);
|
92
|
-
#endif
|
93
|
-
};
|
94
|
-
|
95
|
-
private:
|
96
|
-
LESwaps() {} // private - forbid instantiation
|
97
|
-
};
|
98
|
-
|
99
|
-
U_NAMESPACE_END
|
100
|
-
#endif
|
@@ -1,435 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
* -*- c++ -*-
|
3
|
-
*
|
4
|
-
* (C) Copyright IBM Corp. and others 2015 - All Rights Reserved
|
5
|
-
*
|
6
|
-
* Range checking
|
7
|
-
*
|
8
|
-
*/
|
9
|
-
|
10
|
-
#ifndef __LETABLEREFERENCE_H
|
11
|
-
#define __LETABLEREFERENCE_H
|
12
|
-
|
13
|
-
#include "LETypes.h"
|
14
|
-
#include "LEFontInstance.h"
|
15
|
-
|
16
|
-
|
17
|
-
#define kQuestionmarkTableTag 0x3F3F3F3FUL
|
18
|
-
#define kTildeTableTag 0x7e7e7e7eUL
|
19
|
-
#ifdef __cplusplus
|
20
|
-
|
21
|
-
// internal - interface for range checking
|
22
|
-
U_NAMESPACE_BEGIN
|
23
|
-
|
24
|
-
#if LE_ASSERT_BAD_FONT
|
25
|
-
class LETableReference; // fwd
|
26
|
-
/**
|
27
|
-
* defined in OpenTypeUtilities.cpp
|
28
|
-
* @internal
|
29
|
-
*/
|
30
|
-
extern void _debug_LETableReference(const char *f, int l, const char *msg, const LETableReference *what, const void *ptr, size_t len);
|
31
|
-
|
32
|
-
#define LE_DEBUG_TR(x) _debug_LETableReference(__FILE__, __LINE__, x, this, NULL, 0);
|
33
|
-
#define LE_DEBUG_TR3(x,y,z) _debug_LETableReference(__FILE__, __LINE__, x, this, (const void*)y, (size_t)z);
|
34
|
-
#if 0
|
35
|
-
#define LE_TRACE_TR(x) _debug_LETableReference(__FILE__, __LINE__, x, this, NULL, 0);
|
36
|
-
#else
|
37
|
-
#define LE_TRACE_TR(x)
|
38
|
-
#endif
|
39
|
-
|
40
|
-
#else
|
41
|
-
#define LE_DEBUG_TR(x)
|
42
|
-
#define LE_DEBUG_TR3(x,y,z)
|
43
|
-
#define LE_TRACE_TR(x)
|
44
|
-
#endif
|
45
|
-
|
46
|
-
/**
|
47
|
-
* @internal
|
48
|
-
*/
|
49
|
-
class LETableReference {
|
50
|
-
public:
|
51
|
-
/**
|
52
|
-
* @internal
|
53
|
-
* Construct from a specific tag
|
54
|
-
*/
|
55
|
-
LETableReference(const LEFontInstance* font, LETag tableTag, LEErrorCode &success) :
|
56
|
-
fFont(font), fTag(tableTag), fParent(NULL), fStart(NULL),fLength(LE_UINTPTR_MAX) {
|
57
|
-
loadTable(success);
|
58
|
-
LE_TRACE_TR("INFO: new table load")
|
59
|
-
}
|
60
|
-
|
61
|
-
LETableReference(const LETableReference &parent, LEErrorCode &success) : fFont(parent.fFont), fTag(parent.fTag), fParent(&parent), fStart(parent.fStart), fLength(parent.fLength) {
|
62
|
-
if(LE_FAILURE(success)) {
|
63
|
-
clear();
|
64
|
-
}
|
65
|
-
LE_TRACE_TR("INFO: new clone")
|
66
|
-
}
|
67
|
-
|
68
|
-
LETableReference(const le_uint8* data, size_t length = LE_UINTPTR_MAX) :
|
69
|
-
fFont(NULL), fTag(kQuestionmarkTableTag), fParent(NULL), fStart(data), fLength(length) {
|
70
|
-
LE_TRACE_TR("INFO: new raw")
|
71
|
-
}
|
72
|
-
LETableReference() :
|
73
|
-
fFont(NULL), fTag(kQuestionmarkTableTag), fParent(NULL), fStart(NULL), fLength(0) {
|
74
|
-
LE_TRACE_TR("INFO: new empty")
|
75
|
-
}
|
76
|
-
|
77
|
-
~LETableReference() {
|
78
|
-
fTag=kTildeTableTag;
|
79
|
-
LE_TRACE_TR("INFO: new dtor")
|
80
|
-
}
|
81
|
-
|
82
|
-
/**
|
83
|
-
* @internal
|
84
|
-
* @param length if LE_UINTPTR_MAX means "whole table"
|
85
|
-
* subset
|
86
|
-
*/
|
87
|
-
LETableReference(const LETableReference &parent, size_t offset, size_t length,
|
88
|
-
LEErrorCode &err) :
|
89
|
-
fFont(parent.fFont), fTag(parent.fTag), fParent(&parent),
|
90
|
-
fStart((parent.fStart)+offset), fLength(length) {
|
91
|
-
if(LE_SUCCESS(err)) {
|
92
|
-
if(isEmpty()) {
|
93
|
-
//err = LE_MISSING_FONT_TABLE_ERROR;
|
94
|
-
clear(); // it's just empty. Not an error.
|
95
|
-
} else if(offset >= fParent->fLength) {
|
96
|
-
LE_DEBUG_TR3("offset out of range: (%p) +%d", NULL, offset);
|
97
|
-
err = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
98
|
-
clear();
|
99
|
-
} else {
|
100
|
-
if(fLength == LE_UINTPTR_MAX &&
|
101
|
-
fParent->fLength != LE_UINTPTR_MAX) {
|
102
|
-
fLength = (fParent->fLength) - offset; // decrement length as base address is incremented
|
103
|
-
}
|
104
|
-
if(fLength != LE_UINTPTR_MAX) { // if we have bounds:
|
105
|
-
if(offset+fLength > fParent->fLength) {
|
106
|
-
LE_DEBUG_TR3("offset+fLength out of range: (%p) +%d", NULL, offset+fLength);
|
107
|
-
err = LE_INDEX_OUT_OF_BOUNDS_ERROR; // exceeded
|
108
|
-
clear();
|
109
|
-
}
|
110
|
-
}
|
111
|
-
}
|
112
|
-
} else {
|
113
|
-
clear();
|
114
|
-
}
|
115
|
-
LE_TRACE_TR("INFO: new subset")
|
116
|
-
}
|
117
|
-
|
118
|
-
const void* getAlias() const { return (const void*)fStart; }
|
119
|
-
const void* getAliasRAW() const { LE_DEBUG_TR("getAliasRAW()"); return (const void*)fStart; }
|
120
|
-
le_bool isEmpty() const { return fStart==NULL || fLength==0; }
|
121
|
-
le_bool isValid() const { return !isEmpty(); }
|
122
|
-
le_bool hasBounds() const { return fLength!=LE_UINTPTR_MAX; }
|
123
|
-
void clear() { fLength=0; fStart=NULL; }
|
124
|
-
size_t getLength() const { return fLength; }
|
125
|
-
const LEFontInstance* getFont() const { return fFont; }
|
126
|
-
LETag getTag() const { return fTag; }
|
127
|
-
const LETableReference* getParent() const { return fParent; }
|
128
|
-
|
129
|
-
void addOffset(size_t offset, LEErrorCode &success) {
|
130
|
-
if(hasBounds()) {
|
131
|
-
if(offset > fLength) {
|
132
|
-
LE_DEBUG_TR("addOffset off end");
|
133
|
-
success = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
134
|
-
return;
|
135
|
-
} else {
|
136
|
-
fLength -= offset;
|
137
|
-
}
|
138
|
-
}
|
139
|
-
fStart += offset;
|
140
|
-
}
|
141
|
-
|
142
|
-
size_t ptrToOffset(const void *atPtr, LEErrorCode &success) const {
|
143
|
-
if(atPtr==NULL) return 0;
|
144
|
-
if(LE_FAILURE(success)) return LE_UINTPTR_MAX;
|
145
|
-
if((atPtr < fStart) ||
|
146
|
-
(hasBounds() && (atPtr > fStart+fLength))) {
|
147
|
-
LE_DEBUG_TR3("ptrToOffset args out of range: %p", atPtr, 0);
|
148
|
-
success = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
149
|
-
return LE_UINTPTR_MAX;
|
150
|
-
}
|
151
|
-
return ((const le_uint8*)atPtr)-fStart;
|
152
|
-
}
|
153
|
-
|
154
|
-
/**
|
155
|
-
* Clamp down the length, for range checking.
|
156
|
-
*/
|
157
|
-
size_t contractLength(size_t newLength) {
|
158
|
-
if(fLength!=LE_UINTPTR_MAX&&newLength>0&&newLength<=fLength) {
|
159
|
-
fLength = newLength;
|
160
|
-
}
|
161
|
-
return fLength;
|
162
|
-
}
|
163
|
-
|
164
|
-
/**
|
165
|
-
* Throw an error if offset+length off end
|
166
|
-
*/
|
167
|
-
public:
|
168
|
-
size_t verifyLength(size_t offset, size_t length, LEErrorCode &success) {
|
169
|
-
if(isValid()&&
|
170
|
-
LE_SUCCESS(success) &&
|
171
|
-
fLength!=LE_UINTPTR_MAX && length!=LE_UINTPTR_MAX && offset!=LE_UINTPTR_MAX &&
|
172
|
-
(offset+length)>fLength) {
|
173
|
-
LE_DEBUG_TR3("verifyLength failed (%p) %d",NULL, offset+length);
|
174
|
-
success = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
175
|
-
#if LE_ASSERT_BAD_FONT
|
176
|
-
fprintf(stderr, "offset=%lu, len=%lu, would be at %p, (%lu) off end. End at %p\n", offset,length, fStart+offset+length, (offset+length-fLength), (offset+length-fLength)+fStart);
|
177
|
-
#endif
|
178
|
-
}
|
179
|
-
return fLength;
|
180
|
-
}
|
181
|
-
|
182
|
-
/**
|
183
|
-
* Throw an error if size*count overflows
|
184
|
-
*/
|
185
|
-
size_t verifyLength(size_t offset, size_t size, le_uint32 count, LEErrorCode &success) {
|
186
|
-
if(count!=0 && size>LE_UINT32_MAX/count) {
|
187
|
-
LE_DEBUG_TR3("verifyLength failed size=%u, count=%u", size, count);
|
188
|
-
success = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
189
|
-
return 0;
|
190
|
-
}
|
191
|
-
return verifyLength(offset, size*count, success);
|
192
|
-
}
|
193
|
-
|
194
|
-
/**
|
195
|
-
* Change parent link to another
|
196
|
-
*/
|
197
|
-
LETableReference &reparent(const LETableReference &base) {
|
198
|
-
fParent = &base;
|
199
|
-
return *this;
|
200
|
-
}
|
201
|
-
|
202
|
-
/**
|
203
|
-
* remove parent link. Factory functions should do this.
|
204
|
-
*/
|
205
|
-
void orphan(void) {
|
206
|
-
fParent=NULL;
|
207
|
-
}
|
208
|
-
|
209
|
-
protected:
|
210
|
-
const LEFontInstance* fFont;
|
211
|
-
LETag fTag;
|
212
|
-
const LETableReference *fParent;
|
213
|
-
const le_uint8 *fStart; // keep as 8 bit internally, for pointer math
|
214
|
-
size_t fLength;
|
215
|
-
|
216
|
-
void loadTable(LEErrorCode &success) {
|
217
|
-
if(LE_SUCCESS(success)) {
|
218
|
-
fStart = (const le_uint8*)(fFont->getFontTable(fTag, fLength)); // note - a null table is not an error.
|
219
|
-
}
|
220
|
-
}
|
221
|
-
|
222
|
-
void setRaw(const void *data, size_t length = LE_UINTPTR_MAX) {
|
223
|
-
fFont = NULL;
|
224
|
-
fTag = kQuestionmarkTableTag;
|
225
|
-
fParent = NULL;
|
226
|
-
fStart = (const le_uint8*)data;
|
227
|
-
fLength = length;
|
228
|
-
}
|
229
|
-
};
|
230
|
-
|
231
|
-
|
232
|
-
template<class T>
|
233
|
-
class LETableVarSizer {
|
234
|
-
public:
|
235
|
-
inline static size_t getSize();
|
236
|
-
};
|
237
|
-
|
238
|
-
// base definition- could override for adjustments
|
239
|
-
template<class T> inline
|
240
|
-
size_t LETableVarSizer<T>::getSize() {
|
241
|
-
return sizeof(T);
|
242
|
-
}
|
243
|
-
|
244
|
-
/**
|
245
|
-
* \def LE_VAR_ARRAY
|
246
|
-
* @param x Type (T)
|
247
|
-
* @param y some member that is of length ANY_NUMBER
|
248
|
-
* Call this after defining a class, for example:
|
249
|
-
* LE_VAR_ARRAY(FeatureListTable,featureRecordArray)
|
250
|
-
* this is roughly equivalent to:
|
251
|
-
* template<> inline size_t LETableVarSizer<FeatureListTable>::getSize() { return sizeof(FeatureListTable) - (sizeof(le_uint16)*ANY_NUMBER); }
|
252
|
-
* it's a specialization that informs the LETableReference subclasses to NOT include the variable array in the size.
|
253
|
-
* dereferencing NULL is valid here because we never actually dereference it, just inside sizeof.
|
254
|
-
*/
|
255
|
-
#define LE_VAR_ARRAY(x,y) template<> inline size_t LETableVarSizer<x>::getSize() { return sizeof(x) - (sizeof(((const x*)0)->y)); }
|
256
|
-
/**
|
257
|
-
* \def LE_CORRECT_SIZE
|
258
|
-
* @param x type (T)
|
259
|
-
* @param y fixed size for T
|
260
|
-
*/
|
261
|
-
#define LE_CORRECT_SIZE(x,y) template<> inline size_t LETableVarSizer<x>::getSize() { return y; }
|
262
|
-
|
263
|
-
/**
|
264
|
-
* Open a new entry based on an existing table
|
265
|
-
*/
|
266
|
-
|
267
|
-
/**
|
268
|
-
* \def LE_UNBOUNDED_ARRAY
|
269
|
-
* define an array with no *known* bound. Will trim to available size.
|
270
|
-
* @internal
|
271
|
-
*/
|
272
|
-
#define LE_UNBOUNDED_ARRAY LE_UINT32_MAX
|
273
|
-
|
274
|
-
template<class T>
|
275
|
-
class LEReferenceToArrayOf : public LETableReference {
|
276
|
-
public:
|
277
|
-
LEReferenceToArrayOf(const LETableReference &parent, LEErrorCode &success, size_t offset, le_uint32 count)
|
278
|
-
: LETableReference(parent, offset, LE_UINTPTR_MAX, success), fCount(count) {
|
279
|
-
LE_TRACE_TR("INFO: new RTAO by offset")
|
280
|
-
if(LE_SUCCESS(success)) {
|
281
|
-
if(count == LE_UNBOUNDED_ARRAY) { // not a known length
|
282
|
-
count = getLength()/LETableVarSizer<T>::getSize(); // fit to max size
|
283
|
-
}
|
284
|
-
LETableReference::verifyLength(0, LETableVarSizer<T>::getSize(), fCount, success);
|
285
|
-
}
|
286
|
-
if(LE_FAILURE(success)) {
|
287
|
-
fCount=0;
|
288
|
-
clear();
|
289
|
-
}
|
290
|
-
}
|
291
|
-
|
292
|
-
LEReferenceToArrayOf(const LETableReference &parent, LEErrorCode &success, const T* array, le_uint32 count)
|
293
|
-
: LETableReference(parent, parent.ptrToOffset(array, success), LE_UINTPTR_MAX, success), fCount(count) {
|
294
|
-
LE_TRACE_TR("INFO: new RTAO")
|
295
|
-
if(LE_SUCCESS(success)) {
|
296
|
-
if(count == LE_UNBOUNDED_ARRAY) { // not a known length
|
297
|
-
count = getLength()/LETableVarSizer<T>::getSize(); // fit to max size
|
298
|
-
}
|
299
|
-
LETableReference::verifyLength(0, LETableVarSizer<T>::getSize(), fCount, success);
|
300
|
-
}
|
301
|
-
if(LE_FAILURE(success)) clear();
|
302
|
-
}
|
303
|
-
LEReferenceToArrayOf(const LETableReference &parent, LEErrorCode &success, const T* array, size_t offset, le_uint32 count)
|
304
|
-
: LETableReference(parent, parent.ptrToOffset(array, success)+offset, LE_UINTPTR_MAX, success), fCount(count) {
|
305
|
-
LE_TRACE_TR("INFO: new RTAO")
|
306
|
-
if(LE_SUCCESS(success)) {
|
307
|
-
if(count == LE_UNBOUNDED_ARRAY) { // not a known length
|
308
|
-
count = getLength()/LETableVarSizer<T>::getSize(); // fit to max size
|
309
|
-
}
|
310
|
-
LETableReference::verifyLength(0, LETableVarSizer<T>::getSize(), fCount, success);
|
311
|
-
}
|
312
|
-
if(LE_FAILURE(success)) clear();
|
313
|
-
}
|
314
|
-
|
315
|
-
LEReferenceToArrayOf() :LETableReference(), fCount(0) {}
|
316
|
-
|
317
|
-
le_uint32 getCount() const { return fCount; }
|
318
|
-
|
319
|
-
using LETableReference::getAlias;
|
320
|
-
|
321
|
-
const T *getAlias(le_uint32 i, LEErrorCode &success) const {
|
322
|
-
return ((const T*)(((const char*)getAlias())+getOffsetFor(i, success)));
|
323
|
-
}
|
324
|
-
|
325
|
-
const T *getAliasRAW() const { LE_DEBUG_TR("getAliasRAW<>"); return (const T*)fStart; }
|
326
|
-
|
327
|
-
const T& getObject(le_uint32 i, LEErrorCode &success) const {
|
328
|
-
const T *ret = getAlias(i, success);
|
329
|
-
if (LE_FAILURE(success) || ret==NULL) {
|
330
|
-
return *(new T(0));
|
331
|
-
} else {
|
332
|
-
return *ret;
|
333
|
-
}
|
334
|
-
}
|
335
|
-
|
336
|
-
const T& operator()(le_uint32 i, LEErrorCode &success) const {
|
337
|
-
return *getAlias(i,success);
|
338
|
-
}
|
339
|
-
|
340
|
-
size_t getOffsetFor(le_uint32 i, LEErrorCode &success) const {
|
341
|
-
if(LE_SUCCESS(success)&&i<getCount()) {
|
342
|
-
return LETableVarSizer<T>::getSize()*i;
|
343
|
-
} else {
|
344
|
-
success = LE_INDEX_OUT_OF_BOUNDS_ERROR;
|
345
|
-
}
|
346
|
-
return 0;
|
347
|
-
}
|
348
|
-
|
349
|
-
LEReferenceToArrayOf<T> &reparent(const LETableReference &base) {
|
350
|
-
fParent = &base;
|
351
|
-
return *this;
|
352
|
-
}
|
353
|
-
|
354
|
-
LEReferenceToArrayOf(const LETableReference& parent, LEErrorCode & success) : LETableReference(parent,0, LE_UINTPTR_MAX, success), fCount(0) {
|
355
|
-
LE_TRACE_TR("INFO: null RTAO")
|
356
|
-
}
|
357
|
-
|
358
|
-
private:
|
359
|
-
le_uint32 fCount;
|
360
|
-
};
|
361
|
-
|
362
|
-
|
363
|
-
template<class T>
|
364
|
-
class LEReferenceTo : public LETableReference {
|
365
|
-
public:
|
366
|
-
/**
|
367
|
-
* open a sub reference.
|
368
|
-
* @param parent parent reference
|
369
|
-
* @param success error status
|
370
|
-
* @param atPtr location of reference - if NULL, will be at offset zero (i.e. downcast of parent). Otherwise must be a pointer within parent's bounds.
|
371
|
-
*/
|
372
|
-
inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr)
|
373
|
-
: LETableReference(parent, parent.ptrToOffset(atPtr, success), LE_UINTPTR_MAX, success) {
|
374
|
-
verifyLength(0, LETableVarSizer<T>::getSize(), success);
|
375
|
-
if(LE_FAILURE(success)) clear();
|
376
|
-
}
|
377
|
-
/**
|
378
|
-
* ptr plus offset
|
379
|
-
*/
|
380
|
-
inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr, size_t offset)
|
381
|
-
: LETableReference(parent, parent.ptrToOffset(atPtr, success)+offset, LE_UINTPTR_MAX, success) {
|
382
|
-
verifyLength(0, LETableVarSizer<T>::getSize(), success);
|
383
|
-
if(LE_FAILURE(success)) clear();
|
384
|
-
}
|
385
|
-
inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, size_t offset)
|
386
|
-
: LETableReference(parent, offset, LE_UINTPTR_MAX, success) {
|
387
|
-
verifyLength(0, LETableVarSizer<T>::getSize(), success);
|
388
|
-
if(LE_FAILURE(success)) clear();
|
389
|
-
}
|
390
|
-
inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success)
|
391
|
-
: LETableReference(parent, 0, LE_UINTPTR_MAX, success) {
|
392
|
-
verifyLength(0, LETableVarSizer<T>::getSize(), success);
|
393
|
-
if(LE_FAILURE(success)) clear();
|
394
|
-
}
|
395
|
-
inline LEReferenceTo(const LEFontInstance *font, LETag tableTag, LEErrorCode &success)
|
396
|
-
: LETableReference(font, tableTag, success) {
|
397
|
-
verifyLength(0, LETableVarSizer<T>::getSize(), success);
|
398
|
-
if(LE_FAILURE(success)) clear();
|
399
|
-
}
|
400
|
-
inline LEReferenceTo(const le_uint8 *data, size_t length = LE_UINTPTR_MAX) : LETableReference(data, length) {}
|
401
|
-
inline LEReferenceTo(const T *data, size_t length = LE_UINTPTR_MAX) : LETableReference((const le_uint8*)data, length) {}
|
402
|
-
inline LEReferenceTo() : LETableReference(NULL) {}
|
403
|
-
|
404
|
-
inline LEReferenceTo<T>& operator=(const T* other) {
|
405
|
-
setRaw(other);
|
406
|
-
return *this;
|
407
|
-
}
|
408
|
-
|
409
|
-
LEReferenceTo<T> &reparent(const LETableReference &base) {
|
410
|
-
fParent = &base;
|
411
|
-
return *this;
|
412
|
-
}
|
413
|
-
|
414
|
-
/**
|
415
|
-
* roll forward by one <T> size.
|
416
|
-
* same as addOffset(LETableVarSizer<T>::getSize(),success)
|
417
|
-
*/
|
418
|
-
void addObject(LEErrorCode &success) {
|
419
|
-
addOffset(LETableVarSizer<T>::getSize(), success);
|
420
|
-
}
|
421
|
-
void addObject(size_t count, LEErrorCode &success) {
|
422
|
-
addOffset(LETableVarSizer<T>::getSize()*count, success);
|
423
|
-
}
|
424
|
-
|
425
|
-
const T *operator->() const { return getAlias(); }
|
426
|
-
const T *getAlias() const { return (const T*)fStart; }
|
427
|
-
const T *getAliasRAW() const { LE_DEBUG_TR("getAliasRAW<>"); return (const T*)fStart; }
|
428
|
-
};
|
429
|
-
|
430
|
-
|
431
|
-
U_NAMESPACE_END
|
432
|
-
|
433
|
-
#endif
|
434
|
-
|
435
|
-
#endif
|