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,82 @@
1
+ /*
2
+ *****************************************************************************************
3
+ * Copyright (C) 2010-2013, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ *****************************************************************************************
6
+ */
7
+
8
+ #ifndef UGENDER_H
9
+ #define UGENDER_H
10
+
11
+ #include "unicode/utypes.h"
12
+
13
+ #if !UCONFIG_NO_FORMATTING
14
+
15
+ #include "unicode/localpointer.h"
16
+
17
+ /**
18
+ * \file
19
+ * \brief C API: The purpose of this API is to compute the gender of a list as a
20
+ * whole given the gender of each element.
21
+ *
22
+ */
23
+
24
+ /**
25
+ * Genders
26
+ * @stable ICU 50
27
+ */
28
+ enum UGender {
29
+ /**
30
+ * Male gender.
31
+ * @stable ICU 50
32
+ */
33
+ UGENDER_MALE,
34
+ /**
35
+ * Female gender.
36
+ * @stable ICU 50
37
+ */
38
+ UGENDER_FEMALE,
39
+ /**
40
+ * Neutral gender.
41
+ * @stable ICU 50
42
+ */
43
+ UGENDER_OTHER
44
+ };
45
+ /**
46
+ * @stable ICU 50
47
+ */
48
+ typedef enum UGender UGender;
49
+
50
+ /**
51
+ * Opaque UGenderInfo object for use in C programs.
52
+ * @stable ICU 50
53
+ */
54
+ struct UGenderInfo;
55
+ typedef struct UGenderInfo UGenderInfo;
56
+
57
+ /**
58
+ * Opens a new UGenderInfo object given locale.
59
+ * @param locale The locale for which the rules are desired.
60
+ * @param status UErrorCode pointer
61
+ * @return A UGenderInfo for the specified locale, or NULL if an error occurred.
62
+ * @stable ICU 50
63
+ */
64
+ U_STABLE const UGenderInfo* U_EXPORT2
65
+ ugender_getInstance(const char *locale, UErrorCode *status);
66
+
67
+
68
+ /**
69
+ * Given a list, returns the gender of the list as a whole.
70
+ * @param genderInfo pointer that ugender_getInstance returns.
71
+ * @param genders the gender of each element in the list.
72
+ * @param size the size of the list.
73
+ * @param status A pointer to a UErrorCode to receive any errors.
74
+ * @return The gender of the list.
75
+ * @stable ICU 50
76
+ */
77
+ U_STABLE UGender U_EXPORT2
78
+ ugender_getListGender(const UGenderInfo* genderinfo, const UGender *genders, int32_t size, UErrorCode *status);
79
+
80
+ #endif /* #if !UCONFIG_NO_FORMATTING */
81
+
82
+ #endif
@@ -0,0 +1,762 @@
1
+ /*
2
+ *******************************************************************************
3
+ *
4
+ * Copyright (C) 2003-2013, International Business Machines
5
+ * Corporation and others. All Rights Reserved.
6
+ *
7
+ *******************************************************************************
8
+ * file name: uidna.h
9
+ * encoding: US-ASCII
10
+ * tab size: 8 (not used)
11
+ * indentation:4
12
+ *
13
+ * created on: 2003feb1
14
+ * created by: Ram Viswanadha
15
+ */
16
+
17
+ #ifndef __UIDNA_H__
18
+ #define __UIDNA_H__
19
+
20
+ #include "unicode/utypes.h"
21
+
22
+ #if !UCONFIG_NO_IDNA
23
+
24
+ #include "unicode/localpointer.h"
25
+ #include "unicode/parseerr.h"
26
+
27
+ /**
28
+ * \file
29
+ * \brief C API: Internationalizing Domain Names in Applications (IDNA)
30
+ *
31
+ * IDNA2008 is implemented according to UTS #46, see the IDNA C++ class in idna.h.
32
+ *
33
+ * The C API functions which do take a UIDNA * service object pointer
34
+ * implement UTS #46 and IDNA2008.
35
+ * The C API functions which do not take a service object pointer
36
+ * implement IDNA2003.
37
+ */
38
+
39
+ /*
40
+ * IDNA option bit set values.
41
+ */
42
+ enum {
43
+ /**
44
+ * Default options value: None of the other options are set.
45
+ * For use in static worker and factory methods.
46
+ * @stable ICU 2.6
47
+ */
48
+ UIDNA_DEFAULT=0,
49
+ /**
50
+ * Option to allow unassigned code points in domain names and labels.
51
+ * For use in static worker and factory methods.
52
+ * <p>This option is ignored by the UTS46 implementation.
53
+ * (UTS #46 disallows unassigned code points.)
54
+ * @stable ICU 2.6
55
+ */
56
+ UIDNA_ALLOW_UNASSIGNED=1,
57
+ /**
58
+ * Option to check whether the input conforms to the STD3 ASCII rules,
59
+ * for example the restriction of labels to LDH characters
60
+ * (ASCII Letters, Digits and Hyphen-Minus).
61
+ * For use in static worker and factory methods.
62
+ * @stable ICU 2.6
63
+ */
64
+ UIDNA_USE_STD3_RULES=2,
65
+ /**
66
+ * IDNA option to check for whether the input conforms to the BiDi rules.
67
+ * For use in static worker and factory methods.
68
+ * <p>This option is ignored by the IDNA2003 implementation.
69
+ * (IDNA2003 always performs a BiDi check.)
70
+ * @stable ICU 4.6
71
+ */
72
+ UIDNA_CHECK_BIDI=4,
73
+ /**
74
+ * IDNA option to check for whether the input conforms to the CONTEXTJ rules.
75
+ * For use in static worker and factory methods.
76
+ * <p>This option is ignored by the IDNA2003 implementation.
77
+ * (The CONTEXTJ check is new in IDNA2008.)
78
+ * @stable ICU 4.6
79
+ */
80
+ UIDNA_CHECK_CONTEXTJ=8,
81
+ /**
82
+ * IDNA option for nontransitional processing in ToASCII().
83
+ * For use in static worker and factory methods.
84
+ * <p>By default, ToASCII() uses transitional processing.
85
+ * <p>This option is ignored by the IDNA2003 implementation.
86
+ * (This is only relevant for compatibility of newer IDNA implementations with IDNA2003.)
87
+ * @stable ICU 4.6
88
+ */
89
+ UIDNA_NONTRANSITIONAL_TO_ASCII=0x10,
90
+ /**
91
+ * IDNA option for nontransitional processing in ToUnicode().
92
+ * For use in static worker and factory methods.
93
+ * <p>By default, ToUnicode() uses transitional processing.
94
+ * <p>This option is ignored by the IDNA2003 implementation.
95
+ * (This is only relevant for compatibility of newer IDNA implementations with IDNA2003.)
96
+ * @stable ICU 4.6
97
+ */
98
+ UIDNA_NONTRANSITIONAL_TO_UNICODE=0x20,
99
+ /**
100
+ * IDNA option to check for whether the input conforms to the CONTEXTO rules.
101
+ * For use in static worker and factory methods.
102
+ * <p>This option is ignored by the IDNA2003 implementation.
103
+ * (The CONTEXTO check is new in IDNA2008.)
104
+ * <p>This is for use by registries for IDNA2008 conformance.
105
+ * UTS #46 does not require the CONTEXTO check.
106
+ * @stable ICU 49
107
+ */
108
+ UIDNA_CHECK_CONTEXTO=0x40
109
+ };
110
+
111
+ /**
112
+ * Opaque C service object type for the new IDNA API.
113
+ * @stable ICU 4.6
114
+ */
115
+ struct UIDNA;
116
+ typedef struct UIDNA UIDNA; /**< C typedef for struct UIDNA. @stable ICU 4.6 */
117
+
118
+ /**
119
+ * Returns a UIDNA instance which implements UTS #46.
120
+ * Returns an unmodifiable instance, owned by the caller.
121
+ * Cache it for multiple operations, and uidna_close() it when done.
122
+ * The instance is thread-safe, that is, it can be used concurrently.
123
+ *
124
+ * For details about the UTS #46 implementation see the IDNA C++ class in idna.h.
125
+ *
126
+ * @param options Bit set to modify the processing and error checking.
127
+ * See option bit set values in uidna.h.
128
+ * @param pErrorCode Standard ICU error code. Its input value must
129
+ * pass the U_SUCCESS() test, or else the function returns
130
+ * immediately. Check for U_FAILURE() on output or use with
131
+ * function chaining. (See User Guide for details.)
132
+ * @return the UTS #46 UIDNA instance, if successful
133
+ * @stable ICU 4.6
134
+ */
135
+ U_STABLE UIDNA * U_EXPORT2
136
+ uidna_openUTS46(uint32_t options, UErrorCode *pErrorCode);
137
+
138
+ /**
139
+ * Closes a UIDNA instance.
140
+ * @param idna UIDNA instance to be closed
141
+ * @stable ICU 4.6
142
+ */
143
+ U_STABLE void U_EXPORT2
144
+ uidna_close(UIDNA *idna);
145
+
146
+ #if U_SHOW_CPLUSPLUS_API
147
+
148
+ U_NAMESPACE_BEGIN
149
+
150
+ /**
151
+ * \class LocalUIDNAPointer
152
+ * "Smart pointer" class, closes a UIDNA via uidna_close().
153
+ * For most methods see the LocalPointerBase base class.
154
+ *
155
+ * @see LocalPointerBase
156
+ * @see LocalPointer
157
+ * @stable ICU 4.6
158
+ */
159
+ U_DEFINE_LOCAL_OPEN_POINTER(LocalUIDNAPointer, UIDNA, uidna_close);
160
+
161
+ U_NAMESPACE_END
162
+
163
+ #endif
164
+
165
+ /**
166
+ * Output container for IDNA processing errors.
167
+ * Initialize with UIDNA_INFO_INITIALIZER:
168
+ * \code
169
+ * UIDNAInfo info = UIDNA_INFO_INITIALIZER;
170
+ * int32_t length = uidna_nameToASCII(..., &info, &errorCode);
171
+ * if(U_SUCCESS(errorCode) && info.errors!=0) { ... }
172
+ * \endcode
173
+ * @stable ICU 4.6
174
+ */
175
+ typedef struct UIDNAInfo {
176
+ /** sizeof(UIDNAInfo) @stable ICU 4.6 */
177
+ int16_t size;
178
+ /**
179
+ * Set to TRUE if transitional and nontransitional processing produce different results.
180
+ * For details see C++ IDNAInfo::isTransitionalDifferent().
181
+ * @stable ICU 4.6
182
+ */
183
+ UBool isTransitionalDifferent;
184
+ UBool reservedB3; /**< Reserved field, do not use. @internal */
185
+ /**
186
+ * Bit set indicating IDNA processing errors. 0 if no errors.
187
+ * See UIDNA_ERROR_... constants.
188
+ * @stable ICU 4.6
189
+ */
190
+ uint32_t errors;
191
+ int32_t reservedI2; /**< Reserved field, do not use. @internal */
192
+ int32_t reservedI3; /**< Reserved field, do not use. @internal */
193
+ } UIDNAInfo;
194
+
195
+ /**
196
+ * Static initializer for a UIDNAInfo struct.
197
+ * @stable ICU 4.6
198
+ */
199
+ #define UIDNA_INFO_INITIALIZER { \
200
+ (int16_t)sizeof(UIDNAInfo), \
201
+ FALSE, FALSE, \
202
+ 0, 0, 0 }
203
+
204
+ /**
205
+ * Converts a single domain name label into its ASCII form for DNS lookup.
206
+ * If any processing step fails, then pInfo->errors will be non-zero and
207
+ * the result might not be an ASCII string.
208
+ * The label might be modified according to the types of errors.
209
+ * Labels with severe errors will be left in (or turned into) their Unicode form.
210
+ *
211
+ * The UErrorCode indicates an error only in exceptional cases,
212
+ * such as a U_MEMORY_ALLOCATION_ERROR.
213
+ *
214
+ * @param idna UIDNA instance
215
+ * @param label Input domain name label
216
+ * @param length Label length, or -1 if NUL-terminated
217
+ * @param dest Destination string buffer
218
+ * @param capacity Destination buffer capacity
219
+ * @param pInfo Output container of IDNA processing details.
220
+ * @param pErrorCode Standard ICU error code. Its input value must
221
+ * pass the U_SUCCESS() test, or else the function returns
222
+ * immediately. Check for U_FAILURE() on output or use with
223
+ * function chaining. (See User Guide for details.)
224
+ * @return destination string length
225
+ * @stable ICU 4.6
226
+ */
227
+ U_STABLE int32_t U_EXPORT2
228
+ uidna_labelToASCII(const UIDNA *idna,
229
+ const UChar *label, int32_t length,
230
+ UChar *dest, int32_t capacity,
231
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
232
+
233
+ /**
234
+ * Converts a single domain name label into its Unicode form for human-readable display.
235
+ * If any processing step fails, then pInfo->errors will be non-zero.
236
+ * The label might be modified according to the types of errors.
237
+ *
238
+ * The UErrorCode indicates an error only in exceptional cases,
239
+ * such as a U_MEMORY_ALLOCATION_ERROR.
240
+ *
241
+ * @param idna UIDNA instance
242
+ * @param label Input domain name label
243
+ * @param length Label length, or -1 if NUL-terminated
244
+ * @param dest Destination string buffer
245
+ * @param capacity Destination buffer capacity
246
+ * @param pInfo Output container of IDNA processing details.
247
+ * @param pErrorCode Standard ICU error code. Its input value must
248
+ * pass the U_SUCCESS() test, or else the function returns
249
+ * immediately. Check for U_FAILURE() on output or use with
250
+ * function chaining. (See User Guide for details.)
251
+ * @return destination string length
252
+ * @stable ICU 4.6
253
+ */
254
+ U_STABLE int32_t U_EXPORT2
255
+ uidna_labelToUnicode(const UIDNA *idna,
256
+ const UChar *label, int32_t length,
257
+ UChar *dest, int32_t capacity,
258
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
259
+
260
+ /**
261
+ * Converts a whole domain name into its ASCII form for DNS lookup.
262
+ * If any processing step fails, then pInfo->errors will be non-zero and
263
+ * the result might not be an ASCII string.
264
+ * The domain name might be modified according to the types of errors.
265
+ * Labels with severe errors will be left in (or turned into) their Unicode form.
266
+ *
267
+ * The UErrorCode indicates an error only in exceptional cases,
268
+ * such as a U_MEMORY_ALLOCATION_ERROR.
269
+ *
270
+ * @param idna UIDNA instance
271
+ * @param name Input domain name
272
+ * @param length Domain name length, or -1 if NUL-terminated
273
+ * @param dest Destination string buffer
274
+ * @param capacity Destination buffer capacity
275
+ * @param pInfo Output container of IDNA processing details.
276
+ * @param pErrorCode Standard ICU error code. Its input value must
277
+ * pass the U_SUCCESS() test, or else the function returns
278
+ * immediately. Check for U_FAILURE() on output or use with
279
+ * function chaining. (See User Guide for details.)
280
+ * @return destination string length
281
+ * @stable ICU 4.6
282
+ */
283
+ U_STABLE int32_t U_EXPORT2
284
+ uidna_nameToASCII(const UIDNA *idna,
285
+ const UChar *name, int32_t length,
286
+ UChar *dest, int32_t capacity,
287
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
288
+
289
+ /**
290
+ * Converts a whole domain name into its Unicode form for human-readable display.
291
+ * If any processing step fails, then pInfo->errors will be non-zero.
292
+ * The domain name might be modified according to the types of errors.
293
+ *
294
+ * The UErrorCode indicates an error only in exceptional cases,
295
+ * such as a U_MEMORY_ALLOCATION_ERROR.
296
+ *
297
+ * @param idna UIDNA instance
298
+ * @param name Input domain name
299
+ * @param length Domain name length, or -1 if NUL-terminated
300
+ * @param dest Destination string buffer
301
+ * @param capacity Destination buffer capacity
302
+ * @param pInfo Output container of IDNA processing details.
303
+ * @param pErrorCode Standard ICU error code. Its input value must
304
+ * pass the U_SUCCESS() test, or else the function returns
305
+ * immediately. Check for U_FAILURE() on output or use with
306
+ * function chaining. (See User Guide for details.)
307
+ * @return destination string length
308
+ * @stable ICU 4.6
309
+ */
310
+ U_STABLE int32_t U_EXPORT2
311
+ uidna_nameToUnicode(const UIDNA *idna,
312
+ const UChar *name, int32_t length,
313
+ UChar *dest, int32_t capacity,
314
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
315
+
316
+ /* UTF-8 versions of the processing methods --------------------------------- */
317
+
318
+ /**
319
+ * Converts a single domain name label into its ASCII form for DNS lookup.
320
+ * UTF-8 version of uidna_labelToASCII(), same behavior.
321
+ *
322
+ * @param idna UIDNA instance
323
+ * @param label Input domain name label
324
+ * @param length Label length, or -1 if NUL-terminated
325
+ * @param dest Destination string buffer
326
+ * @param capacity Destination buffer capacity
327
+ * @param pInfo Output container of IDNA processing details.
328
+ * @param pErrorCode Standard ICU error code. Its input value must
329
+ * pass the U_SUCCESS() test, or else the function returns
330
+ * immediately. Check for U_FAILURE() on output or use with
331
+ * function chaining. (See User Guide for details.)
332
+ * @return destination string length
333
+ * @stable ICU 4.6
334
+ */
335
+ U_STABLE int32_t U_EXPORT2
336
+ uidna_labelToASCII_UTF8(const UIDNA *idna,
337
+ const char *label, int32_t length,
338
+ char *dest, int32_t capacity,
339
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
340
+
341
+ /**
342
+ * Converts a single domain name label into its Unicode form for human-readable display.
343
+ * UTF-8 version of uidna_labelToUnicode(), same behavior.
344
+ *
345
+ * @param idna UIDNA instance
346
+ * @param label Input domain name label
347
+ * @param length Label length, or -1 if NUL-terminated
348
+ * @param dest Destination string buffer
349
+ * @param capacity Destination buffer capacity
350
+ * @param pInfo Output container of IDNA processing details.
351
+ * @param pErrorCode Standard ICU error code. Its input value must
352
+ * pass the U_SUCCESS() test, or else the function returns
353
+ * immediately. Check for U_FAILURE() on output or use with
354
+ * function chaining. (See User Guide for details.)
355
+ * @return destination string length
356
+ * @stable ICU 4.6
357
+ */
358
+ U_STABLE int32_t U_EXPORT2
359
+ uidna_labelToUnicodeUTF8(const UIDNA *idna,
360
+ const char *label, int32_t length,
361
+ char *dest, int32_t capacity,
362
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
363
+
364
+ /**
365
+ * Converts a whole domain name into its ASCII form for DNS lookup.
366
+ * UTF-8 version of uidna_nameToASCII(), same behavior.
367
+ *
368
+ * @param idna UIDNA instance
369
+ * @param name Input domain name
370
+ * @param length Domain name length, or -1 if NUL-terminated
371
+ * @param dest Destination string buffer
372
+ * @param capacity Destination buffer capacity
373
+ * @param pInfo Output container of IDNA processing details.
374
+ * @param pErrorCode Standard ICU error code. Its input value must
375
+ * pass the U_SUCCESS() test, or else the function returns
376
+ * immediately. Check for U_FAILURE() on output or use with
377
+ * function chaining. (See User Guide for details.)
378
+ * @return destination string length
379
+ * @stable ICU 4.6
380
+ */
381
+ U_STABLE int32_t U_EXPORT2
382
+ uidna_nameToASCII_UTF8(const UIDNA *idna,
383
+ const char *name, int32_t length,
384
+ char *dest, int32_t capacity,
385
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
386
+
387
+ /**
388
+ * Converts a whole domain name into its Unicode form for human-readable display.
389
+ * UTF-8 version of uidna_nameToUnicode(), same behavior.
390
+ *
391
+ * @param idna UIDNA instance
392
+ * @param name Input domain name
393
+ * @param length Domain name length, or -1 if NUL-terminated
394
+ * @param dest Destination string buffer
395
+ * @param capacity Destination buffer capacity
396
+ * @param pInfo Output container of IDNA processing details.
397
+ * @param pErrorCode Standard ICU error code. Its input value must
398
+ * pass the U_SUCCESS() test, or else the function returns
399
+ * immediately. Check for U_FAILURE() on output or use with
400
+ * function chaining. (See User Guide for details.)
401
+ * @return destination string length
402
+ * @stable ICU 4.6
403
+ */
404
+ U_STABLE int32_t U_EXPORT2
405
+ uidna_nameToUnicodeUTF8(const UIDNA *idna,
406
+ const char *name, int32_t length,
407
+ char *dest, int32_t capacity,
408
+ UIDNAInfo *pInfo, UErrorCode *pErrorCode);
409
+
410
+ /*
411
+ * IDNA error bit set values.
412
+ * When a domain name or label fails a processing step or does not meet the
413
+ * validity criteria, then one or more of these error bits are set.
414
+ */
415
+ enum {
416
+ /**
417
+ * A non-final domain name label (or the whole domain name) is empty.
418
+ * @stable ICU 4.6
419
+ */
420
+ UIDNA_ERROR_EMPTY_LABEL=1,
421
+ /**
422
+ * A domain name label is longer than 63 bytes.
423
+ * (See STD13/RFC1034 3.1. Name space specifications and terminology.)
424
+ * This is only checked in ToASCII operations, and only if the output label is all-ASCII.
425
+ * @stable ICU 4.6
426
+ */
427
+ UIDNA_ERROR_LABEL_TOO_LONG=2,
428
+ /**
429
+ * A domain name is longer than 255 bytes in its storage form.
430
+ * (See STD13/RFC1034 3.1. Name space specifications and terminology.)
431
+ * This is only checked in ToASCII operations, and only if the output domain name is all-ASCII.
432
+ * @stable ICU 4.6
433
+ */
434
+ UIDNA_ERROR_DOMAIN_NAME_TOO_LONG=4,
435
+ /**
436
+ * A label starts with a hyphen-minus ('-').
437
+ * @stable ICU 4.6
438
+ */
439
+ UIDNA_ERROR_LEADING_HYPHEN=8,
440
+ /**
441
+ * A label ends with a hyphen-minus ('-').
442
+ * @stable ICU 4.6
443
+ */
444
+ UIDNA_ERROR_TRAILING_HYPHEN=0x10,
445
+ /**
446
+ * A label contains hyphen-minus ('-') in the third and fourth positions.
447
+ * @stable ICU 4.6
448
+ */
449
+ UIDNA_ERROR_HYPHEN_3_4=0x20,
450
+ /**
451
+ * A label starts with a combining mark.
452
+ * @stable ICU 4.6
453
+ */
454
+ UIDNA_ERROR_LEADING_COMBINING_MARK=0x40,
455
+ /**
456
+ * A label or domain name contains disallowed characters.
457
+ * @stable ICU 4.6
458
+ */
459
+ UIDNA_ERROR_DISALLOWED=0x80,
460
+ /**
461
+ * A label starts with "xn--" but does not contain valid Punycode.
462
+ * That is, an xn-- label failed Punycode decoding.
463
+ * @stable ICU 4.6
464
+ */
465
+ UIDNA_ERROR_PUNYCODE=0x100,
466
+ /**
467
+ * A label contains a dot=full stop.
468
+ * This can occur in an input string for a single-label function.
469
+ * @stable ICU 4.6
470
+ */
471
+ UIDNA_ERROR_LABEL_HAS_DOT=0x200,
472
+ /**
473
+ * An ACE label does not contain a valid label string.
474
+ * The label was successfully ACE (Punycode) decoded but the resulting
475
+ * string had severe validation errors. For example,
476
+ * it might contain characters that are not allowed in ACE labels,
477
+ * or it might not be normalized.
478
+ * @stable ICU 4.6
479
+ */
480
+ UIDNA_ERROR_INVALID_ACE_LABEL=0x400,
481
+ /**
482
+ * A label does not meet the IDNA BiDi requirements (for right-to-left characters).
483
+ * @stable ICU 4.6
484
+ */
485
+ UIDNA_ERROR_BIDI=0x800,
486
+ /**
487
+ * A label does not meet the IDNA CONTEXTJ requirements.
488
+ * @stable ICU 4.6
489
+ */
490
+ UIDNA_ERROR_CONTEXTJ=0x1000,
491
+ /**
492
+ * A label does not meet the IDNA CONTEXTO requirements for punctuation characters.
493
+ * Some punctuation characters "Would otherwise have been DISALLOWED"
494
+ * but are allowed in certain contexts. (RFC 5892)
495
+ * @stable ICU 49
496
+ */
497
+ UIDNA_ERROR_CONTEXTO_PUNCTUATION=0x2000,
498
+ /**
499
+ * A label does not meet the IDNA CONTEXTO requirements for digits.
500
+ * Arabic-Indic Digits (U+066x) must not be mixed with Extended Arabic-Indic Digits (U+06Fx).
501
+ * @stable ICU 49
502
+ */
503
+ UIDNA_ERROR_CONTEXTO_DIGITS=0x4000
504
+ };
505
+
506
+ /* IDNA2003 API ------------------------------------------------------------- */
507
+
508
+ /**
509
+ * IDNA2003: This function implements the ToASCII operation as defined in the IDNA RFC.
510
+ * This operation is done on <b>single labels</b> before sending it to something that expects
511
+ * ASCII names. A label is an individual part of a domain name. Labels are usually
512
+ * separated by dots; e.g. "www.example.com" is composed of 3 labels "www","example", and "com".
513
+ *
514
+ * IDNA2003 API Overview:
515
+ *
516
+ * The uidna_ API implements the IDNA protocol as defined in the IDNA RFC
517
+ * (http://www.ietf.org/rfc/rfc3490.txt).
518
+ * The RFC defines 2 operations: ToASCII and ToUnicode. Domain name labels
519
+ * containing non-ASCII code points are processed by the
520
+ * ToASCII operation before passing it to resolver libraries. Domain names
521
+ * that are obtained from resolver libraries are processed by the
522
+ * ToUnicode operation before displaying the domain name to the user.
523
+ * IDNA requires that implementations process input strings with Nameprep
524
+ * (http://www.ietf.org/rfc/rfc3491.txt),
525
+ * which is a profile of Stringprep (http://www.ietf.org/rfc/rfc3454.txt),
526
+ * and then with Punycode (http://www.ietf.org/rfc/rfc3492.txt).
527
+ * Implementations of IDNA MUST fully implement Nameprep and Punycode;
528
+ * neither Nameprep nor Punycode are optional.
529
+ * The input and output of ToASCII and ToUnicode operations are Unicode
530
+ * and are designed to be chainable, i.e., applying ToASCII or ToUnicode operations
531
+ * multiple times to an input string will yield the same result as applying the operation
532
+ * once.
533
+ * ToUnicode(ToUnicode(ToUnicode...(ToUnicode(string)))) == ToUnicode(string)
534
+ * ToASCII(ToASCII(ToASCII...(ToASCII(string))) == ToASCII(string).
535
+ *
536
+ * @param src Input UChar array containing label in Unicode.
537
+ * @param srcLength Number of UChars in src, or -1 if NUL-terminated.
538
+ * @param dest Output UChar array with ASCII (ACE encoded) label.
539
+ * @param destCapacity Size of dest.
540
+ * @param options A bit set of options:
541
+ *
542
+ * - UIDNA_DEFAULT Use default options, i.e., do not process unassigned code points
543
+ * and do not use STD3 ASCII rules
544
+ * If unassigned code points are found the operation fails with
545
+ * U_UNASSIGNED_ERROR error code.
546
+ *
547
+ * - UIDNA_ALLOW_UNASSIGNED Unassigned values can be converted to ASCII for query operations
548
+ * If this option is set, the unassigned code points are in the input
549
+ * are treated as normal Unicode code points.
550
+ *
551
+ * - UIDNA_USE_STD3_RULES Use STD3 ASCII rules for host name syntax restrictions
552
+ * If this option is set and the input does not satisfy STD3 rules,
553
+ * the operation will fail with U_IDNA_STD3_ASCII_RULES_ERROR
554
+ *
555
+ * @param parseError Pointer to UParseError struct to receive information on position
556
+ * of error if an error is encountered. Can be NULL.
557
+ * @param status ICU in/out error code parameter.
558
+ * U_INVALID_CHAR_FOUND if src contains
559
+ * unmatched single surrogates.
560
+ * U_INDEX_OUTOFBOUNDS_ERROR if src contains
561
+ * too many code points.
562
+ * U_BUFFER_OVERFLOW_ERROR if destCapacity is not enough
563
+ * @return The length of the result string, if successful - or in case of a buffer overflow,
564
+ * in which case it will be greater than destCapacity.
565
+ * @stable ICU 2.6
566
+ */
567
+ U_STABLE int32_t U_EXPORT2
568
+ uidna_toASCII(const UChar* src, int32_t srcLength,
569
+ UChar* dest, int32_t destCapacity,
570
+ int32_t options,
571
+ UParseError* parseError,
572
+ UErrorCode* status);
573
+
574
+
575
+ /**
576
+ * IDNA2003: This function implements the ToUnicode operation as defined in the IDNA RFC.
577
+ * This operation is done on <b>single labels</b> before sending it to something that expects
578
+ * Unicode names. A label is an individual part of a domain name. Labels are usually
579
+ * separated by dots; for e.g. "www.example.com" is composed of 3 labels "www","example", and "com".
580
+ *
581
+ * @param src Input UChar array containing ASCII (ACE encoded) label.
582
+ * @param srcLength Number of UChars in src, or -1 if NUL-terminated.
583
+ * @param dest Output Converted UChar array containing Unicode equivalent of label.
584
+ * @param destCapacity Size of dest.
585
+ * @param options A bit set of options:
586
+ *
587
+ * - UIDNA_DEFAULT Use default options, i.e., do not process unassigned code points
588
+ * and do not use STD3 ASCII rules
589
+ * If unassigned code points are found the operation fails with
590
+ * U_UNASSIGNED_ERROR error code.
591
+ *
592
+ * - UIDNA_ALLOW_UNASSIGNED Unassigned values can be converted to ASCII for query operations
593
+ * If this option is set, the unassigned code points are in the input
594
+ * are treated as normal Unicode code points. <b> Note: </b> This option is
595
+ * required on toUnicode operation because the RFC mandates
596
+ * verification of decoded ACE input by applying toASCII and comparing
597
+ * its output with source
598
+ *
599
+ * - UIDNA_USE_STD3_RULES Use STD3 ASCII rules for host name syntax restrictions
600
+ * If this option is set and the input does not satisfy STD3 rules,
601
+ * the operation will fail with U_IDNA_STD3_ASCII_RULES_ERROR
602
+ *
603
+ * @param parseError Pointer to UParseError struct to receive information on position
604
+ * of error if an error is encountered. Can be NULL.
605
+ * @param status ICU in/out error code parameter.
606
+ * U_INVALID_CHAR_FOUND if src contains
607
+ * unmatched single surrogates.
608
+ * U_INDEX_OUTOFBOUNDS_ERROR if src contains
609
+ * too many code points.
610
+ * U_BUFFER_OVERFLOW_ERROR if destCapacity is not enough
611
+ * @return The length of the result string, if successful - or in case of a buffer overflow,
612
+ * in which case it will be greater than destCapacity.
613
+ * @stable ICU 2.6
614
+ */
615
+ U_STABLE int32_t U_EXPORT2
616
+ uidna_toUnicode(const UChar* src, int32_t srcLength,
617
+ UChar* dest, int32_t destCapacity,
618
+ int32_t options,
619
+ UParseError* parseError,
620
+ UErrorCode* status);
621
+
622
+
623
+ /**
624
+ * IDNA2003: Convenience function that implements the IDNToASCII operation as defined in the IDNA RFC.
625
+ * This operation is done on complete domain names, e.g: "www.example.com".
626
+ * It is important to note that this operation can fail. If it fails, then the input
627
+ * domain name cannot be used as an Internationalized Domain Name and the application
628
+ * should have methods defined to deal with the failure.
629
+ *
630
+ * <b>Note:</b> IDNA RFC specifies that a conformant application should divide a domain name
631
+ * into separate labels, decide whether to apply allowUnassigned and useSTD3ASCIIRules on each,
632
+ * and then convert. This function does not offer that level of granularity. The options once
633
+ * set will apply to all labels in the domain name
634
+ *
635
+ * @param src Input UChar array containing IDN in Unicode.
636
+ * @param srcLength Number of UChars in src, or -1 if NUL-terminated.
637
+ * @param dest Output UChar array with ASCII (ACE encoded) IDN.
638
+ * @param destCapacity Size of dest.
639
+ * @param options A bit set of options:
640
+ *
641
+ * - UIDNA_DEFAULT Use default options, i.e., do not process unassigned code points
642
+ * and do not use STD3 ASCII rules
643
+ * If unassigned code points are found the operation fails with
644
+ * U_UNASSIGNED_CODE_POINT_FOUND error code.
645
+ *
646
+ * - UIDNA_ALLOW_UNASSIGNED Unassigned values can be converted to ASCII for query operations
647
+ * If this option is set, the unassigned code points are in the input
648
+ * are treated as normal Unicode code points.
649
+ *
650
+ * - UIDNA_USE_STD3_RULES Use STD3 ASCII rules for host name syntax restrictions
651
+ * If this option is set and the input does not satisfy STD3 rules,
652
+ * the operation will fail with U_IDNA_STD3_ASCII_RULES_ERROR
653
+ *
654
+ * @param parseError Pointer to UParseError struct to receive information on position
655
+ * of error if an error is encountered. Can be NULL.
656
+ * @param status ICU in/out error code parameter.
657
+ * U_INVALID_CHAR_FOUND if src contains
658
+ * unmatched single surrogates.
659
+ * U_INDEX_OUTOFBOUNDS_ERROR if src contains
660
+ * too many code points.
661
+ * U_BUFFER_OVERFLOW_ERROR if destCapacity is not enough
662
+ * @return The length of the result string, if successful - or in case of a buffer overflow,
663
+ * in which case it will be greater than destCapacity.
664
+ * @stable ICU 2.6
665
+ */
666
+ U_STABLE int32_t U_EXPORT2
667
+ uidna_IDNToASCII( const UChar* src, int32_t srcLength,
668
+ UChar* dest, int32_t destCapacity,
669
+ int32_t options,
670
+ UParseError* parseError,
671
+ UErrorCode* status);
672
+
673
+ /**
674
+ * IDNA2003: Convenience function that implements the IDNToUnicode operation as defined in the IDNA RFC.
675
+ * This operation is done on complete domain names, e.g: "www.example.com".
676
+ *
677
+ * <b>Note:</b> IDNA RFC specifies that a conformant application should divide a domain name
678
+ * into separate labels, decide whether to apply allowUnassigned and useSTD3ASCIIRules on each,
679
+ * and then convert. This function does not offer that level of granularity. The options once
680
+ * set will apply to all labels in the domain name
681
+ *
682
+ * @param src Input UChar array containing IDN in ASCII (ACE encoded) form.
683
+ * @param srcLength Number of UChars in src, or -1 if NUL-terminated.
684
+ * @param dest Output UChar array containing Unicode equivalent of source IDN.
685
+ * @param destCapacity Size of dest.
686
+ * @param options A bit set of options:
687
+ *
688
+ * - UIDNA_DEFAULT Use default options, i.e., do not process unassigned code points
689
+ * and do not use STD3 ASCII rules
690
+ * If unassigned code points are found the operation fails with
691
+ * U_UNASSIGNED_CODE_POINT_FOUND error code.
692
+ *
693
+ * - UIDNA_ALLOW_UNASSIGNED Unassigned values can be converted to ASCII for query operations
694
+ * If this option is set, the unassigned code points are in the input
695
+ * are treated as normal Unicode code points.
696
+ *
697
+ * - UIDNA_USE_STD3_RULES Use STD3 ASCII rules for host name syntax restrictions
698
+ * If this option is set and the input does not satisfy STD3 rules,
699
+ * the operation will fail with U_IDNA_STD3_ASCII_RULES_ERROR
700
+ *
701
+ * @param parseError Pointer to UParseError struct to receive information on position
702
+ * of error if an error is encountered. Can be NULL.
703
+ * @param status ICU in/out error code parameter.
704
+ * U_INVALID_CHAR_FOUND if src contains
705
+ * unmatched single surrogates.
706
+ * U_INDEX_OUTOFBOUNDS_ERROR if src contains
707
+ * too many code points.
708
+ * U_BUFFER_OVERFLOW_ERROR if destCapacity is not enough
709
+ * @return The length of the result string, if successful - or in case of a buffer overflow,
710
+ * in which case it will be greater than destCapacity.
711
+ * @stable ICU 2.6
712
+ */
713
+ U_STABLE int32_t U_EXPORT2
714
+ uidna_IDNToUnicode( const UChar* src, int32_t srcLength,
715
+ UChar* dest, int32_t destCapacity,
716
+ int32_t options,
717
+ UParseError* parseError,
718
+ UErrorCode* status);
719
+
720
+ /**
721
+ * IDNA2003: Compare two IDN strings for equivalence.
722
+ * This function splits the domain names into labels and compares them.
723
+ * According to IDN RFC, whenever two labels are compared, they are
724
+ * considered equal if and only if their ASCII forms (obtained by
725
+ * applying toASCII) match using an case-insensitive ASCII comparison.
726
+ * Two domain names are considered a match if and only if all labels
727
+ * match regardless of whether label separators match.
728
+ *
729
+ * @param s1 First source string.
730
+ * @param length1 Length of first source string, or -1 if NUL-terminated.
731
+ *
732
+ * @param s2 Second source string.
733
+ * @param length2 Length of second source string, or -1 if NUL-terminated.
734
+ * @param options A bit set of options:
735
+ *
736
+ * - UIDNA_DEFAULT Use default options, i.e., do not process unassigned code points
737
+ * and do not use STD3 ASCII rules
738
+ * If unassigned code points are found the operation fails with
739
+ * U_UNASSIGNED_CODE_POINT_FOUND error code.
740
+ *
741
+ * - UIDNA_ALLOW_UNASSIGNED Unassigned values can be converted to ASCII for query operations
742
+ * If this option is set, the unassigned code points are in the input
743
+ * are treated as normal Unicode code points.
744
+ *
745
+ * - UIDNA_USE_STD3_RULES Use STD3 ASCII rules for host name syntax restrictions
746
+ * If this option is set and the input does not satisfy STD3 rules,
747
+ * the operation will fail with U_IDNA_STD3_ASCII_RULES_ERROR
748
+ *
749
+ * @param status ICU error code in/out parameter.
750
+ * Must fulfill U_SUCCESS before the function call.
751
+ * @return <0 or 0 or >0 as usual for string comparisons
752
+ * @stable ICU 2.6
753
+ */
754
+ U_STABLE int32_t U_EXPORT2
755
+ uidna_compare( const UChar *s1, int32_t length1,
756
+ const UChar *s2, int32_t length2,
757
+ int32_t options,
758
+ UErrorCode* status);
759
+
760
+ #endif /* #if !UCONFIG_NO_IDNA */
761
+
762
+ #endif