pango 2.2.0-x86-mingw32 → 2.2.1-x86-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +21 -2
  3. data/lib/2.0/pango.so +0 -0
  4. data/vendor/local/bin/derb.exe +0 -0
  5. data/vendor/local/bin/genbrk.exe +0 -0
  6. data/vendor/local/bin/genccode.exe +0 -0
  7. data/vendor/local/bin/gencfu.exe +0 -0
  8. data/vendor/local/bin/gencmn.exe +0 -0
  9. data/vendor/local/bin/gencnval.exe +0 -0
  10. data/vendor/local/bin/gendict.exe +0 -0
  11. data/vendor/local/bin/gennorm2.exe +0 -0
  12. data/vendor/local/bin/genrb.exe +0 -0
  13. data/vendor/local/bin/gensprep.exe +0 -0
  14. data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
  15. data/vendor/local/bin/hb-shape.exe +0 -0
  16. data/vendor/local/bin/hb-view.exe +0 -0
  17. data/vendor/local/bin/icu-config +820 -0
  18. data/vendor/local/bin/icuinfo.exe +0 -0
  19. data/vendor/local/bin/icupkg.exe +0 -0
  20. data/vendor/local/bin/libharfbuzz-0.dll +0 -0
  21. data/vendor/local/bin/libpango-1.0-0.dll +0 -0
  22. data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
  23. data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
  24. data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
  25. data/vendor/local/bin/libstdc++-6.dll +0 -0
  26. data/vendor/local/bin/makeconv.exe +0 -0
  27. data/vendor/local/bin/pango-querymodules.exe +0 -0
  28. data/vendor/local/bin/pango-view.exe +0 -0
  29. data/vendor/local/bin/pkgdata.exe +0 -0
  30. data/vendor/local/bin/uconv.exe +0 -0
  31. data/vendor/local/etc/pango/pango.modules +3 -3
  32. data/vendor/local/include/harfbuzz/hb-blob.h +3 -4
  33. data/vendor/local/include/harfbuzz/hb-buffer.h +22 -1
  34. data/vendor/local/include/harfbuzz/hb-common.h +23 -18
  35. data/vendor/local/include/harfbuzz/hb-icu.h +52 -0
  36. data/vendor/local/include/harfbuzz/hb-ot-font.h +41 -0
  37. data/vendor/local/include/harfbuzz/hb-ot-layout.h +11 -3
  38. data/vendor/local/include/harfbuzz/hb-ot-shape.h +10 -11
  39. data/vendor/local/include/harfbuzz/hb-ot.h +1 -0
  40. data/vendor/local/include/harfbuzz/hb-version.h +7 -7
  41. data/vendor/local/include/layout/LEFontInstance.h +550 -0
  42. data/vendor/local/include/layout/LEGlyphFilter.h +45 -0
  43. data/vendor/local/include/layout/LEGlyphStorage.h +546 -0
  44. data/vendor/local/include/layout/LEInsertionList.h +177 -0
  45. data/vendor/local/include/layout/LELanguages.h +112 -0
  46. data/vendor/local/include/layout/LEScripts.h +263 -0
  47. data/vendor/local/include/layout/LESwaps.h +100 -0
  48. data/vendor/local/include/layout/LETableReference.h +418 -0
  49. data/vendor/local/include/layout/LETypes.h +728 -0
  50. data/vendor/local/include/layout/LayoutEngine.h +518 -0
  51. data/vendor/local/include/layout/ParagraphLayout.h +747 -0
  52. data/vendor/local/include/layout/RunArrays.h +676 -0
  53. data/vendor/local/include/layout/loengine.h +225 -0
  54. data/vendor/local/include/layout/playout.h +466 -0
  55. data/vendor/local/include/layout/plruns.h +441 -0
  56. data/vendor/local/include/pango-1.0/pango/pango-features.h +2 -2
  57. data/vendor/local/include/pango-1.0/pango/pango-font.h +3 -1
  58. data/vendor/local/include/pango-1.0/pango/pango-item.h +11 -2
  59. data/vendor/local/include/unicode/alphaindex.h +752 -0
  60. data/vendor/local/include/unicode/appendable.h +232 -0
  61. data/vendor/local/include/unicode/basictz.h +214 -0
  62. data/vendor/local/include/unicode/brkiter.h +655 -0
  63. data/vendor/local/include/unicode/bytestream.h +257 -0
  64. data/vendor/local/include/unicode/bytestrie.h +519 -0
  65. data/vendor/local/include/unicode/bytestriebuilder.h +181 -0
  66. data/vendor/local/include/unicode/calendar.h +2519 -0
  67. data/vendor/local/include/unicode/caniter.h +208 -0
  68. data/vendor/local/include/unicode/chariter.h +722 -0
  69. data/vendor/local/include/unicode/choicfmt.h +594 -0
  70. data/vendor/local/include/unicode/coleitr.h +404 -0
  71. data/vendor/local/include/unicode/coll.h +1267 -0
  72. data/vendor/local/include/unicode/compactdecimalformat.h +330 -0
  73. data/vendor/local/include/unicode/curramt.h +130 -0
  74. data/vendor/local/include/unicode/currpinf.h +258 -0
  75. data/vendor/local/include/unicode/currunit.h +110 -0
  76. data/vendor/local/include/unicode/datefmt.h +883 -0
  77. data/vendor/local/include/unicode/dbbi.h +40 -0
  78. data/vendor/local/include/unicode/dcfmtsym.h +482 -0
  79. data/vendor/local/include/unicode/decimfmt.h +2479 -0
  80. data/vendor/local/include/unicode/docmain.h +215 -0
  81. data/vendor/local/include/unicode/dtfmtsym.h +912 -0
  82. data/vendor/local/include/unicode/dtintrv.h +158 -0
  83. data/vendor/local/include/unicode/dtitvfmt.h +985 -0
  84. data/vendor/local/include/unicode/dtitvinf.h +514 -0
  85. data/vendor/local/include/unicode/dtptngen.h +498 -0
  86. data/vendor/local/include/unicode/dtrule.h +250 -0
  87. data/vendor/local/include/unicode/enumset.h +64 -0
  88. data/vendor/local/include/unicode/errorcode.h +137 -0
  89. data/vendor/local/include/unicode/fieldpos.h +291 -0
  90. data/vendor/local/include/unicode/filteredbrk.h +131 -0
  91. data/vendor/local/include/unicode/fmtable.h +760 -0
  92. data/vendor/local/include/unicode/format.h +305 -0
  93. data/vendor/local/include/unicode/fpositer.h +117 -0
  94. data/vendor/local/include/unicode/gender.h +111 -0
  95. data/vendor/local/include/unicode/gregocal.h +777 -0
  96. data/vendor/local/include/unicode/icudataver.h +41 -0
  97. data/vendor/local/include/unicode/icuplug.h +371 -0
  98. data/vendor/local/include/unicode/idna.h +323 -0
  99. data/vendor/local/include/unicode/listformatter.h +167 -0
  100. data/vendor/local/include/unicode/localpointer.h +304 -0
  101. data/vendor/local/include/unicode/locdspnm.h +204 -0
  102. data/vendor/local/include/unicode/locid.h +815 -0
  103. data/vendor/local/include/unicode/measfmt.h +389 -0
  104. data/vendor/local/include/unicode/measunit.h +1443 -0
  105. data/vendor/local/include/unicode/measure.h +159 -0
  106. data/vendor/local/include/unicode/messagepattern.h +943 -0
  107. data/vendor/local/include/unicode/msgfmt.h +1093 -0
  108. data/vendor/local/include/unicode/normalizer2.h +658 -0
  109. data/vendor/local/include/unicode/normlzr.h +797 -0
  110. data/vendor/local/include/unicode/numfmt.h +1187 -0
  111. data/vendor/local/include/unicode/numsys.h +208 -0
  112. data/vendor/local/include/unicode/parseerr.h +92 -0
  113. data/vendor/local/include/unicode/parsepos.h +230 -0
  114. data/vendor/local/include/unicode/platform.h +751 -0
  115. data/vendor/local/include/unicode/plurfmt.h +615 -0
  116. data/vendor/local/include/unicode/plurrule.h +501 -0
  117. data/vendor/local/include/unicode/ptypes.h +126 -0
  118. data/vendor/local/include/unicode/putil.h +181 -0
  119. data/vendor/local/include/unicode/rbbi.h +782 -0
  120. data/vendor/local/include/unicode/rbnf.h +1032 -0
  121. data/vendor/local/include/unicode/rbtz.h +362 -0
  122. data/vendor/local/include/unicode/regex.h +1857 -0
  123. data/vendor/local/include/unicode/region.h +228 -0
  124. data/vendor/local/include/unicode/reldatefmt.h +498 -0
  125. data/vendor/local/include/unicode/rep.h +261 -0
  126. data/vendor/local/include/unicode/resbund.h +490 -0
  127. data/vendor/local/include/unicode/schriter.h +187 -0
  128. data/vendor/local/include/unicode/scientificformathelper.h +139 -0
  129. data/vendor/local/include/unicode/search.h +575 -0
  130. data/vendor/local/include/unicode/selfmt.h +367 -0
  131. data/vendor/local/include/unicode/simpletz.h +928 -0
  132. data/vendor/local/include/unicode/smpdtfmt.h +1592 -0
  133. data/vendor/local/include/unicode/sortkey.h +338 -0
  134. data/vendor/local/include/unicode/std_string.h +37 -0
  135. data/vendor/local/include/unicode/strenum.h +276 -0
  136. data/vendor/local/include/unicode/stringpiece.h +224 -0
  137. data/vendor/local/include/unicode/stringtriebuilder.h +402 -0
  138. data/vendor/local/include/unicode/stsearch.h +504 -0
  139. data/vendor/local/include/unicode/symtable.h +112 -0
  140. data/vendor/local/include/unicode/tblcoll.h +873 -0
  141. data/vendor/local/include/unicode/timezone.h +948 -0
  142. data/vendor/local/include/unicode/tmunit.h +129 -0
  143. data/vendor/local/include/unicode/tmutamt.h +168 -0
  144. data/vendor/local/include/unicode/tmutfmt.h +243 -0
  145. data/vendor/local/include/unicode/translit.h +1342 -0
  146. data/vendor/local/include/unicode/tzfmt.h +1098 -0
  147. data/vendor/local/include/unicode/tznames.h +404 -0
  148. data/vendor/local/include/unicode/tzrule.h +828 -0
  149. data/vendor/local/include/unicode/tztrans.h +195 -0
  150. data/vendor/local/include/unicode/ubidi.h +2186 -0
  151. data/vendor/local/include/unicode/ubrk.h +540 -0
  152. data/vendor/local/include/unicode/ucal.h +1560 -0
  153. data/vendor/local/include/unicode/ucasemap.h +423 -0
  154. data/vendor/local/include/unicode/ucat.h +158 -0
  155. data/vendor/local/include/unicode/uchar.h +3426 -0
  156. data/vendor/local/include/unicode/ucharstrie.h +576 -0
  157. data/vendor/local/include/unicode/ucharstriebuilder.h +185 -0
  158. data/vendor/local/include/unicode/uchriter.h +381 -0
  159. data/vendor/local/include/unicode/uclean.h +258 -0
  160. data/vendor/local/include/unicode/ucnv.h +2036 -0
  161. data/vendor/local/include/unicode/ucnv_cb.h +162 -0
  162. data/vendor/local/include/unicode/ucnv_err.h +463 -0
  163. data/vendor/local/include/unicode/ucnvsel.h +187 -0
  164. data/vendor/local/include/unicode/ucol.h +1474 -0
  165. data/vendor/local/include/unicode/ucoleitr.h +266 -0
  166. data/vendor/local/include/unicode/uconfig.h +430 -0
  167. data/vendor/local/include/unicode/ucsdet.h +413 -0
  168. data/vendor/local/include/unicode/ucurr.h +424 -0
  169. data/vendor/local/include/unicode/udat.h +1536 -0
  170. data/vendor/local/include/unicode/udata.h +430 -0
  171. data/vendor/local/include/unicode/udateintervalformat.h +181 -0
  172. data/vendor/local/include/unicode/udatpg.h +588 -0
  173. data/vendor/local/include/unicode/udisplaycontext.h +150 -0
  174. data/vendor/local/include/unicode/uenum.h +206 -0
  175. data/vendor/local/include/unicode/uformattable.h +280 -0
  176. data/vendor/local/include/unicode/ugender.h +82 -0
  177. data/vendor/local/include/unicode/uidna.h +762 -0
  178. data/vendor/local/include/unicode/uiter.h +707 -0
  179. data/vendor/local/include/unicode/uldnames.h +302 -0
  180. data/vendor/local/include/unicode/uloc.h +1256 -0
  181. data/vendor/local/include/unicode/ulocdata.h +277 -0
  182. data/vendor/local/include/unicode/umachine.h +356 -0
  183. data/vendor/local/include/unicode/umisc.h +60 -0
  184. data/vendor/local/include/unicode/umsg.h +623 -0
  185. data/vendor/local/include/unicode/unifilt.h +120 -0
  186. data/vendor/local/include/unicode/unifunct.h +125 -0
  187. data/vendor/local/include/unicode/unimatch.h +163 -0
  188. data/vendor/local/include/unicode/unirepl.h +97 -0
  189. data/vendor/local/include/unicode/uniset.h +1691 -0
  190. data/vendor/local/include/unicode/unistr.h +4470 -0
  191. data/vendor/local/include/unicode/unorm.h +561 -0
  192. data/vendor/local/include/unicode/unorm2.h +528 -0
  193. data/vendor/local/include/unicode/unum.h +1328 -0
  194. data/vendor/local/include/unicode/unumsys.h +170 -0
  195. data/vendor/local/include/unicode/uobject.h +320 -0
  196. data/vendor/local/include/unicode/upluralrules.h +145 -0
  197. data/vendor/local/include/unicode/uregex.h +1591 -0
  198. data/vendor/local/include/unicode/uregion.h +248 -0
  199. data/vendor/local/include/unicode/urename.h +1784 -0
  200. data/vendor/local/include/unicode/urep.h +155 -0
  201. data/vendor/local/include/unicode/ures.h +887 -0
  202. data/vendor/local/include/unicode/uscript.h +642 -0
  203. data/vendor/local/include/unicode/usearch.h +885 -0
  204. data/vendor/local/include/unicode/uset.h +1126 -0
  205. data/vendor/local/include/unicode/usetiter.h +318 -0
  206. data/vendor/local/include/unicode/ushape.h +474 -0
  207. data/vendor/local/include/unicode/uspoof.h +1064 -0
  208. data/vendor/local/include/unicode/usprep.h +269 -0
  209. data/vendor/local/include/unicode/ustdio.h +1018 -0
  210. data/vendor/local/include/unicode/ustream.h +68 -0
  211. data/vendor/local/include/unicode/ustring.h +1700 -0
  212. data/vendor/local/include/unicode/ustringtrie.h +95 -0
  213. data/vendor/local/include/unicode/utext.h +1600 -0
  214. data/vendor/local/include/unicode/utf.h +223 -0
  215. data/vendor/local/include/unicode/utf16.h +623 -0
  216. data/vendor/local/include/unicode/utf32.h +23 -0
  217. data/vendor/local/include/unicode/utf8.h +824 -0
  218. data/vendor/local/include/unicode/utf_old.h +1169 -0
  219. data/vendor/local/include/unicode/utmscale.h +481 -0
  220. data/vendor/local/include/unicode/utrace.h +359 -0
  221. data/vendor/local/include/unicode/utrans.h +658 -0
  222. data/vendor/local/include/unicode/utypes.h +723 -0
  223. data/vendor/local/include/unicode/uvernum.h +170 -0
  224. data/vendor/local/include/unicode/uversion.h +193 -0
  225. data/vendor/local/include/unicode/vtzone.h +455 -0
  226. data/vendor/local/lib/girepository-1.0/Pango-1.0.typelib +0 -0
  227. data/vendor/local/lib/girepository-1.0/PangoCairo-1.0.typelib +0 -0
  228. data/vendor/local/lib/girepository-1.0/PangoFT2-1.0.typelib +0 -0
  229. data/vendor/local/lib/icu/54.1/Makefile.inc +293 -0
  230. data/vendor/local/lib/icu/54.1/pkgdata.inc +17 -0
  231. data/vendor/local/lib/icu/Makefile.inc +293 -0
  232. data/vendor/local/lib/icu/pkgdata.inc +17 -0
  233. data/vendor/local/lib/icudt.dll +0 -0
  234. data/vendor/local/lib/icudt54.dll +0 -0
  235. data/vendor/local/lib/icuin.dll +0 -0
  236. data/vendor/local/lib/icuin54.dll +0 -0
  237. data/vendor/local/lib/icuio.dll +0 -0
  238. data/vendor/local/lib/icuio54.dll +0 -0
  239. data/vendor/local/lib/icule.dll +0 -0
  240. data/vendor/local/lib/icule54.dll +0 -0
  241. data/vendor/local/lib/iculx.dll +0 -0
  242. data/vendor/local/lib/iculx54.dll +0 -0
  243. data/vendor/local/lib/icutest.dll +0 -0
  244. data/vendor/local/lib/icutest54.dll +0 -0
  245. data/vendor/local/lib/icutu.dll +0 -0
  246. data/vendor/local/lib/icutu54.dll +0 -0
  247. data/vendor/local/lib/icuuc.dll +0 -0
  248. data/vendor/local/lib/icuuc54.dll +0 -0
  249. data/vendor/local/lib/libharfbuzz-icu.a +0 -0
  250. data/vendor/local/lib/libharfbuzz-icu.la +41 -0
  251. data/vendor/local/lib/libharfbuzz.dll.a +0 -0
  252. data/vendor/local/lib/libharfbuzz.la +3 -3
  253. data/vendor/local/lib/libicudt.dll.a +0 -0
  254. data/vendor/local/lib/libicuin.dll.a +0 -0
  255. data/vendor/local/lib/libicuio.dll.a +0 -0
  256. data/vendor/local/lib/libicule.dll.a +0 -0
  257. data/vendor/local/lib/libiculx.dll.a +0 -0
  258. data/vendor/local/lib/libicutest.dll.a +0 -0
  259. data/vendor/local/lib/libicutu.dll.a +0 -0
  260. data/vendor/local/lib/libicuuc.dll.a +0 -0
  261. data/vendor/local/lib/libpango-1.0.dll.a +0 -0
  262. data/vendor/local/lib/libpango-1.0.la +2 -2
  263. data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
  264. data/vendor/local/lib/libpangocairo-1.0.la +2 -2
  265. data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
  266. data/vendor/local/lib/libpangoft2-1.0.la +2 -2
  267. data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
  268. data/vendor/local/lib/libpangowin32-1.0.la +2 -2
  269. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll +0 -0
  270. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll.a +0 -0
  271. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.la +1 -1
  272. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll +0 -0
  273. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll.a +0 -0
  274. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.la +1 -1
  275. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll +0 -0
  276. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll.a +0 -0
  277. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.la +1 -1
  278. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll +0 -0
  279. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll.a +0 -0
  280. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.la +1 -1
  281. data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +13 -0
  282. data/vendor/local/lib/pkgconfig/harfbuzz.pc +1 -1
  283. data/vendor/local/lib/pkgconfig/icu-i18n.pc +38 -0
  284. data/vendor/local/lib/pkgconfig/icu-io.pc +38 -0
  285. data/vendor/local/lib/pkgconfig/icu-le.pc +38 -0
  286. data/vendor/local/lib/pkgconfig/icu-lx.pc +38 -0
  287. data/vendor/local/lib/pkgconfig/icu-uc.pc +38 -0
  288. data/vendor/local/lib/pkgconfig/pango.pc +1 -1
  289. data/vendor/local/lib/pkgconfig/pangocairo.pc +1 -1
  290. data/vendor/local/lib/pkgconfig/pangoft2.pc +1 -1
  291. data/vendor/local/lib/pkgconfig/pangowin32.pc +1 -1
  292. data/vendor/local/share/gir-1.0/Pango-1.0.gir +3009 -462
  293. data/vendor/local/share/gir-1.0/PangoCairo-1.0.gir +64 -22
  294. data/vendor/local/share/gir-1.0/PangoFT2-1.0.gir +4 -2
  295. data/vendor/local/share/gtk-doc/html/harfbuzz/annotation-glossary.html +30 -26
  296. data/vendor/local/share/gtk-doc/html/harfbuzz/api-index-full.html +343 -313
  297. data/vendor/local/share/gtk-doc/html/harfbuzz/ch01.html +5 -5
  298. data/vendor/local/share/gtk-doc/html/harfbuzz/deprecated-api-index.html +6 -8
  299. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-blob.html +442 -247
  300. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-buffer.html +1389 -654
  301. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-common.html +954 -698
  302. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-coretext.html +95 -18
  303. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-deprecated.html +36 -27
  304. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-face.html +477 -191
  305. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-font.html +1951 -1039
  306. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ft.html +123 -65
  307. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-glib.html +66 -21
  308. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-gobject.html +11 -13
  309. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-graphite2.html +67 -23
  310. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-icu.html +66 -21
  311. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-layout.html +574 -347
  312. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-tag.html +104 -37
  313. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot.html +10 -27
  314. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-set.html +744 -318
  315. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape-plan.html +294 -153
  316. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape.html +196 -104
  317. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-unicode.html +1100 -757
  318. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-uniscribe.html +51 -18
  319. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +110 -84
  320. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb.html +11 -13
  321. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz.devhelp2 +289 -503
  322. data/vendor/local/share/gtk-doc/html/harfbuzz/index.html +3 -3
  323. data/vendor/local/share/gtk-doc/html/harfbuzz/index.sgml +161 -316
  324. data/vendor/local/share/gtk-doc/html/harfbuzz/object-tree.html +31 -4
  325. data/vendor/local/share/gtk-doc/html/harfbuzz/style.css +260 -105
  326. data/vendor/local/share/gtk-doc/html/pango/PangoEngineLang.html +143 -105
  327. data/vendor/local/share/gtk-doc/html/pango/PangoEngineShape.html +150 -108
  328. data/vendor/local/share/gtk-doc/html/pango/PangoFcDecoder.html +163 -112
  329. data/vendor/local/share/gtk-doc/html/pango/PangoFcFont.html +348 -229
  330. data/vendor/local/share/gtk-doc/html/pango/PangoFcFontMap.html +746 -514
  331. data/vendor/local/share/gtk-doc/html/pango/PangoMarkupFormat.html +9 -9
  332. data/vendor/local/share/gtk-doc/html/pango/PangoRenderer.html +853 -623
  333. data/vendor/local/share/gtk-doc/html/pango/annotation-glossary.html +29 -13
  334. data/vendor/local/share/gtk-doc/html/pango/api-index-1-10.html +31 -33
  335. data/vendor/local/share/gtk-doc/html/pango/api-index-1-12.html +10 -12
  336. data/vendor/local/share/gtk-doc/html/pango/api-index-1-14.html +12 -14
  337. data/vendor/local/share/gtk-doc/html/pango/api-index-1-16.html +53 -55
  338. data/vendor/local/share/gtk-doc/html/pango/api-index-1-18.html +28 -30
  339. data/vendor/local/share/gtk-doc/html/pango/api-index-1-2.html +29 -31
  340. data/vendor/local/share/gtk-doc/html/pango/api-index-1-20.html +17 -19
  341. data/vendor/local/share/gtk-doc/html/pango/api-index-1-22.html +28 -30
  342. data/vendor/local/share/gtk-doc/html/pango/api-index-1-24.html +17 -19
  343. data/vendor/local/share/gtk-doc/html/pango/api-index-1-26.html +9 -11
  344. data/vendor/local/share/gtk-doc/html/pango/api-index-1-30.html +6 -6
  345. data/vendor/local/share/gtk-doc/html/pango/api-index-1-31-0.html +6 -6
  346. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32-4.html +11 -13
  347. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32.html +7 -9
  348. data/vendor/local/share/gtk-doc/html/pango/api-index-1-34.html +5 -5
  349. data/vendor/local/share/gtk-doc/html/pango/api-index-1-4.html +49 -51
  350. data/vendor/local/share/gtk-doc/html/pango/api-index-1-6.html +36 -38
  351. data/vendor/local/share/gtk-doc/html/pango/api-index-1-8.html +37 -39
  352. data/vendor/local/share/gtk-doc/html/pango/api-index-deprecated.html +68 -70
  353. data/vendor/local/share/gtk-doc/html/pango/api-index-full.html +568 -570
  354. data/vendor/local/share/gtk-doc/html/pango/index.html +3 -3
  355. data/vendor/local/share/gtk-doc/html/pango/index.sgml +229 -399
  356. data/vendor/local/share/gtk-doc/html/pango/lowlevel.html +4 -4
  357. data/vendor/local/share/gtk-doc/html/pango/pango-Bidirectional-Text.html +345 -259
  358. data/vendor/local/share/gtk-doc/html/pango/pango-Cairo-Rendering.html +979 -664
  359. data/vendor/local/share/gtk-doc/html/pango/pango-CoreText-Fonts.html +70 -43
  360. data/vendor/local/share/gtk-doc/html/pango/pango-Coverage-Maps.html +349 -229
  361. data/vendor/local/share/gtk-doc/html/pango/pango-Engines.html +236 -153
  362. data/vendor/local/share/gtk-doc/html/pango/pango-Fonts.html +3100 -2159
  363. data/vendor/local/share/gtk-doc/html/pango/pango-FreeType-Fonts-and-Rendering.html +659 -472
  364. data/vendor/local/share/gtk-doc/html/pango/pango-Glyph-Storage.html +1952 -1384
  365. data/vendor/local/share/gtk-doc/html/pango/pango-Layout-Objects.html +3050 -2135
  366. data/vendor/local/share/gtk-doc/html/pango/pango-Miscellaneous-Utilities.html +676 -463
  367. data/vendor/local/share/gtk-doc/html/pango/pango-Modules.html +223 -146
  368. data/vendor/local/share/gtk-doc/html/pango/pango-OpenType-Font-Handling.html +1589 -1199
  369. data/vendor/local/share/gtk-doc/html/pango/pango-Scripts-and-Languages.html +1072 -842
  370. data/vendor/local/share/gtk-doc/html/pango/pango-Tab-Stops.html +406 -276
  371. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Attributes.html +2541 -1792
  372. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Processing.html +1479 -1033
  373. data/vendor/local/share/gtk-doc/html/pango/pango-Version-Checking.html +214 -154
  374. data/vendor/local/share/gtk-doc/html/pango/pango-Vertical-Text.html +374 -291
  375. data/vendor/local/share/gtk-doc/html/pango/pango-Win32-Fonts-and-Rendering.html +733 -498
  376. data/vendor/local/share/gtk-doc/html/pango/pango-Xft-Fonts-and-Rendering.html +893 -617
  377. data/vendor/local/share/gtk-doc/html/pango/pango-hierarchy.html +59 -59
  378. data/vendor/local/share/gtk-doc/html/pango/pango-querymodules.html +5 -5
  379. data/vendor/local/share/gtk-doc/html/pango/pango.devhelp2 +578 -782
  380. data/vendor/local/share/gtk-doc/html/pango/pango.html +4 -4
  381. data/vendor/local/share/gtk-doc/html/pango/rendering.html +4 -4
  382. data/vendor/local/share/gtk-doc/html/pango/style.css +260 -105
  383. data/vendor/local/share/gtk-doc/html/pango/tools.html +4 -4
  384. data/vendor/local/share/icu/54.1/config/mh-mingw +158 -0
  385. data/vendor/local/share/icu/54.1/install-sh +251 -0
  386. data/vendor/local/share/icu/54.1/license.html +385 -0
  387. data/vendor/local/share/icu/54.1/mkinstalldirs +43 -0
  388. data/vendor/local/share/license/harfbuzz/AUTHORS +1 -0
  389. data/vendor/local/share/man/man1/derb.1 +196 -0
  390. data/vendor/local/share/man/man1/genbrk.1 +112 -0
  391. data/vendor/local/share/man/man1/gencfu.1 +91 -0
  392. data/vendor/local/share/man/man1/gencnval.1 +91 -0
  393. data/vendor/local/share/man/man1/gendict.1 +131 -0
  394. data/vendor/local/share/man/man1/genrb.1 +146 -0
  395. data/vendor/local/share/man/man1/icu-config.1 +288 -0
  396. data/vendor/local/share/man/man1/makeconv.1 +112 -0
  397. data/vendor/local/share/man/man1/pango-querymodules.1 +2 -2
  398. data/vendor/local/share/man/man1/pango-view.1 +1 -118
  399. data/vendor/local/share/man/man1/pkgdata.1 +258 -0
  400. data/vendor/local/share/man/man1/uconv.1 +443 -0
  401. data/vendor/local/share/man/man8/genccode.8 +106 -0
  402. data/vendor/local/share/man/man8/gencmn.8 +129 -0
  403. data/vendor/local/share/man/man8/gensprep.8 +102 -0
  404. data/vendor/local/share/man/man8/icupkg.8 +204 -0
  405. metadata +266 -14
  406. data/lib/1.9/pango.so +0 -0
  407. data/lib/2.1/pango.so +0 -0
