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,797 @@
1
+ /*
2
+ ********************************************************************
3
+ * COPYRIGHT:
4
+ * Copyright (c) 1996-2011, International Business Machines Corporation and
5
+ * others. All Rights Reserved.
6
+ ********************************************************************
7
+ */
8
+
9
+ #ifndef NORMLZR_H
10
+ #define NORMLZR_H
11
+
12
+ #include "unicode/utypes.h"
13
+
14
+ /**
15
+ * \file
16
+ * \brief C++ API: Unicode Normalization
17
+ */
18
+
19
+ #if !UCONFIG_NO_NORMALIZATION
20
+
21
+ #include "unicode/chariter.h"
22
+ #include "unicode/normalizer2.h"
23
+ #include "unicode/unistr.h"
24
+ #include "unicode/unorm.h"
25
+ #include "unicode/uobject.h"
26
+
27
+ U_NAMESPACE_BEGIN
28
+ /**
29
+ * The Normalizer class supports the standard normalization forms described in
30
+ * <a href="http://www.unicode.org/unicode/reports/tr15/" target="unicode">
31
+ * Unicode Standard Annex #15: Unicode Normalization Forms</a>.
32
+ *
33
+ * Note: This API has been replaced by the Normalizer2 class and is only available
34
+ * for backward compatibility. This class simply delegates to the Normalizer2 class.
35
+ * There is one exception: The new API does not provide a replacement for Normalizer::compare().
36
+ *
37
+ * The Normalizer class consists of two parts:
38
+ * - static functions that normalize strings or test if strings are normalized
39
+ * - a Normalizer object is an iterator that takes any kind of text and
40
+ * provides iteration over its normalized form
41
+ *
42
+ * The Normalizer class is not suitable for subclassing.
43
+ *
44
+ * For basic information about normalization forms and details about the C API
45
+ * please see the documentation in unorm.h.
46
+ *
47
+ * The iterator API with the Normalizer constructors and the non-static functions
48
+ * use a CharacterIterator as input. It is possible to pass a string which
49
+ * is then internally wrapped in a CharacterIterator.
50
+ * The input text is not normalized all at once, but incrementally where needed
51
+ * (providing efficient random access).
52
+ * This allows to pass in a large text but spend only a small amount of time
53
+ * normalizing a small part of that text.
54
+ * However, if the entire text is normalized, then the iterator will be
55
+ * slower than normalizing the entire text at once and iterating over the result.
56
+ * A possible use of the Normalizer iterator is also to report an index into the
57
+ * original text that is close to where the normalized characters come from.
58
+ *
59
+ * <em>Important:</em> The iterator API was cleaned up significantly for ICU 2.0.
60
+ * The earlier implementation reported the getIndex() inconsistently,
61
+ * and previous() could not be used after setIndex(), next(), first(), and current().
62
+ *
63
+ * Normalizer allows to start normalizing from anywhere in the input text by
64
+ * calling setIndexOnly(), first(), or last().
65
+ * Without calling any of these, the iterator will start at the beginning of the text.
66
+ *
67
+ * At any time, next() returns the next normalized code point (UChar32),
68
+ * with post-increment semantics (like CharacterIterator::next32PostInc()).
69
+ * previous() returns the previous normalized code point (UChar32),
70
+ * with pre-decrement semantics (like CharacterIterator::previous32()).
71
+ *
72
+ * current() returns the current code point
73
+ * (respectively the one at the newly set index) without moving
74
+ * the getIndex(). Note that if the text at the current position
75
+ * needs to be normalized, then these functions will do that.
76
+ * (This is why current() is not const.)
77
+ * It is more efficient to call setIndexOnly() instead, which does not
78
+ * normalize.
79
+ *
80
+ * getIndex() always refers to the position in the input text where the normalized
81
+ * code points are returned from. It does not always change with each returned
82
+ * code point.
83
+ * The code point that is returned from any of the functions
84
+ * corresponds to text at or after getIndex(), according to the
85
+ * function's iteration semantics (post-increment or pre-decrement).
86
+ *
87
+ * next() returns a code point from at or after the getIndex()
88
+ * from before the next() call. After the next() call, the getIndex()
89
+ * might have moved to where the next code point will be returned from
90
+ * (from a next() or current() call).
91
+ * This is semantically equivalent to array access with array[index++]
92
+ * (post-increment semantics).
93
+ *
94
+ * previous() returns a code point from at or after the getIndex()
95
+ * from after the previous() call.
96
+ * This is semantically equivalent to array access with array[--index]
97
+ * (pre-decrement semantics).
98
+ *
99
+ * Internally, the Normalizer iterator normalizes a small piece of text
100
+ * starting at the getIndex() and ending at a following "safe" index.
101
+ * The normalized results is stored in an internal string buffer, and
102
+ * the code points are iterated from there.
103
+ * With multiple iteration calls, this is repeated until the next piece
104
+ * of text needs to be normalized, and the getIndex() needs to be moved.
105
+ *
106
+ * The following "safe" index, the internal buffer, and the secondary
107
+ * iteration index into that buffer are not exposed on the API.
108
+ * This also means that it is currently not practical to return to
109
+ * a particular, arbitrary position in the text because one would need to
110
+ * know, and be able to set, in addition to the getIndex(), at least also the
111
+ * current index into the internal buffer.
112
+ * It is currently only possible to observe when getIndex() changes
113
+ * (with careful consideration of the iteration semantics),
114
+ * at which time the internal index will be 0.
115
+ * For example, if getIndex() is different after next() than before it,
116
+ * then the internal index is 0 and one can return to this getIndex()
117
+ * later with setIndexOnly().
118
+ *
119
+ * Note: While the setIndex() and getIndex() refer to indices in the
120
+ * underlying Unicode input text, the next() and previous() methods
121
+ * iterate through characters in the normalized output.
122
+ * This means that there is not necessarily a one-to-one correspondence
123
+ * between characters returned by next() and previous() and the indices
124
+ * passed to and returned from setIndex() and getIndex().
125
+ * It is for this reason that Normalizer does not implement the CharacterIterator interface.
126
+ *
127
+ * @author Laura Werner, Mark Davis, Markus Scherer
128
+ * @stable ICU 2.0
129
+ */
130
+ class U_COMMON_API Normalizer : public UObject {
131
+ public:
132
+ /**
133
+ * If DONE is returned from an iteration function that returns a code point,
134
+ * then there are no more normalization results available.
135
+ * @stable ICU 2.0
136
+ */
137
+ enum {
138
+ DONE=0xffff
139
+ };
140
+
141
+ // Constructors
142
+
143
+ /**
144
+ * Creates a new <code>Normalizer</code> object for iterating over the
145
+ * normalized form of a given string.
146
+ * <p>
147
+ * @param str The string to be normalized. The normalization
148
+ * will start at the beginning of the string.
149
+ *
150
+ * @param mode The normalization mode.
151
+ * @stable ICU 2.0
152
+ */
153
+ Normalizer(const UnicodeString& str, UNormalizationMode mode);
154
+
155
+ /**
156
+ * Creates a new <code>Normalizer</code> object for iterating over the
157
+ * normalized form of a given string.
158
+ * <p>
159
+ * @param str The string to be normalized. The normalization
160
+ * will start at the beginning of the string.
161
+ *
162
+ * @param length Length of the string, or -1 if NUL-terminated.
163
+ * @param mode The normalization mode.
164
+ * @stable ICU 2.0
165
+ */
166
+ Normalizer(const UChar* str, int32_t length, UNormalizationMode mode);
167
+
168
+ /**
169
+ * Creates a new <code>Normalizer</code> object for iterating over the
170
+ * normalized form of the given text.
171
+ * <p>
172
+ * @param iter The input text to be normalized. The normalization
173
+ * will start at the beginning of the string.
174
+ *
175
+ * @param mode The normalization mode.
176
+ * @stable ICU 2.0
177
+ */
178
+ Normalizer(const CharacterIterator& iter, UNormalizationMode mode);
179
+
180
+ /**
181
+ * Copy constructor.
182
+ * @param copy The object to be copied.
183
+ * @stable ICU 2.0
184
+ */
185
+ Normalizer(const Normalizer& copy);
186
+
187
+ /**
188
+ * Destructor
189
+ * @stable ICU 2.0
190
+ */
191
+ virtual ~Normalizer();
192
+
193
+
194
+ //-------------------------------------------------------------------------
195
+ // Static utility methods
196
+ //-------------------------------------------------------------------------
197
+
198
+ /**
199
+ * Normalizes a <code>UnicodeString</code> according to the specified normalization mode.
200
+ * This is a wrapper for unorm_normalize(), using UnicodeString's.
201
+ *
202
+ * The <code>options</code> parameter specifies which optional
203
+ * <code>Normalizer</code> features are to be enabled for this operation.
204
+ *
205
+ * @param source the input string to be normalized.
206
+ * @param mode the normalization mode
207
+ * @param options the optional features to be enabled (0 for no options)
208
+ * @param result The normalized string (on output).
209
+ * @param status The error code.
210
+ * @stable ICU 2.0
211
+ */
212
+ static void U_EXPORT2 normalize(const UnicodeString& source,
213
+ UNormalizationMode mode, int32_t options,
214
+ UnicodeString& result,
215
+ UErrorCode &status);
216
+
217
+ /**
218
+ * Compose a <code>UnicodeString</code>.
219
+ * This is equivalent to normalize() with mode UNORM_NFC or UNORM_NFKC.
220
+ * This is a wrapper for unorm_normalize(), using UnicodeString's.
221
+ *
222
+ * The <code>options</code> parameter specifies which optional
223
+ * <code>Normalizer</code> features are to be enabled for this operation.
224
+ *
225
+ * @param source the string to be composed.
226
+ * @param compat Perform compatibility decomposition before composition.
227
+ * If this argument is <code>FALSE</code>, only canonical
228
+ * decomposition will be performed.
229
+ * @param options the optional features to be enabled (0 for no options)
230
+ * @param result The composed string (on output).
231
+ * @param status The error code.
232
+ * @stable ICU 2.0
233
+ */
234
+ static void U_EXPORT2 compose(const UnicodeString& source,
235
+ UBool compat, int32_t options,
236
+ UnicodeString& result,
237
+ UErrorCode &status);
238
+
239
+ /**
240
+ * Static method to decompose a <code>UnicodeString</code>.
241
+ * This is equivalent to normalize() with mode UNORM_NFD or UNORM_NFKD.
242
+ * This is a wrapper for unorm_normalize(), using UnicodeString's.
243
+ *
244
+ * The <code>options</code> parameter specifies which optional
245
+ * <code>Normalizer</code> features are to be enabled for this operation.
246
+ *
247
+ * @param source the string to be decomposed.
248
+ * @param compat Perform compatibility decomposition.
249
+ * If this argument is <code>FALSE</code>, only canonical
250
+ * decomposition will be performed.
251
+ * @param options the optional features to be enabled (0 for no options)
252
+ * @param result The decomposed string (on output).
253
+ * @param status The error code.
254
+ * @stable ICU 2.0
255
+ */
256
+ static void U_EXPORT2 decompose(const UnicodeString& source,
257
+ UBool compat, int32_t options,
258
+ UnicodeString& result,
259
+ UErrorCode &status);
260
+
261
+ /**
262
+ * Performing quick check on a string, to quickly determine if the string is
263
+ * in a particular normalization format.
264
+ * This is a wrapper for unorm_quickCheck(), using a UnicodeString.
265
+ *
266
+ * Three types of result can be returned UNORM_YES, UNORM_NO or
267
+ * UNORM_MAYBE. Result UNORM_YES indicates that the argument
268
+ * string is in the desired normalized format, UNORM_NO determines that
269
+ * argument string is not in the desired normalized format. A
270
+ * UNORM_MAYBE result indicates that a more thorough check is required,
271
+ * the user may have to put the string in its normalized form and compare the
272
+ * results.
273
+ * @param source string for determining if it is in a normalized format
274
+ * @param mode normalization format
275
+ * @param status A reference to a UErrorCode to receive any errors
276
+ * @return UNORM_YES, UNORM_NO or UNORM_MAYBE
277
+ *
278
+ * @see isNormalized
279
+ * @stable ICU 2.0
280
+ */
281
+ static inline UNormalizationCheckResult
282
+ quickCheck(const UnicodeString &source, UNormalizationMode mode, UErrorCode &status);
283
+
284
+ /**
285
+ * Performing quick check on a string; same as the other version of quickCheck
286
+ * but takes an extra options parameter like most normalization functions.
287
+ *
288
+ * @param source string for determining if it is in a normalized format
289
+ * @param mode normalization format
290
+ * @param options the optional features to be enabled (0 for no options)
291
+ * @param status A reference to a UErrorCode to receive any errors
292
+ * @return UNORM_YES, UNORM_NO or UNORM_MAYBE
293
+ *
294
+ * @see isNormalized
295
+ * @stable ICU 2.6
296
+ */
297
+ static UNormalizationCheckResult
298
+ quickCheck(const UnicodeString &source, UNormalizationMode mode, int32_t options, UErrorCode &status);
299
+
300
+ /**
301
+ * Test if a string is in a given normalization form.
302
+ * This is semantically equivalent to source.equals(normalize(source, mode)) .
303
+ *
304
+ * Unlike unorm_quickCheck(), this function returns a definitive result,
305
+ * never a "maybe".
306
+ * For NFD, NFKD, and FCD, both functions work exactly the same.
307
+ * For NFC and NFKC where quickCheck may return "maybe", this function will
308
+ * perform further tests to arrive at a TRUE/FALSE result.
309
+ *
310
+ * @param src String that is to be tested if it is in a normalization format.
311
+ * @param mode Which normalization form to test for.
312
+ * @param errorCode ICU error code in/out parameter.
313
+ * Must fulfill U_SUCCESS before the function call.
314
+ * @return Boolean value indicating whether the source string is in the
315
+ * "mode" normalization form.
316
+ *
317
+ * @see quickCheck
318
+ * @stable ICU 2.2
319
+ */
320
+ static inline UBool
321
+ isNormalized(const UnicodeString &src, UNormalizationMode mode, UErrorCode &errorCode);
322
+
323
+ /**
324
+ * Test if a string is in a given normalization form; same as the other version of isNormalized
325
+ * but takes an extra options parameter like most normalization functions.
326
+ *
327
+ * @param src String that is to be tested if it is in a normalization format.
328
+ * @param mode Which normalization form to test for.
329
+ * @param options the optional features to be enabled (0 for no options)
330
+ * @param errorCode ICU error code in/out parameter.
331
+ * Must fulfill U_SUCCESS before the function call.
332
+ * @return Boolean value indicating whether the source string is in the
333
+ * "mode" normalization form.
334
+ *
335
+ * @see quickCheck
336
+ * @stable ICU 2.6
337
+ */
338
+ static UBool
339
+ isNormalized(const UnicodeString &src, UNormalizationMode mode, int32_t options, UErrorCode &errorCode);
340
+
341
+ /**
342
+ * Concatenate normalized strings, making sure that the result is normalized as well.
343
+ *
344
+ * If both the left and the right strings are in
345
+ * the normalization form according to "mode/options",
346
+ * then the result will be
347
+ *
348
+ * \code
349
+ * dest=normalize(left+right, mode, options)
350
+ * \endcode
351
+ *
352
+ * For details see unorm_concatenate in unorm.h.
353
+ *
354
+ * @param left Left source string.
355
+ * @param right Right source string.
356
+ * @param result The output string.
357
+ * @param mode The normalization mode.
358
+ * @param options A bit set of normalization options.
359
+ * @param errorCode ICU error code in/out parameter.
360
+ * Must fulfill U_SUCCESS before the function call.
361
+ * @return result
362
+ *
363
+ * @see unorm_concatenate
364
+ * @see normalize
365
+ * @see unorm_next
366
+ * @see unorm_previous
367
+ *
368
+ * @stable ICU 2.1
369
+ */
370
+ static UnicodeString &
371
+ U_EXPORT2 concatenate(const UnicodeString &left, const UnicodeString &right,
372
+ UnicodeString &result,
373
+ UNormalizationMode mode, int32_t options,
374
+ UErrorCode &errorCode);
375
+
376
+ /**
377
+ * Compare two strings for canonical equivalence.
378
+ * Further options include case-insensitive comparison and
379
+ * code point order (as opposed to code unit order).
380
+ *
381
+ * Canonical equivalence between two strings is defined as their normalized
382
+ * forms (NFD or NFC) being identical.
383
+ * This function compares strings incrementally instead of normalizing
384
+ * (and optionally case-folding) both strings entirely,
385
+ * improving performance significantly.
386
+ *
387
+ * Bulk normalization is only necessary if the strings do not fulfill the FCD
388
+ * conditions. Only in this case, and only if the strings are relatively long,
389
+ * is memory allocated temporarily.
390
+ * For FCD strings and short non-FCD strings there is no memory allocation.
391
+ *
392
+ * Semantically, this is equivalent to
393
+ * strcmp[CodePointOrder](NFD(foldCase(s1)), NFD(foldCase(s2)))
394
+ * where code point order and foldCase are all optional.
395
+ *
396
+ * UAX 21 2.5 Caseless Matching specifies that for a canonical caseless match
397
+ * the case folding must be performed first, then the normalization.
398
+ *
399
+ * @param s1 First source string.
400
+ * @param s2 Second source string.
401
+ *
402
+ * @param options A bit set of options:
403
+ * - U_FOLD_CASE_DEFAULT or 0 is used for default options:
404
+ * Case-sensitive comparison in code unit order, and the input strings
405
+ * are quick-checked for FCD.
406
+ *
407
+ * - UNORM_INPUT_IS_FCD
408
+ * Set if the caller knows that both s1 and s2 fulfill the FCD conditions.
409
+ * If not set, the function will quickCheck for FCD
410
+ * and normalize if necessary.
411
+ *
412
+ * - U_COMPARE_CODE_POINT_ORDER
413
+ * Set to choose code point order instead of code unit order
414
+ * (see u_strCompare for details).
415
+ *
416
+ * - U_COMPARE_IGNORE_CASE
417
+ * Set to compare strings case-insensitively using case folding,
418
+ * instead of case-sensitively.
419
+ * If set, then the following case folding options are used.
420
+ *
421
+ * - Options as used with case-insensitive comparisons, currently:
422
+ *
423
+ * - U_FOLD_CASE_EXCLUDE_SPECIAL_I
424
+ * (see u_strCaseCompare for details)
425
+ *
426
+ * - regular normalization options shifted left by UNORM_COMPARE_NORM_OPTIONS_SHIFT
427
+ *
428
+ * @param errorCode ICU error code in/out parameter.
429
+ * Must fulfill U_SUCCESS before the function call.
430
+ * @return <0 or 0 or >0 as usual for string comparisons
431
+ *
432
+ * @see unorm_compare
433
+ * @see normalize
434
+ * @see UNORM_FCD
435
+ * @see u_strCompare
436
+ * @see u_strCaseCompare
437
+ *
438
+ * @stable ICU 2.2
439
+ */
440
+ static inline int32_t
441
+ compare(const UnicodeString &s1, const UnicodeString &s2,
442
+ uint32_t options,
443
+ UErrorCode &errorCode);
444
+
445
+ //-------------------------------------------------------------------------
446
+ // Iteration API
447
+ //-------------------------------------------------------------------------
448
+
449
+ /**
450
+ * Return the current character in the normalized text.
451
+ * current() may need to normalize some text at getIndex().
452
+ * The getIndex() is not changed.
453
+ *
454
+ * @return the current normalized code point
455
+ * @stable ICU 2.0
456
+ */
457
+ UChar32 current(void);
458
+
459
+ /**
460
+ * Return the first character in the normalized text.
461
+ * This is equivalent to setIndexOnly(startIndex()) followed by next().
462
+ * (Post-increment semantics.)
463
+ *
464
+ * @return the first normalized code point
465
+ * @stable ICU 2.0
466
+ */
467
+ UChar32 first(void);
468
+
469
+ /**
470
+ * Return the last character in the normalized text.
471
+ * This is equivalent to setIndexOnly(endIndex()) followed by previous().
472
+ * (Pre-decrement semantics.)
473
+ *
474
+ * @return the last normalized code point
475
+ * @stable ICU 2.0
476
+ */
477
+ UChar32 last(void);
478
+
479
+ /**
480
+ * Return the next character in the normalized text.
481
+ * (Post-increment semantics.)
482
+ * If the end of the text has already been reached, DONE is returned.
483
+ * The DONE value could be confused with a U+FFFF non-character code point
484
+ * in the text. If this is possible, you can test getIndex()<endIndex()
485
+ * before calling next(), or (getIndex()<endIndex() || last()!=DONE)
486
+ * after calling next(). (Calling last() will change the iterator state!)
487
+ *
488
+ * The C API unorm_next() is more efficient and does not have this ambiguity.
489
+ *
490
+ * @return the next normalized code point
491
+ * @stable ICU 2.0
492
+ */
493
+ UChar32 next(void);
494
+
495
+ /**
496
+ * Return the previous character in the normalized text and decrement.
497
+ * (Pre-decrement semantics.)
498
+ * If the beginning of the text has already been reached, DONE is returned.
499
+ * The DONE value could be confused with a U+FFFF non-character code point
500
+ * in the text. If this is possible, you can test
501
+ * (getIndex()>startIndex() || first()!=DONE). (Calling first() will change
502
+ * the iterator state!)
503
+ *
504
+ * The C API unorm_previous() is more efficient and does not have this ambiguity.
505
+ *
506
+ * @return the previous normalized code point
507
+ * @stable ICU 2.0
508
+ */
509
+ UChar32 previous(void);
510
+
511
+ /**
512
+ * Set the iteration position in the input text that is being normalized,
513
+ * without any immediate normalization.
514
+ * After setIndexOnly(), getIndex() will return the same index that is
515
+ * specified here.
516
+ *
517
+ * @param index the desired index in the input text.
518
+ * @stable ICU 2.0
519
+ */
520
+ void setIndexOnly(int32_t index);
521
+
522
+ /**
523
+ * Reset the index to the beginning of the text.
524
+ * This is equivalent to setIndexOnly(startIndex)).
525
+ * @stable ICU 2.0
526
+ */
527
+ void reset(void);
528
+
529
+ /**
530
+ * Retrieve the current iteration position in the input text that is
531
+ * being normalized.
532
+ *
533
+ * A following call to next() will return a normalized code point from
534
+ * the input text at or after this index.
535
+ *
536
+ * After a call to previous(), getIndex() will point at or before the
537
+ * position in the input text where the normalized code point
538
+ * was returned from with previous().
539
+ *
540
+ * @return the current index in the input text
541
+ * @stable ICU 2.0
542
+ */
543
+ int32_t getIndex(void) const;
544
+
545
+ /**
546
+ * Retrieve the index of the start of the input text. This is the begin index
547
+ * of the <code>CharacterIterator</code> or the start (i.e. index 0) of the string
548
+ * over which this <code>Normalizer</code> is iterating.
549
+ *
550
+ * @return the smallest index in the input text where the Normalizer operates
551
+ * @stable ICU 2.0
552
+ */
553
+ int32_t startIndex(void) const;
554
+
555
+ /**
556
+ * Retrieve the index of the end of the input text. This is the end index
557
+ * of the <code>CharacterIterator</code> or the length of the string
558
+ * over which this <code>Normalizer</code> is iterating.
559
+ * This end index is exclusive, i.e., the Normalizer operates only on characters
560
+ * before this index.
561
+ *
562
+ * @return the first index in the input text where the Normalizer does not operate
563
+ * @stable ICU 2.0
564
+ */
565
+ int32_t endIndex(void) const;
566
+
567
+ /**
568
+ * Returns TRUE when both iterators refer to the same character in the same
569
+ * input text.
570
+ *
571
+ * @param that a Normalizer object to compare this one to
572
+ * @return comparison result
573
+ * @stable ICU 2.0
574
+ */
575
+ UBool operator==(const Normalizer& that) const;
576
+
577
+ /**
578
+ * Returns FALSE when both iterators refer to the same character in the same
579
+ * input text.
580
+ *
581
+ * @param that a Normalizer object to compare this one to
582
+ * @return comparison result
583
+ * @stable ICU 2.0
584
+ */
585
+ inline UBool operator!=(const Normalizer& that) const;
586
+
587
+ /**
588
+ * Returns a pointer to a new Normalizer that is a clone of this one.
589
+ * The caller is responsible for deleting the new clone.
590
+ * @return a pointer to a new Normalizer
591
+ * @stable ICU 2.0
592
+ */
593
+ Normalizer* clone(void) const;
594
+
595
+ /**
596
+ * Generates a hash code for this iterator.
597
+ *
598
+ * @return the hash code
599
+ * @stable ICU 2.0
600
+ */
601
+ int32_t hashCode(void) const;
602
+
603
+ //-------------------------------------------------------------------------
604
+ // Property access methods
605
+ //-------------------------------------------------------------------------
606
+
607
+ /**
608
+ * Set the normalization mode for this object.
609
+ * <p>
610
+ * <b>Note:</b>If the normalization mode is changed while iterating
611
+ * over a string, calls to {@link #next() } and {@link #previous() } may
612
+ * return previously buffers characters in the old normalization mode
613
+ * until the iteration is able to re-sync at the next base character.
614
+ * It is safest to call {@link #setIndexOnly }, {@link #reset() },
615
+ * {@link #setText }, {@link #first() },
616
+ * {@link #last() }, etc. after calling <code>setMode</code>.
617
+ * <p>
618
+ * @param newMode the new mode for this <code>Normalizer</code>.
619
+ * @see #getUMode
620
+ * @stable ICU 2.0
621
+ */
622
+ void setMode(UNormalizationMode newMode);
623
+
624
+ /**
625
+ * Return the normalization mode for this object.
626
+ *
627
+ * This is an unusual name because there used to be a getMode() that
628
+ * returned a different type.
629
+ *
630
+ * @return the mode for this <code>Normalizer</code>
631
+ * @see #setMode
632
+ * @stable ICU 2.0
633
+ */
634
+ UNormalizationMode getUMode(void) const;
635
+
636
+ /**
637
+ * Set options that affect this <code>Normalizer</code>'s operation.
638
+ * Options do not change the basic composition or decomposition operation
639
+ * that is being performed, but they control whether
640
+ * certain optional portions of the operation are done.
641
+ * Currently the only available option is obsolete.
642
+ *
643
+ * It is possible to specify multiple options that are all turned on or off.
644
+ *
645
+ * @param option the option(s) whose value is/are to be set.
646
+ * @param value the new setting for the option. Use <code>TRUE</code> to
647
+ * turn the option(s) on and <code>FALSE</code> to turn it/them off.
648
+ *
649
+ * @see #getOption
650
+ * @stable ICU 2.0
651
+ */
652
+ void setOption(int32_t option,
653
+ UBool value);
654
+
655
+ /**
656
+ * Determine whether an option is turned on or off.
657
+ * If multiple options are specified, then the result is TRUE if any
658
+ * of them are set.
659
+ * <p>
660
+ * @param option the option(s) that are to be checked
661
+ * @return TRUE if any of the option(s) are set
662
+ * @see #setOption
663
+ * @stable ICU 2.0
664
+ */
665
+ UBool getOption(int32_t option) const;
666
+
667
+ /**
668
+ * Set the input text over which this <code>Normalizer</code> will iterate.
669
+ * The iteration position is set to the beginning.
670
+ *
671
+ * @param newText a string that replaces the current input text
672
+ * @param status a UErrorCode
673
+ * @stable ICU 2.0
674
+ */
675
+ void setText(const UnicodeString& newText,
676
+ UErrorCode &status);
677
+
678
+ /**
679
+ * Set the input text over which this <code>Normalizer</code> will iterate.
680
+ * The iteration position is set to the beginning.
681
+ *
682
+ * @param newText a CharacterIterator object that replaces the current input text
683
+ * @param status a UErrorCode
684
+ * @stable ICU 2.0
685
+ */
686
+ void setText(const CharacterIterator& newText,
687
+ UErrorCode &status);
688
+
689
+ /**
690
+ * Set the input text over which this <code>Normalizer</code> will iterate.
691
+ * The iteration position is set to the beginning.
692
+ *
693
+ * @param newText a string that replaces the current input text
694
+ * @param length the length of the string, or -1 if NUL-terminated
695
+ * @param status a UErrorCode
696
+ * @stable ICU 2.0
697
+ */
698
+ void setText(const UChar* newText,
699
+ int32_t length,
700
+ UErrorCode &status);
701
+ /**
702
+ * Copies the input text into the UnicodeString argument.
703
+ *
704
+ * @param result Receives a copy of the text under iteration.
705
+ * @stable ICU 2.0
706
+ */
707
+ void getText(UnicodeString& result);
708
+
709
+ /**
710
+ * ICU "poor man's RTTI", returns a UClassID for this class.
711
+ * @returns a UClassID for this class.
712
+ * @stable ICU 2.2
713
+ */
714
+ static UClassID U_EXPORT2 getStaticClassID();
715
+
716
+ /**
717
+ * ICU "poor man's RTTI", returns a UClassID for the actual class.
718
+ * @return a UClassID for the actual class.
719
+ * @stable ICU 2.2
720
+ */
721
+ virtual UClassID getDynamicClassID() const;
722
+
723
+ private:
724
+ //-------------------------------------------------------------------------
725
+ // Private functions
726
+ //-------------------------------------------------------------------------
727
+
728
+ Normalizer(); // default constructor not implemented
729
+ Normalizer &operator=(const Normalizer &that); // assignment operator not implemented
730
+
731
+ // Private utility methods for iteration
732
+ // For documentation, see the source code
733
+ UBool nextNormalize();
734
+ UBool previousNormalize();
735
+
736
+ void init();
737
+ void clearBuffer(void);
738
+
739
+ //-------------------------------------------------------------------------
740
+ // Private data
741
+ //-------------------------------------------------------------------------
742
+
743
+ FilteredNormalizer2*fFilteredNorm2; // owned if not NULL
744
+ const Normalizer2 *fNorm2; // not owned; may be equal to fFilteredNorm2
745
+ UNormalizationMode fUMode;
746
+ int32_t fOptions;
747
+
748
+ // The input text and our position in it
749
+ CharacterIterator *text;
750
+
751
+ // The normalization buffer is the result of normalization
752
+ // of the source in [currentIndex..nextIndex[ .
753
+ int32_t currentIndex, nextIndex;
754
+
755
+ // A buffer for holding intermediate results
756
+ UnicodeString buffer;
757
+ int32_t bufferPos;
758
+ };
759
+
760
+ //-------------------------------------------------------------------------
761
+ // Inline implementations
762
+ //-------------------------------------------------------------------------
763
+
764
+ inline UBool
765
+ Normalizer::operator!= (const Normalizer& other) const
766
+ { return ! operator==(other); }
767
+
768
+ inline UNormalizationCheckResult
769
+ Normalizer::quickCheck(const UnicodeString& source,
770
+ UNormalizationMode mode,
771
+ UErrorCode &status) {
772
+ return quickCheck(source, mode, 0, status);
773
+ }
774
+
775
+ inline UBool
776
+ Normalizer::isNormalized(const UnicodeString& source,
777
+ UNormalizationMode mode,
778
+ UErrorCode &status) {
779
+ return isNormalized(source, mode, 0, status);
780
+ }
781
+
782
+ inline int32_t
783
+ Normalizer::compare(const UnicodeString &s1, const UnicodeString &s2,
784
+ uint32_t options,
785
+ UErrorCode &errorCode) {
786
+ // all argument checking is done in unorm_compare
787
+ return unorm_compare(s1.getBuffer(), s1.length(),
788
+ s2.getBuffer(), s2.length(),
789
+ options,
790
+ &errorCode);
791
+ }
792
+
793
+ U_NAMESPACE_END
794
+
795
+ #endif /* #if !UCONFIG_NO_NORMALIZATION */
796
+
797
+ #endif // NORMLZR_H