@@ -0,0 +1,257 @@
1
+ // Copyright (C) 2009-2012, International Business Machines
2
+ // Corporation and others. All Rights Reserved.
3
+ //
4
+ // Copyright 2007 Google Inc. All Rights Reserved.
5
+ // Author: sanjay@google.com (Sanjay Ghemawat)
6
+ //
7
+ // Abstract interface that consumes a sequence of bytes (ByteSink).
8
+ //
9
+ // Used so that we can write a single piece of code that can operate
10
+ // on a variety of output string types.
11
+ //
12
+ // Various implementations of this interface are provided:
13
+ // ByteSink:
14
+ // CheckedArrayByteSink Write to a flat array, with bounds checking
15
+ // StringByteSink Write to an STL string
16
+
17
+ // This code is a contribution of Google code, and the style used here is
18
+ // a compromise between the original Google code and the ICU coding guidelines.
19
+ // For example, data types are ICU-ified (size_t,int->int32_t),
20
+ // and API comments doxygen-ified, but function names and behavior are
21
+ // as in the original, if possible.
22
+ // Assertion-style error handling, not available in ICU, was changed to
23
+ // parameter "pinning" similar to UnicodeString.
24
+ //
25
+ // In addition, this is only a partial port of the original Google code,
26
+ // limited to what was needed so far. The (nearly) complete original code
27
+ // is in the ICU svn repository at icuhtml/trunk/design/strings/contrib
28
+ // (see ICU ticket 6765, r25517).
29
+
30
+ #ifndef __BYTESTREAM_H__
31
+ #define __BYTESTREAM_H__
32
+
33
+ /**
34
+ * \file
35
+ * \brief C++ API: Interface for writing bytes, and implementation classes.
36
+ */
37
+
38
+ #include "unicode/utypes.h"
39
+ #include "unicode/uobject.h"
40
+ #include "unicode/std_string.h"
41
+
42
+ U_NAMESPACE_BEGIN
43
+
44
+ /**
45
+ * A ByteSink can be filled with bytes.
46
+ * @stable ICU 4.2
47
+ */
48
+ class U_COMMON_API ByteSink : public UMemory {
49
+ public:
50
+ /**
51
+ * Default constructor.
52
+ * @stable ICU 4.2
53
+ */
54
+ ByteSink() { }
55
+ /**
56
+ * Virtual destructor.
57
+ * @stable ICU 4.2
58
+ */
59
+ virtual ~ByteSink();
60
+
61
+ /**
62
+ * Append "bytes[0,n-1]" to this.
63
+ * @param bytes the pointer to the bytes
64
+ * @param n the number of bytes; must be non-negative
65
+ * @stable ICU 4.2
66
+ */
67
+ virtual void Append(const char* bytes, int32_t n) = 0;
68
+
69
+ /**
70
+ * Returns a writable buffer for appending and writes the buffer's capacity to
71
+ * *result_capacity. Guarantees *result_capacity>=min_capacity.
72
+ * May return a pointer to the caller-owned scratch buffer which must have
73
+ * scratch_capacity>=min_capacity.
74
+ * The returned buffer is only valid until the next operation
75
+ * on this ByteSink.
76
+ *
77
+ * After writing at most *result_capacity bytes, call Append() with the
78
+ * pointer returned from this function and the number of bytes written.
79
+ * Many Append() implementations will avoid copying bytes if this function
80
+ * returned an internal buffer.
81
+ *
82
+ * Partial usage example:
83
+ * int32_t capacity;
84
+ * char* buffer = sink->GetAppendBuffer(..., &capacity);
85
+ * ... Write n bytes into buffer, with n <= capacity.
86
+ * sink->Append(buffer, n);
87
+ * In many implementations, that call to Append will avoid copying bytes.
88
+ *
89
+ * If the ByteSink allocates or reallocates an internal buffer, it should use
90
+ * the desired_capacity_hint if appropriate.
91
+ * If a caller cannot provide a reasonable guess at the desired capacity,
92
+ * it should pass desired_capacity_hint=0.
93
+ *
94
+ * If a non-scratch buffer is returned, the caller may only pass
95
+ * a prefix to it to Append().
96
+ * That is, it is not correct to pass an interior pointer to Append().
97
+ *
98
+ * The default implementation always returns the scratch buffer.
99
+ *
100
+ * @param min_capacity required minimum capacity of the returned buffer;
101
+ * must be non-negative
102
+ * @param desired_capacity_hint desired capacity of the returned buffer;
103
+ * must be non-negative
104
+ * @param scratch default caller-owned buffer
105
+ * @param scratch_capacity capacity of the scratch buffer
106
+ * @param result_capacity pointer to an integer which will be set to the
107
+ * capacity of the returned buffer
108
+ * @return a buffer with *result_capacity>=min_capacity
109
+ * @stable ICU 4.2
110
+ */
111
+ virtual char* GetAppendBuffer(int32_t min_capacity,
112
+ int32_t desired_capacity_hint,
113
+ char* scratch, int32_t scratch_capacity,
114
+ int32_t* result_capacity);
115
+
116
+ /**
117
+ * Flush internal buffers.
118
+ * Some byte sinks use internal buffers or provide buffering
119
+ * and require calling Flush() at the end of the stream.
120
+ * The ByteSink should be ready for further Append() calls after Flush().
121
+ * The default implementation of Flush() does nothing.
122
+ * @stable ICU 4.2
123
+ */
124
+ virtual void Flush();
125
+
126
+ private:
127
+ ByteSink(const ByteSink &); // copy constructor not implemented
128
+ ByteSink &operator=(const ByteSink &); // assignment operator not implemented
129
+ };
130
+
131
+ // -------------------------------------------------------------
132
+ // Some standard implementations
133
+
134
+ /**
135
+ * Implementation of ByteSink that writes to a flat byte array,
136
+ * with bounds-checking:
137
+ * This sink will not write more than capacity bytes to outbuf.
138
+ * If more than capacity bytes are Append()ed, then excess bytes are ignored,
139
+ * and Overflowed() will return true.
140
+ * Overflow does not cause a runtime error.
141
+ * @stable ICU 4.2
142
+ */
143
+ class U_COMMON_API CheckedArrayByteSink : public ByteSink {
144
+ public:
145
+ /**
146
+ * Constructs a ByteSink that will write to outbuf[0..capacity-1].
147
+ * @param outbuf buffer to write to
148
+ * @param capacity size of the buffer
149
+ * @stable ICU 4.2
150
+ */
151
+ CheckedArrayByteSink(char* outbuf, int32_t capacity);
152
+ /**
153
+ * Destructor.
154
+ * @stable ICU 4.2
155
+ */
156
+ virtual ~CheckedArrayByteSink();
157
+ /**
158
+ * Returns the sink to its original state, without modifying the buffer.
159
+ * Useful for reusing both the buffer and the sink for multiple streams.
160
+ * Resets the state to NumberOfBytesWritten()=NumberOfBytesAppended()=0
161
+ * and Overflowed()=FALSE.
162
+ * @return *this
163
+ * @stable ICU 4.6
164
+ */
165
+ virtual CheckedArrayByteSink& Reset();
166
+ /**
167
+ * Append "bytes[0,n-1]" to this.
168
+ * @param bytes the pointer to the bytes
169
+ * @param n the number of bytes; must be non-negative
170
+ * @stable ICU 4.2
171
+ */
172
+ virtual void Append(const char* bytes, int32_t n);
173
+ /**
174
+ * Returns a writable buffer for appending and writes the buffer's capacity to
175
+ * *result_capacity. For details see the base class documentation.
176
+ * @param min_capacity required minimum capacity of the returned buffer;
177
+ * must be non-negative
178
+ * @param desired_capacity_hint desired capacity of the returned buffer;
179
+ * must be non-negative
180
+ * @param scratch default caller-owned buffer
181
+ * @param scratch_capacity capacity of the scratch buffer
182
+ * @param result_capacity pointer to an integer which will be set to the
183
+ * capacity of the returned buffer
184
+ * @return a buffer with *result_capacity>=min_capacity
185
+ * @stable ICU 4.2
186
+ */
187
+ virtual char* GetAppendBuffer(int32_t min_capacity,
188
+ int32_t desired_capacity_hint,
189
+ char* scratch, int32_t scratch_capacity,
190
+ int32_t* result_capacity);
191
+ /**
192
+ * Returns the number of bytes actually written to the sink.
193
+ * @return number of bytes written to the buffer
194
+ * @stable ICU 4.2
195
+ */
196
+ int32_t NumberOfBytesWritten() const { return size_; }
197
+ /**
198
+ * Returns true if any bytes were discarded, i.e., if there was an
199
+ * attempt to write more than 'capacity' bytes.
200
+ * @return TRUE if more than 'capacity' bytes were Append()ed
201
+ * @stable ICU 4.2
202
+ */
203
+ UBool Overflowed() const { return overflowed_; }
204
+ /**
205
+ * Returns the number of bytes appended to the sink.
206
+ * If Overflowed() then NumberOfBytesAppended()>NumberOfBytesWritten()
207
+ * else they return the same number.
208
+ * @return number of bytes written to the buffer
209
+ * @stable ICU 4.6
210
+ */
211
+ int32_t NumberOfBytesAppended() const { return appended_; }
212
+ private:
213
+ char* outbuf_;
214
+ const int32_t capacity_;
215
+ int32_t size_;
216
+ int32_t appended_;
217
+ UBool overflowed_;
218
+ CheckedArrayByteSink(); ///< default constructor not implemented
219
+ CheckedArrayByteSink(const CheckedArrayByteSink &); ///< copy constructor not implemented
220
+ CheckedArrayByteSink &operator=(const CheckedArrayByteSink &); ///< assignment operator not implemented
221
+ };
222
+
223
+ #if U_HAVE_STD_STRING
224
+
225
+ /**
226
+ * Implementation of ByteSink that writes to a "string".
227
+ * The StringClass is usually instantiated with a std::string.
228
+ * @stable ICU 4.2
229
+ */
230
+ template<typename StringClass>
231
+ class StringByteSink : public ByteSink {
232
+ public:
233
+ /**
234
+ * Constructs a ByteSink that will append bytes to the dest string.
235
+ * @param dest pointer to string object to append to
236
+ * @stable ICU 4.2
237
+ */
238
+ StringByteSink(StringClass* dest) : dest_(dest) { }
239
+ /**
240
+ * Append "bytes[0,n-1]" to this.
241
+ * @param data the pointer to the bytes
242
+ * @param n the number of bytes; must be non-negative
243
+ * @stable ICU 4.2
244
+ */
245
+ virtual void Append(const char* data, int32_t n) { dest_->append(data, n); }
246
+ private:
247
+ StringClass* dest_;
248
+ StringByteSink(); ///< default constructor not implemented
249
+ StringByteSink(const StringByteSink &); ///< copy constructor not implemented
250
+ StringByteSink &operator=(const StringByteSink &); ///< assignment operator not implemented
251
+ };
252
+
253
+ #endif
254
+
255
+ U_NAMESPACE_END
256
+
257
+ #endif // __BYTESTREAM_H__
@@ -0,0 +1,519 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2010-2012, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ *******************************************************************************
6
+ * file name: bytestrie.h
7
+ * encoding: US-ASCII
8
+ * tab size: 8 (not used)
9
+ * indentation:4
10
+ *
11
+ * created on: 2010sep25
12
+ * created by: Markus W. Scherer
13
+ */
14
+
15
+ #ifndef __BYTESTRIE_H__
16
+ #define __BYTESTRIE_H__
17
+
18
+ /**
19
+ * \file
20
+ * \brief C++ API: Trie for mapping byte sequences to integer values.
21
+ */
22
+
23
+ #include "unicode/utypes.h"
24
+ #include "unicode/stringpiece.h"
25
+ #include "unicode/uobject.h"
26
+ #include "unicode/ustringtrie.h"
27
+
28
+ U_NAMESPACE_BEGIN
29
+
30
+ class ByteSink;
31
+ class BytesTrieBuilder;
32
+ class CharString;
33
+ class UVector32;
34
+
35
+ /**
36
+ * Light-weight, non-const reader class for a BytesTrie.
37
+ * Traverses a byte-serialized data structure with minimal state,
38
+ * for mapping byte sequences to non-negative integer values.
39
+ *
40
+ * This class owns the serialized trie data only if it was constructed by
41
+ * the builder's build() method.
42
+ * The public constructor and the copy constructor only alias the data (only copy the pointer).
43
+ * There is no assignment operator.
44
+ *
45
+ * This class is not intended for public subclassing.
46
+ * @stable ICU 4.8
47
+ */
48
+ class U_COMMON_API BytesTrie : public UMemory {
49
+ public:
50
+ /**
51
+ * Constructs a BytesTrie reader instance.
52
+ *
53
+ * The trieBytes must contain a copy of a byte sequence from the BytesTrieBuilder,
54
+ * starting with the first byte of that sequence.
55
+ * The BytesTrie object will not read more bytes than
56
+ * the BytesTrieBuilder generated in the corresponding build() call.
57
+ *
58
+ * The array is not copied/cloned and must not be modified while
59
+ * the BytesTrie object is in use.
60
+ *
61
+ * @param trieBytes The byte array that contains the serialized trie.
62
+ * @stable ICU 4.8
63
+ */
64
+ BytesTrie(const void *trieBytes)
65
+ : ownedArray_(NULL), bytes_(static_cast<const uint8_t *>(trieBytes)),
66
+ pos_(bytes_), remainingMatchLength_(-1) {}
67
+
68
+ /**
69
+ * Destructor.
70
+ * @stable ICU 4.8
71
+ */
72
+ ~BytesTrie();
73
+
74
+ /**
75
+ * Copy constructor, copies the other trie reader object and its state,
76
+ * but not the byte array which will be shared. (Shallow copy.)
77
+ * @param other Another BytesTrie object.
78
+ * @stable ICU 4.8
79
+ */
80
+ BytesTrie(const BytesTrie &other)
81
+ : ownedArray_(NULL), bytes_(other.bytes_),
82
+ pos_(other.pos_), remainingMatchLength_(other.remainingMatchLength_) {}
83
+
84
+ /**
85
+ * Resets this trie to its initial state.
86
+ * @return *this
87
+ * @stable ICU 4.8
88
+ */
89
+ BytesTrie &reset() {
90
+ pos_=bytes_;
91
+ remainingMatchLength_=-1;
92
+ return *this;
93
+ }
94
+
95
+ /**
96
+ * BytesTrie state object, for saving a trie's current state
97
+ * and resetting the trie back to this state later.
98
+ * @stable ICU 4.8
99
+ */
100
+ class State : public UMemory {
101
+ public:
102
+ /**
103
+ * Constructs an empty State.
104
+ * @stable ICU 4.8
105
+ */
106
+ State() { bytes=NULL; }
107
+ private:
108
+ friend class BytesTrie;
109
+
110
+ const uint8_t *bytes;
111
+ const uint8_t *pos;
112
+ int32_t remainingMatchLength;
113
+ };
114
+
115
+ /**
116
+ * Saves the state of this trie.
117
+ * @param state The State object to hold the trie's state.
118
+ * @return *this
119
+ * @see resetToState
120
+ * @stable ICU 4.8
121
+ */
122
+ const BytesTrie &saveState(State &state) const {
123
+ state.bytes=bytes_;
124
+ state.pos=pos_;
125
+ state.remainingMatchLength=remainingMatchLength_;
126
+ return *this;
127
+ }
128
+
129
+ /**
130
+ * Resets this trie to the saved state.
131
+ * If the state object contains no state, or the state of a different trie,
132
+ * then this trie remains unchanged.
133
+ * @param state The State object which holds a saved trie state.
134
+ * @return *this
135
+ * @see saveState
136
+ * @see reset
137
+ * @stable ICU 4.8
138
+ */
139
+ BytesTrie &resetToState(const State &state) {
140
+ if(bytes_==state.bytes && bytes_!=NULL) {
141
+ pos_=state.pos;
142
+ remainingMatchLength_=state.remainingMatchLength;
143
+ }
144
+ return *this;
145
+ }
146
+
147
+ /**
148
+ * Determines whether the byte sequence so far matches, whether it has a value,
149
+ * and whether another input byte can continue a matching byte sequence.
150
+ * @return The match/value Result.
151
+ * @stable ICU 4.8
152
+ */
153
+ UStringTrieResult current() const;
154
+
155
+ /**
156
+ * Traverses the trie from the initial state for this input byte.
157
+ * Equivalent to reset().next(inByte).
158
+ * @param inByte Input byte value. Values -0x100..-1 are treated like 0..0xff.
159
+ * Values below -0x100 and above 0xff will never match.
160
+ * @return The match/value Result.
161
+ * @stable ICU 4.8
162
+ */
163
+ inline UStringTrieResult first(int32_t inByte) {
164
+ remainingMatchLength_=-1;
165
+ if(inByte<0) {
166
+ inByte+=0x100;
167
+ }
168
+ return nextImpl(bytes_, inByte);
169
+ }
170
+
171
+ /**
172
+ * Traverses the trie from the current state for this input byte.
173
+ * @param inByte Input byte value. Values -0x100..-1 are treated like 0..0xff.
174
+ * Values below -0x100 and above 0xff will never match.
175
+ * @return The match/value Result.
176
+ * @stable ICU 4.8
177
+ */
178
+ UStringTrieResult next(int32_t inByte);
179
+
180
+ /**
181
+ * Traverses the trie from the current state for this byte sequence.
182
+ * Equivalent to
183
+ * \code
184
+ * Result result=current();
185
+ * for(each c in s)
186
+ * if(!USTRINGTRIE_HAS_NEXT(result)) return USTRINGTRIE_NO_MATCH;
187
+ * result=next(c);
188
+ * return result;
189
+ * \endcode
190
+ * @param s A string or byte sequence. Can be NULL if length is 0.
191
+ * @param length The length of the byte sequence. Can be -1 if NUL-terminated.
192
+ * @return The match/value Result.
193
+ * @stable ICU 4.8
194
+ */
195
+ UStringTrieResult next(const char *s, int32_t length);
196
+
197
+ /**
198
+ * Returns a matching byte sequence's value if called immediately after
199
+ * current()/first()/next() returned USTRINGTRIE_INTERMEDIATE_VALUE or USTRINGTRIE_FINAL_VALUE.
200
+ * getValue() can be called multiple times.
201
+ *
202
+ * Do not call getValue() after USTRINGTRIE_NO_MATCH or USTRINGTRIE_NO_VALUE!
203
+ * @return The value for the byte sequence so far.
204
+ * @stable ICU 4.8
205
+ */
206
+ inline int32_t getValue() const {
207
+ const uint8_t *pos=pos_;
208
+ int32_t leadByte=*pos++;
209
+ // U_ASSERT(leadByte>=kMinValueLead);
210
+ return readValue(pos, leadByte>>1);
211
+ }
212
+
213
+ /**
214
+ * Determines whether all byte sequences reachable from the current state
215
+ * map to the same value.
216
+ * @param uniqueValue Receives the unique value, if this function returns TRUE.
217
+ * (output-only)
218
+ * @return TRUE if all byte sequences reachable from the current state
219
+ * map to the same value.
220
+ * @stable ICU 4.8
221
+ */
222
+ inline UBool hasUniqueValue(int32_t &uniqueValue) const {
223
+ const uint8_t *pos=pos_;
224
+ // Skip the rest of a pending linear-match node.
225
+ return pos!=NULL && findUniqueValue(pos+remainingMatchLength_+1, FALSE, uniqueValue);
226
+ }
227
+
228
+ /**
229
+ * Finds each byte which continues the byte sequence from the current state.
230
+ * That is, each byte b for which it would be next(b)!=USTRINGTRIE_NO_MATCH now.
231
+ * @param out Each next byte is appended to this object.
232
+ * (Only uses the out.Append(s, length) method.)
233
+ * @return the number of bytes which continue the byte sequence from here
234
+ * @stable ICU 4.8
235
+ */
236
+ int32_t getNextBytes(ByteSink &out) const;
237
+
238
+ /**
239
+ * Iterator for all of the (byte sequence, value) pairs in a BytesTrie.
240
+ * @stable ICU 4.8
241
+ */
242
+ class U_COMMON_API Iterator : public UMemory {
243
+ public:
244
+ /**
245
+ * Iterates from the root of a byte-serialized BytesTrie.
246
+ * @param trieBytes The trie bytes.
247
+ * @param maxStringLength If 0, the iterator returns full strings/byte sequences.
248
+ * Otherwise, the iterator returns strings with this maximum length.
249
+ * @param errorCode Standard ICU error code. Its input value must
250
+ * pass the U_SUCCESS() test, or else the function returns
251
+ * immediately. Check for U_FAILURE() on output or use with
252
+ * function chaining. (See User Guide for details.)
253
+ * @stable ICU 4.8
254
+ */
255
+ Iterator(const void *trieBytes, int32_t maxStringLength, UErrorCode &errorCode);
256
+
257
+ /**
258
+ * Iterates from the current state of the specified BytesTrie.
259
+ * @param trie The trie whose state will be copied for iteration.
260
+ * @param maxStringLength If 0, the iterator returns full strings/byte sequences.
261
+ * Otherwise, the iterator returns strings with this maximum length.
262
+ * @param errorCode Standard ICU error code. Its input value must
263
+ * pass the U_SUCCESS() test, or else the function returns
264
+ * immediately. Check for U_FAILURE() on output or use with
265
+ * function chaining. (See User Guide for details.)
266
+ * @stable ICU 4.8
267
+ */
268
+ Iterator(const BytesTrie &trie, int32_t maxStringLength, UErrorCode &errorCode);
269
+
270
+ /**
271
+ * Destructor.
272
+ * @stable ICU 4.8
273
+ */
274
+ ~Iterator();
275
+
276
+ /**
277
+ * Resets this iterator to its initial state.
278
+ * @return *this
279
+ * @stable ICU 4.8
280
+ */
281
+ Iterator &reset();
282
+
283
+ /**
284
+ * @return TRUE if there are more elements.
285
+ * @stable ICU 4.8
286
+ */
287
+ UBool hasNext() const;
288
+
289
+ /**
290
+ * Finds the next (byte sequence, value) pair if there is one.
291
+ *
292
+ * If the byte sequence is truncated to the maximum length and does not
293
+ * have a real value, then the value is set to -1.
294
+ * In this case, this "not a real value" is indistinguishable from
295
+ * a real value of -1.
296
+ * @param errorCode Standard ICU error code. Its input value must
297
+ * pass the U_SUCCESS() test, or else the function returns
298
+ * immediately. Check for U_FAILURE() on output or use with
299
+ * function chaining. (See User Guide for details.)
300
+ * @return TRUE if there is another element.
301
+ * @stable ICU 4.8
302
+ */
303
+ UBool next(UErrorCode &errorCode);
304
+
305
+ /**
306
+ * @return The NUL-terminated byte sequence for the last successful next().
307
+ * @stable ICU 4.8
308
+ */
309
+ const StringPiece &getString() const { return sp_; }
310
+ /**
311
+ * @return The value for the last successful next().
312
+ * @stable ICU 4.8
313
+ */
314
+ int32_t getValue() const { return value_; }
315
+
316
+ private:
317
+ UBool truncateAndStop();
318
+
319
+ const uint8_t *branchNext(const uint8_t *pos, int32_t length, UErrorCode &errorCode);
320
+
321
+ const uint8_t *bytes_;
322
+ const uint8_t *pos_;
323
+ const uint8_t *initialPos_;
324
+ int32_t remainingMatchLength_;
325
+ int32_t initialRemainingMatchLength_;
326
+
327
+ CharString *str_;
328
+ StringPiece sp_;
329
+ int32_t maxLength_;
330
+ int32_t value_;
331
+
332
+ // The stack stores pairs of integers for backtracking to another
333
+ // outbound edge of a branch node.
334
+ // The first integer is an offset from bytes_.
335
+ // The second integer has the str_->length() from before the node in bits 15..0,
336
+ // and the remaining branch length in bits 24..16. (Bits 31..25 are unused.)
337
+ // (We could store the remaining branch length minus 1 in bits 23..16 and not use bits 31..24,
338
+ // but the code looks more confusing that way.)
339
+ UVector32 *stack_;
340
+ };
341
+
342
+ private:
343
+ friend class BytesTrieBuilder;
344
+
345
+ /**
346
+ * Constructs a BytesTrie reader instance.
347
+ * Unlike the public constructor which just aliases an array,
348
+ * this constructor adopts the builder's array.
349
+ * This constructor is only called by the builder.
350
+ */
351
+ BytesTrie(void *adoptBytes, const void *trieBytes)
352
+ : ownedArray_(static_cast<uint8_t *>(adoptBytes)),
353
+ bytes_(static_cast<const uint8_t *>(trieBytes)),
354
+ pos_(bytes_), remainingMatchLength_(-1) {}
355
+
356
+ // No assignment operator.
357
+ BytesTrie &operator=(const BytesTrie &other);
358
+
359
+ inline void stop() {
360
+ pos_=NULL;
361
+ }
362
+
363
+ // Reads a compact 32-bit integer.
364
+ // pos is already after the leadByte, and the lead byte is already shifted right by 1.
365
+ static int32_t readValue(const uint8_t *pos, int32_t leadByte);
366
+ static inline const uint8_t *skipValue(const uint8_t *pos, int32_t leadByte) {
367
+ // U_ASSERT(leadByte>=kMinValueLead);
368
+ if(leadByte>=(kMinTwoByteValueLead<<1)) {
369
+ if(leadByte<(kMinThreeByteValueLead<<1)) {
370
+ ++pos;
371
+ } else if(leadByte<(kFourByteValueLead<<1)) {
372
+ pos+=2;
373
+ } else {
374
+ pos+=3+((leadByte>>1)&1);
375
+ }
376
+ }
377
+ return pos;
378
+ }
379
+ static inline const uint8_t *skipValue(const uint8_t *pos) {
380
+ int32_t leadByte=*pos++;
381
+ return skipValue(pos, leadByte);
382
+ }
383
+
384
+ // Reads a jump delta and jumps.
385
+ static const uint8_t *jumpByDelta(const uint8_t *pos);
386
+
387
+ static inline const uint8_t *skipDelta(const uint8_t *pos) {
388
+ int32_t delta=*pos++;
389
+ if(delta>=kMinTwoByteDeltaLead) {
390
+ if(delta<kMinThreeByteDeltaLead) {
391
+ ++pos;
392
+ } else if(delta<kFourByteDeltaLead) {
393
+ pos+=2;
394
+ } else {
395
+ pos+=3+(delta&1);
396
+ }
397
+ }
398
+ return pos;
399
+ }
400
+
401
+ static inline UStringTrieResult valueResult(int32_t node) {
402
+ return (UStringTrieResult)(USTRINGTRIE_INTERMEDIATE_VALUE-(node&kValueIsFinal));
403
+ }
404
+
405
+ // Handles a branch node for both next(byte) and next(string).
406
+ UStringTrieResult branchNext(const uint8_t *pos, int32_t length, int32_t inByte);
407
+
408
+ // Requires remainingLength_<0.
409
+ UStringTrieResult nextImpl(const uint8_t *pos, int32_t inByte);
410
+
411
+ // Helper functions for hasUniqueValue().
412
+ // Recursively finds a unique value (or whether there is not a unique one)
413
+ // from a branch.
414
+ static const uint8_t *findUniqueValueFromBranch(const uint8_t *pos, int32_t length,
415
+ UBool haveUniqueValue, int32_t &uniqueValue);
416
+ // Recursively finds a unique value (or whether there is not a unique one)
417
+ // starting from a position on a node lead byte.
418
+ static UBool findUniqueValue(const uint8_t *pos, UBool haveUniqueValue, int32_t &uniqueValue);
419
+
420
+ // Helper functions for getNextBytes().
421
+ // getNextBytes() when pos is on a branch node.
422
+ static void getNextBranchBytes(const uint8_t *pos, int32_t length, ByteSink &out);
423
+ static void append(ByteSink &out, int c);
424
+
425
+ // BytesTrie data structure
426
+ //
427
+ // The trie consists of a series of byte-serialized nodes for incremental
428
+ // string/byte sequence matching. The root node is at the beginning of the trie data.
429
+ //
430
+ // Types of nodes are distinguished by their node lead byte ranges.
431
+ // After each node, except a final-value node, another node follows to
432
+ // encode match values or continue matching further bytes.
433
+ //
434
+ // Node types:
435
+ // - Value node: Stores a 32-bit integer in a compact, variable-length format.
436
+ // The value is for the string/byte sequence so far.
437
+ // One node bit indicates whether the value is final or whether
438
+ // matching continues with the next node.
439
+ // - Linear-match node: Matches a number of bytes.
440
+ // - Branch node: Branches to other nodes according to the current input byte.
441
+ // The node byte is the length of the branch (number of bytes to select from)
442
+ // minus 1. It is followed by a sub-node:
443
+ // - If the length is at most kMaxBranchLinearSubNodeLength, then
444
+ // there are length-1 (key, value) pairs and then one more comparison byte.
445
+ // If one of the key bytes matches, then the value is either a final value for
446
+ // the string/byte sequence so far, or a "jump" delta to the next node.
447
+ // If the last byte matches, then matching continues with the next node.
448
+ // (Values have the same encoding as value nodes.)
449
+ // - If the length is greater than kMaxBranchLinearSubNodeLength, then
450
+ // there is one byte and one "jump" delta.
451
+ // If the input byte is less than the sub-node byte, then "jump" by delta to
452
+ // the next sub-node which will have a length of length/2.
453
+ // (The delta has its own compact encoding.)
454
+ // Otherwise, skip the "jump" delta to the next sub-node
455
+ // which will have a length of length-length/2.
456
+
457
+ // Node lead byte values.
458
+
459
+ // 00..0f: Branch node. If node!=0 then the length is node+1, otherwise
460
+ // the length is one more than the next byte.
461
+
462
+ // For a branch sub-node with at most this many entries, we drop down
463
+ // to a linear search.
464
+ static const int32_t kMaxBranchLinearSubNodeLength=5;
465
+
466
+ // 10..1f: Linear-match node, match 1..16 bytes and continue reading the next node.
467
+ static const int32_t kMinLinearMatch=0x10;
468
+ static const int32_t kMaxLinearMatchLength=0x10;
469
+
470
+ // 20..ff: Variable-length value node.
471
+ // If odd, the value is final. (Otherwise, intermediate value or jump delta.)
472
+ // Then shift-right by 1 bit.
473
+ // The remaining lead byte value indicates the number of following bytes (0..4)
474
+ // and contains the value's top bits.
475
+ static const int32_t kMinValueLead=kMinLinearMatch+kMaxLinearMatchLength; // 0x20
476
+ // It is a final value if bit 0 is set.
477
+ static const int32_t kValueIsFinal=1;
478
+
479
+ // Compact value: After testing bit 0, shift right by 1 and then use the following thresholds.
480
+ static const int32_t kMinOneByteValueLead=kMinValueLead/2; // 0x10
481
+ static const int32_t kMaxOneByteValue=0x40; // At least 6 bits in the first byte.
482
+
483
+ static const int32_t kMinTwoByteValueLead=kMinOneByteValueLead+kMaxOneByteValue+1; // 0x51
484
+ static const int32_t kMaxTwoByteValue=0x1aff;
485
+
486
+ static const int32_t kMinThreeByteValueLead=kMinTwoByteValueLead+(kMaxTwoByteValue>>8)+1; // 0x6c
487
+ static const int32_t kFourByteValueLead=0x7e;
488
+
489
+ // A little more than Unicode code points. (0x11ffff)
490
+ static const int32_t kMaxThreeByteValue=((kFourByteValueLead-kMinThreeByteValueLead)<<16)-1;
491
+
492
+ static const int32_t kFiveByteValueLead=0x7f;
493
+
494
+ // Compact delta integers.
495
+ static const int32_t kMaxOneByteDelta=0xbf;
496
+ static const int32_t kMinTwoByteDeltaLead=kMaxOneByteDelta+1; // 0xc0
497
+ static const int32_t kMinThreeByteDeltaLead=0xf0;
498
+ static const int32_t kFourByteDeltaLead=0xfe;
499
+ static const int32_t kFiveByteDeltaLead=0xff;
500
+
501
+ static const int32_t kMaxTwoByteDelta=((kMinThreeByteDeltaLead-kMinTwoByteDeltaLead)<<8)-1; // 0x2fff
502
+ static const int32_t kMaxThreeByteDelta=((kFourByteDeltaLead-kMinThreeByteDeltaLead)<<16)-1; // 0xdffff
503
+
504
+ uint8_t *ownedArray_;
505
+
506
+ // Fixed value referencing the BytesTrie bytes.
507
+ const uint8_t *bytes_;
508
+
509
+ // Iterator variables.
510
+
511
+ // Pointer to next trie byte to read. NULL if no more matches.
512
+ const uint8_t *pos_;
513
+ // Remaining length of a linear-match node, minus 1. Negative if not in such a node.
514
+ int32_t remainingMatchLength_;
515
+ };
516
+
517
+ U_NAMESPACE_END
518
+
519
+ #endif // __BYTESTRIE_H__