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,359 @@
1
+ /*
2
+ *******************************************************************************
3
+ *
4
+ * Copyright (C) 2003-2013, International Business Machines
5
+ * Corporation and others. All Rights Reserved.
6
+ *
7
+ *******************************************************************************
8
+ * file name: utrace.h
9
+ * encoding: US-ASCII
10
+ * tab size: 8 (not used)
11
+ * indentation:4
12
+ *
13
+ * created on: 2003aug06
14
+ * created by: Markus W. Scherer
15
+ *
16
+ * Definitions for ICU tracing/logging.
17
+ *
18
+ */
19
+
20
+ #ifndef __UTRACE_H__
21
+ #define __UTRACE_H__
22
+
23
+ #include <stdarg.h>
24
+ #include "unicode/utypes.h"
25
+
26
+ /**
27
+ * \file
28
+ * \brief C API: Definitions for ICU tracing/logging.
29
+ *
30
+ * This provides API for debugging the internals of ICU without the use of
31
+ * a traditional debugger.
32
+ *
33
+ * By default, tracing is disabled in ICU. If you need to debug ICU with
34
+ * tracing, please compile ICU with the --enable-tracing configure option.
35
+ */
36
+
37
+ U_CDECL_BEGIN
38
+
39
+ /**
40
+ * Trace severity levels. Higher levels increase the verbosity of the trace output.
41
+ * @see utrace_setLevel
42
+ * @stable ICU 2.8
43
+ */
44
+ typedef enum UTraceLevel {
45
+ /** Disable all tracing @stable ICU 2.8*/
46
+ UTRACE_OFF=-1,
47
+ /** Trace error conditions only @stable ICU 2.8*/
48
+ UTRACE_ERROR=0,
49
+ /** Trace errors and warnings @stable ICU 2.8*/
50
+ UTRACE_WARNING=3,
51
+ /** Trace opens and closes of ICU services @stable ICU 2.8*/
52
+ UTRACE_OPEN_CLOSE=5,
53
+ /** Trace an intermediate number of ICU operations @stable ICU 2.8*/
54
+ UTRACE_INFO=7,
55
+ /** Trace the maximum number of ICU operations @stable ICU 2.8*/
56
+ UTRACE_VERBOSE=9
57
+ } UTraceLevel;
58
+
59
+ /**
60
+ * These are the ICU functions that will be traced when tracing is enabled.
61
+ * @stable ICU 2.8
62
+ */
63
+ typedef enum UTraceFunctionNumber {
64
+ UTRACE_FUNCTION_START=0,
65
+ UTRACE_U_INIT=UTRACE_FUNCTION_START,
66
+ UTRACE_U_CLEANUP,
67
+ UTRACE_FUNCTION_LIMIT,
68
+
69
+ UTRACE_CONVERSION_START=0x1000,
70
+ UTRACE_UCNV_OPEN=UTRACE_CONVERSION_START,
71
+ UTRACE_UCNV_OPEN_PACKAGE,
72
+ UTRACE_UCNV_OPEN_ALGORITHMIC,
73
+ UTRACE_UCNV_CLONE,
74
+ UTRACE_UCNV_CLOSE,
75
+ UTRACE_UCNV_FLUSH_CACHE,
76
+ UTRACE_UCNV_LOAD,
77
+ UTRACE_UCNV_UNLOAD,
78
+ UTRACE_CONVERSION_LIMIT,
79
+
80
+ UTRACE_COLLATION_START=0x2000,
81
+ UTRACE_UCOL_OPEN=UTRACE_COLLATION_START,
82
+ UTRACE_UCOL_CLOSE,
83
+ UTRACE_UCOL_STRCOLL,
84
+ UTRACE_UCOL_GET_SORTKEY,
85
+ UTRACE_UCOL_GETLOCALE,
86
+ UTRACE_UCOL_NEXTSORTKEYPART,
87
+ UTRACE_UCOL_STRCOLLITER,
88
+ UTRACE_UCOL_OPEN_FROM_SHORT_STRING,
89
+ UTRACE_UCOL_STRCOLLUTF8, /**< @stable ICU 50 */
90
+ UTRACE_COLLATION_LIMIT
91
+ } UTraceFunctionNumber;
92
+
93
+ /**
94
+ * Setter for the trace level.
95
+ * @param traceLevel A UTraceLevel value.
96
+ * @stable ICU 2.8
97
+ */
98
+ U_STABLE void U_EXPORT2
99
+ utrace_setLevel(int32_t traceLevel);
100
+
101
+ /**
102
+ * Getter for the trace level.
103
+ * @return The UTraceLevel value being used by ICU.
104
+ * @stable ICU 2.8
105
+ */
106
+ U_STABLE int32_t U_EXPORT2
107
+ utrace_getLevel(void);
108
+
109
+ /* Trace function pointers types ----------------------------- */
110
+
111
+ /**
112
+ * Type signature for the trace function to be called when entering a function.
113
+ * @param context value supplied at the time the trace functions are set.
114
+ * @param fnNumber Enum value indicating the ICU function being entered.
115
+ * @stable ICU 2.8
116
+ */
117
+ typedef void U_CALLCONV
118
+ UTraceEntry(const void *context, int32_t fnNumber);
119
+
120
+ /**
121
+ * Type signature for the trace function to be called when exiting from a function.
122
+ * @param context value supplied at the time the trace functions are set.
123
+ * @param fnNumber Enum value indicating the ICU function being exited.
124
+ * @param fmt A formatting string that describes the number and types
125
+ * of arguments included with the variable args. The fmt
126
+ * string has the same form as the utrace_vformat format
127
+ * string.
128
+ * @param args A variable arguments list. Contents are described by
129
+ * the fmt parameter.
130
+ * @see utrace_vformat
131
+ * @stable ICU 2.8
132
+ */
133
+ typedef void U_CALLCONV
134
+ UTraceExit(const void *context, int32_t fnNumber,
135
+ const char *fmt, va_list args);
136
+
137
+ /**
138
+ * Type signature for the trace function to be called from within an ICU function
139
+ * to display data or messages.
140
+ * @param context value supplied at the time the trace functions are set.
141
+ * @param fnNumber Enum value indicating the ICU function being exited.
142
+ * @param level The current tracing level
143
+ * @param fmt A format string describing the tracing data that is supplied
144
+ * as variable args
145
+ * @param args The data being traced, passed as variable args.
146
+ * @stable ICU 2.8
147
+ */
148
+ typedef void U_CALLCONV
149
+ UTraceData(const void *context, int32_t fnNumber, int32_t level,
150
+ const char *fmt, va_list args);
151
+
152
+ /**
153
+ * Set ICU Tracing functions. Installs application-provided tracing
154
+ * functions into ICU. After doing this, subsequent ICU operations
155
+ * will call back to the installed functions, providing a trace
156
+ * of the use of ICU. Passing a NULL pointer for a tracing function
157
+ * is allowed, and inhibits tracing action at points where that function
158
+ * would be called.
159
+ * <p>
160
+ * Tracing and Threads: Tracing functions are global to a process, and
161
+ * will be called in response to ICU operations performed by any
162
+ * thread. If tracing of an individual thread is desired, the
163
+ * tracing functions must themselves filter by checking that the
164
+ * current thread is the desired thread.
165
+ *
166
+ * @param context an uninterpretted pointer. Whatever is passed in
167
+ * here will in turn be passed to each of the tracing
168
+ * functions UTraceEntry, UTraceExit and UTraceData.
169
+ * ICU does not use or alter this pointer.
170
+ * @param e Callback function to be called on entry to a
171
+ * a traced ICU function.
172
+ * @param x Callback function to be called on exit from a
173
+ * traced ICU function.
174
+ * @param d Callback function to be called from within a
175
+ * traced ICU function, for the purpose of providing
176
+ * data to the trace.
177
+ *
178
+ * @stable ICU 2.8
179
+ */
180
+ U_STABLE void U_EXPORT2
181
+ utrace_setFunctions(const void *context,
182
+ UTraceEntry *e, UTraceExit *x, UTraceData *d);
183
+
184
+ /**
185
+ * Get the currently installed ICU tracing functions. Note that a null function
186
+ * pointer will be returned if no trace function has been set.
187
+ *
188
+ * @param context The currently installed tracing context.
189
+ * @param e The currently installed UTraceEntry function.
190
+ * @param x The currently installed UTraceExit function.
191
+ * @param d The currently installed UTraceData function.
192
+ * @stable ICU 2.8
193
+ */
194
+ U_STABLE void U_EXPORT2
195
+ utrace_getFunctions(const void **context,
196
+ UTraceEntry **e, UTraceExit **x, UTraceData **d);
197
+
198
+
199
+
200
+ /*
201
+ *
202
+ * ICU trace format string syntax
203
+ *
204
+ * Format Strings are passed to UTraceData functions, and define the
205
+ * number and types of the trace data being passed on each call.
206
+ *
207
+ * The UTraceData function, which is supplied by the application,
208
+ * not by ICU, can either forward the trace data (passed via
209
+ * varargs) and the format string back to ICU for formatting into
210
+ * a displayable string, or it can interpret the format itself,
211
+ * and do as it wishes with the trace data.
212
+ *
213
+ *
214
+ * Goals for the format string
215
+ * - basic data output
216
+ * - easy to use for trace programmer
217
+ * - sufficient provision for data types for trace output readability
218
+ * - well-defined types and binary portable APIs
219
+ *
220
+ * Non-goals
221
+ * - printf compatibility
222
+ * - fancy formatting
223
+ * - argument reordering and other internationalization features
224
+ *
225
+ * ICU trace format strings contain plain text with argument inserts,
226
+ * much like standard printf format strings.
227
+ * Each insert begins with a '%', then optionally contains a 'v',
228
+ * then exactly one type character.
229
+ * Two '%' in a row represent a '%' instead of an insert.
230
+ * The trace format strings need not have \n at the end.
231
+ *
232
+ *
233
+ * Types
234
+ * -----
235
+ *
236
+ * Type characters:
237
+ * - c A char character in the default codepage.
238
+ * - s A NUL-terminated char * string in the default codepage.
239
+ * - S A UChar * string. Requires two params, (ptr, length). Length=-1 for nul term.
240
+ * - b A byte (8-bit integer).
241
+ * - h A 16-bit integer. Also a 16 bit Unicode code unit.
242
+ * - d A 32-bit integer. Also a 20 bit Unicode code point value.
243
+ * - l A 64-bit integer.
244
+ * - p A data pointer.
245
+ *
246
+ * Vectors
247
+ * -------
248
+ *
249
+ * If the 'v' is not specified, then one item of the specified type
250
+ * is passed in.
251
+ * If the 'v' (for "vector") is specified, then a vector of items of the
252
+ * specified type is passed in, via a pointer to the first item
253
+ * and an int32_t value for the length of the vector.
254
+ * Length==-1 means zero or NUL termination. Works for vectors of all types.
255
+ *
256
+ * Note: %vS is a vector of (UChar *) strings. The strings must
257
+ * be nul terminated as there is no way to provide a
258
+ * separate length parameter for each string. The length
259
+ * parameter (required for all vectors) is the number of
260
+ * strings, not the length of the strings.
261
+ *
262
+ * Examples
263
+ * --------
264
+ *
265
+ * These examples show the parameters that will be passed to an application's
266
+ * UTraceData() function for various formats.
267
+ *
268
+ * - the precise formatting is up to the application!
269
+ * - the examples use type casts for arguments only to _show_ the types of
270
+ * arguments without needing variable declarations in the examples;
271
+ * the type casts will not be necessary in actual code
272
+ *
273
+ * UTraceDataFunc(context, fnNumber, level,
274
+ * "There is a character %c in the string %s.", // Format String
275
+ * (char)c, (const char *)s); // varargs parameters
276
+ * -> There is a character 0x42 'B' in the string "Bravo".
277
+ *
278
+ * UTraceDataFunc(context, fnNumber, level,
279
+ * "Vector of bytes %vb vector of chars %vc",
280
+ * (const uint8_t *)bytes, (int32_t)bytesLength,
281
+ * (const char *)chars, (int32_t)charsLength);
282
+ * -> Vector of bytes
283
+ * 42 63 64 3f [4]
284
+ * vector of chars
285
+ * "Bcd?"[4]
286
+ *
287
+ * UTraceDataFunc(context, fnNumber, level,
288
+ * "An int32_t %d and a whole bunch of them %vd",
289
+ * (int32_t)-5, (const int32_t *)ints, (int32_t)intsLength);
290
+ * -> An int32_t 0xfffffffb and a whole bunch of them
291
+ * fffffffb 00000005 0000010a [3]
292
+ *
293
+ */
294
+
295
+
296
+
297
+ /**
298
+ * Trace output Formatter. An application's UTraceData tracing functions may call
299
+ * back to this function to format the trace output in a
300
+ * human readable form. Note that a UTraceData function may choose
301
+ * to not format the data; it could, for example, save it in
302
+ * in the raw form it was received (more compact), leaving
303
+ * formatting for a later trace analyis tool.
304
+ * @param outBuf pointer to a buffer to receive the formatted output. Output
305
+ * will be nul terminated if there is space in the buffer -
306
+ * if the length of the requested output < the output buffer size.
307
+ * @param capacity Length of the output buffer.
308
+ * @param indent Number of spaces to indent the output. Intended to allow
309
+ * data displayed from nested functions to be indented for readability.
310
+ * @param fmt Format specification for the data to output
311
+ * @param args Data to be formatted.
312
+ * @return Length of formatted output, including the terminating NUL.
313
+ * If buffer capacity is insufficient, the required capacity is returned.
314
+ * @stable ICU 2.8
315
+ */
316
+ U_STABLE int32_t U_EXPORT2
317
+ utrace_vformat(char *outBuf, int32_t capacity,
318
+ int32_t indent, const char *fmt, va_list args);
319
+
320
+ /**
321
+ * Trace output Formatter. An application's UTraceData tracing functions may call
322
+ * this function to format any additional trace data, beyond that
323
+ * provided by default, in human readable form with the same
324
+ * formatting conventions used by utrace_vformat().
325
+ * @param outBuf pointer to a buffer to receive the formatted output. Output
326
+ * will be nul terminated if there is space in the buffer -
327
+ * if the length of the requested output < the output buffer size.
328
+ * @param capacity Length of the output buffer.
329
+ * @param indent Number of spaces to indent the output. Intended to allow
330
+ * data displayed from nested functions to be indented for readability.
331
+ * @param fmt Format specification for the data to output
332
+ * @param ... Data to be formatted.
333
+ * @return Length of formatted output, including the terminating NUL.
334
+ * If buffer capacity is insufficient, the required capacity is returned.
335
+ * @stable ICU 2.8
336
+ */
337
+ U_STABLE int32_t U_EXPORT2
338
+ utrace_format(char *outBuf, int32_t capacity,
339
+ int32_t indent, const char *fmt, ...);
340
+
341
+
342
+
343
+ /* Trace function numbers --------------------------------------------------- */
344
+
345
+ /**
346
+ * Get the name of a function from its trace function number.
347
+ *
348
+ * @param fnNumber The trace number for an ICU function.
349
+ * @return The name string for the function.
350
+ *
351
+ * @see UTraceFunctionNumber
352
+ * @stable ICU 2.8
353
+ */
354
+ U_STABLE const char * U_EXPORT2
355
+ utrace_functionName(int32_t fnNumber);
356
+
357
+ U_CDECL_END
358
+
359
+ #endif
@@ -0,0 +1,658 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 1997-2011,2014 International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ *******************************************************************************
6
+ * Date Name Description
7
+ * 06/21/00 aliu Creation.
8
+ *******************************************************************************
9
+ */
10
+
11
+ #ifndef UTRANS_H
12
+ #define UTRANS_H
13
+
14
+ #include "unicode/utypes.h"
15
+
16
+ #if !UCONFIG_NO_TRANSLITERATION
17
+
18
+ #include "unicode/localpointer.h"
19
+ #include "unicode/urep.h"
20
+ #include "unicode/parseerr.h"
21
+ #include "unicode/uenum.h"
22
+ #include "unicode/uset.h"
23
+
24
+ /********************************************************************
25
+ * General Notes
26
+ ********************************************************************
27
+ */
28
+ /**
29
+ * \file
30
+ * \brief C API: Transliterator
31
+ *
32
+ * <h2> Transliteration </h2>
33
+ * The data structures and functions described in this header provide
34
+ * transliteration services. Transliteration services are implemented
35
+ * as C++ classes. The comments and documentation in this header
36
+ * assume the reader is familiar with the C++ headers translit.h and
37
+ * associated documentation.
38
+ *
39
+ * A significant but incomplete subset of the C++ transliteration
40
+ * services are available to C code through this header. In order to
41
+ * access more complex transliteration services, refer to the C++
42
+ * headers and documentation.
43
+ *
44
+ * There are two sets of functions for working with transliterator IDs:
45
+ *
46
+ * An old, deprecated set uses char * IDs, which works for true and pure
47
+ * identifiers that these APIs were designed for,
48
+ * for example "Cyrillic-Latin".
49
+ * It does not work when the ID contains filters ("[:Script=Cyrl:]")
50
+ * or even a complete set of rules because then the ID string contains more
51
+ * than just "invariant" characters (see utypes.h).
52
+ *
53
+ * A new set of functions replaces the old ones and uses UChar * IDs,
54
+ * paralleling the UnicodeString IDs in the C++ API. (New in ICU 2.8.)
55
+ */
56
+
57
+ /********************************************************************
58
+ * Data Structures
59
+ ********************************************************************/
60
+
61
+ /**
62
+ * An opaque transliterator for use in C. Open with utrans_openxxx()
63
+ * and close with utrans_close() when done. Equivalent to the C++ class
64
+ * Transliterator and its subclasses.
65
+ * @see Transliterator
66
+ * @stable ICU 2.0
67
+ */
68
+ typedef void* UTransliterator;
69
+
70
+ /**
71
+ * Direction constant indicating the direction in a transliterator,
72
+ * e.g., the forward or reverse rules of a RuleBasedTransliterator.
73
+ * Specified when a transliterator is opened. An "A-B" transliterator
74
+ * transliterates A to B when operating in the forward direction, and
75
+ * B to A when operating in the reverse direction.
76
+ * @stable ICU 2.0
77
+ */
78
+ typedef enum UTransDirection {
79
+
80
+ /**
81
+ * UTRANS_FORWARD means from &lt;source&gt; to &lt;target&gt; for a
82
+ * transliterator with ID &lt;source&gt;-&lt;target&gt;. For a transliterator
83
+ * opened using a rule, it means forward direction rules, e.g.,
84
+ * "A > B".
85
+ */
86
+ UTRANS_FORWARD,
87
+
88
+ /**
89
+ * UTRANS_REVERSE means from &lt;target&gt; to &lt;source&gt; for a
90
+ * transliterator with ID &lt;source&gt;-&lt;target&gt;. For a transliterator
91
+ * opened using a rule, it means reverse direction rules, e.g.,
92
+ * "A < B".
93
+ */
94
+ UTRANS_REVERSE
95
+
96
+ } UTransDirection;
97
+
98
+ /**
99
+ * Position structure for utrans_transIncremental() incremental
100
+ * transliteration. This structure defines two substrings of the text
101
+ * being transliterated. The first region, [contextStart,
102
+ * contextLimit), defines what characters the transliterator will read
103
+ * as context. The second region, [start, limit), defines what
104
+ * characters will actually be transliterated. The second region
105
+ * should be a subset of the first.
106
+ *
107
+ * <p>After a transliteration operation, some of the indices in this
108
+ * structure will be modified. See the field descriptions for
109
+ * details.
110
+ *
111
+ * <p>contextStart <= start <= limit <= contextLimit
112
+ *
113
+ * <p>Note: All index values in this structure must be at code point
114
+ * boundaries. That is, none of them may occur between two code units
115
+ * of a surrogate pair. If any index does split a surrogate pair,
116
+ * results are unspecified.
117
+ *
118
+ * @stable ICU 2.0
119
+ */
120
+ typedef struct UTransPosition {
121
+
122
+ /**
123
+ * Beginning index, inclusive, of the context to be considered for
124
+ * a transliteration operation. The transliterator will ignore
125
+ * anything before this index. INPUT/OUTPUT parameter: This parameter
126
+ * is updated by a transliteration operation to reflect the maximum
127
+ * amount of antecontext needed by a transliterator.
128
+ * @stable ICU 2.4
129
+ */
130
+ int32_t contextStart;
131
+
132
+ /**
133
+ * Ending index, exclusive, of the context to be considered for a
134
+ * transliteration operation. The transliterator will ignore
135
+ * anything at or after this index. INPUT/OUTPUT parameter: This
136
+ * parameter is updated to reflect changes in the length of the
137
+ * text, but points to the same logical position in the text.
138
+ * @stable ICU 2.4
139
+ */
140
+ int32_t contextLimit;
141
+
142
+ /**
143
+ * Beginning index, inclusive, of the text to be transliteratd.
144
+ * INPUT/OUTPUT parameter: This parameter is advanced past
145
+ * characters that have already been transliterated by a
146
+ * transliteration operation.
147
+ * @stable ICU 2.4
148
+ */
149
+ int32_t start;
150
+
151
+ /**
152
+ * Ending index, exclusive, of the text to be transliteratd.
153
+ * INPUT/OUTPUT parameter: This parameter is updated to reflect
154
+ * changes in the length of the text, but points to the same
155
+ * logical position in the text.
156
+ * @stable ICU 2.4
157
+ */
158
+ int32_t limit;
159
+
160
+ } UTransPosition;
161
+
162
+ /********************************************************************
163
+ * General API
164
+ ********************************************************************/
165
+
166
+ /**
167
+ * Open a custom transliterator, given a custom rules string
168
+ * OR
169
+ * a system transliterator, given its ID.
170
+ * Any non-NULL result from this function should later be closed with
171
+ * utrans_close().
172
+ *
173
+ * @param id a valid transliterator ID
174
+ * @param idLength the length of the ID string, or -1 if NUL-terminated
175
+ * @param dir the desired direction
176
+ * @param rules the transliterator rules. See the C++ header rbt.h for
177
+ * rules syntax. If NULL then a system transliterator matching
178
+ * the ID is returned.
179
+ * @param rulesLength the length of the rules, or -1 if the rules
180
+ * are NUL-terminated.
181
+ * @param parseError a pointer to a UParseError struct to receive the details
182
+ * of any parsing errors. This parameter may be NULL if no
183
+ * parsing error details are desired.
184
+ * @param pErrorCode a pointer to the UErrorCode
185
+ * @return a transliterator pointer that may be passed to other
186
+ * utrans_xxx() functions, or NULL if the open call fails.
187
+ * @stable ICU 2.8
188
+ */
189
+ U_STABLE UTransliterator* U_EXPORT2
190
+ utrans_openU(const UChar *id,
191
+ int32_t idLength,
192
+ UTransDirection dir,
193
+ const UChar *rules,
194
+ int32_t rulesLength,
195
+ UParseError *parseError,
196
+ UErrorCode *pErrorCode);
197
+
198
+ /**
199
+ * Open an inverse of an existing transliterator. For this to work,
200
+ * the inverse must be registered with the system. For example, if
201
+ * the Transliterator "A-B" is opened, and then its inverse is opened,
202
+ * the result is the Transliterator "B-A", if such a transliterator is
203
+ * registered with the system. Otherwise the result is NULL and a
204
+ * failing UErrorCode is set. Any non-NULL result from this function
205
+ * should later be closed with utrans_close().
206
+ *
207
+ * @param trans the transliterator to open the inverse of.
208
+ * @param status a pointer to the UErrorCode
209
+ * @return a pointer to a newly-opened transliterator that is the
210
+ * inverse of trans, or NULL if the open call fails.
211
+ * @stable ICU 2.0
212
+ */
213
+ U_STABLE UTransliterator* U_EXPORT2
214
+ utrans_openInverse(const UTransliterator* trans,
215
+ UErrorCode* status);
216
+
217
+ /**
218
+ * Create a copy of a transliterator. Any non-NULL result from this
219
+ * function should later be closed with utrans_close().
220
+ *
221
+ * @param trans the transliterator to be copied.
222
+ * @param status a pointer to the UErrorCode
223
+ * @return a transliterator pointer that may be passed to other
224
+ * utrans_xxx() functions, or NULL if the clone call fails.
225
+ * @stable ICU 2.0
226
+ */
227
+ U_STABLE UTransliterator* U_EXPORT2
228
+ utrans_clone(const UTransliterator* trans,
229
+ UErrorCode* status);
230
+
231
+ /**
232
+ * Close a transliterator. Any non-NULL pointer returned by
233
+ * utrans_openXxx() or utrans_clone() should eventually be closed.
234
+ * @param trans the transliterator to be closed.
235
+ * @stable ICU 2.0
236
+ */
237
+ U_STABLE void U_EXPORT2
238
+ utrans_close(UTransliterator* trans);
239
+
240
+ #if U_SHOW_CPLUSPLUS_API
241
+
242
+ U_NAMESPACE_BEGIN
243
+
244
+ /**
245
+ * \class LocalUTransliteratorPointer
246
+ * "Smart pointer" class, closes a UTransliterator via utrans_close().
247
+ * For most methods see the LocalPointerBase base class.
248
+ *
249
+ * @see LocalPointerBase
250
+ * @see LocalPointer
251
+ * @stable ICU 4.4
252
+ */
253
+ U_DEFINE_LOCAL_OPEN_POINTER(LocalUTransliteratorPointer, UTransliterator, utrans_close);
254
+
255
+ U_NAMESPACE_END
256
+
257
+ #endif
258
+
259
+ /**
260
+ * Return the programmatic identifier for this transliterator.
261
+ * If this identifier is passed to utrans_openU(), it will open
262
+ * a transliterator equivalent to this one, if the ID has been
263
+ * registered.
264
+ *
265
+ * @param trans the transliterator to return the ID of.
266
+ * @param resultLength pointer to an output variable receiving the length
267
+ * of the ID string; can be NULL
268
+ * @return the NUL-terminated ID string. This pointer remains
269
+ * valid until utrans_close() is called on this transliterator.
270
+ *
271
+ * @stable ICU 2.8
272
+ */
273
+ U_STABLE const UChar * U_EXPORT2
274
+ utrans_getUnicodeID(const UTransliterator *trans,
275
+ int32_t *resultLength);
276
+
277
+ /**
278
+ * Register an open transliterator with the system. When
279
+ * utrans_open() is called with an ID string that is equal to that
280
+ * returned by utrans_getID(adoptedTrans,...), then
281
+ * utrans_clone(adoptedTrans,...) is returned.
282
+ *
283
+ * <p>NOTE: After this call the system owns the adoptedTrans and will
284
+ * close it. The user must not call utrans_close() on adoptedTrans.
285
+ *
286
+ * @param adoptedTrans a transliterator, typically the result of
287
+ * utrans_openRules(), to be registered with the system.
288
+ * @param status a pointer to the UErrorCode
289
+ * @stable ICU 2.0
290
+ */
291
+ U_STABLE void U_EXPORT2
292
+ utrans_register(UTransliterator* adoptedTrans,
293
+ UErrorCode* status);
294
+
295
+ /**
296
+ * Unregister a transliterator from the system. After this call the
297
+ * system will no longer recognize the given ID when passed to
298
+ * utrans_open(). If the ID is invalid then nothing is done.
299
+ *
300
+ * @param id an ID to unregister
301
+ * @param idLength the length of id, or -1 if id is zero-terminated
302
+ * @stable ICU 2.8
303
+ */
304
+ U_STABLE void U_EXPORT2
305
+ utrans_unregisterID(const UChar* id, int32_t idLength);
306
+
307
+ /**
308
+ * Set the filter used by a transliterator. A filter can be used to
309
+ * make the transliterator pass certain characters through untouched.
310
+ * The filter is expressed using a UnicodeSet pattern. If the
311
+ * filterPattern is NULL or the empty string, then the transliterator
312
+ * will be reset to use no filter.
313
+ *
314
+ * @param trans the transliterator
315
+ * @param filterPattern a pattern string, in the form accepted by
316
+ * UnicodeSet, specifying which characters to apply the
317
+ * transliteration to. May be NULL or the empty string to indicate no
318
+ * filter.
319
+ * @param filterPatternLen the length of filterPattern, or -1 if
320
+ * filterPattern is zero-terminated
321
+ * @param status a pointer to the UErrorCode
322
+ * @see UnicodeSet
323
+ * @stable ICU 2.0
324
+ */
325
+ U_STABLE void U_EXPORT2
326
+ utrans_setFilter(UTransliterator* trans,
327
+ const UChar* filterPattern,
328
+ int32_t filterPatternLen,
329
+ UErrorCode* status);
330
+
331
+ /**
332
+ * Return the number of system transliterators.
333
+ * It is recommended to use utrans_openIDs() instead.
334
+ *
335
+ * @return the number of system transliterators.
336
+ * @stable ICU 2.0
337
+ */
338
+ U_STABLE int32_t U_EXPORT2
339
+ utrans_countAvailableIDs(void);
340
+
341
+ /**
342
+ * Return a UEnumeration for the available transliterators.
343
+ *
344
+ * @param pErrorCode Pointer to the UErrorCode in/out parameter.
345
+ * @return UEnumeration for the available transliterators.
346
+ * Close with uenum_close().
347
+ *
348
+ * @stable ICU 2.8
349
+ */
350
+ U_STABLE UEnumeration * U_EXPORT2
351
+ utrans_openIDs(UErrorCode *pErrorCode);
352
+
353
+ /********************************************************************
354
+ * Transliteration API
355
+ ********************************************************************/
356
+
357
+ /**
358
+ * Transliterate a segment of a UReplaceable string. The string is
359
+ * passed in as a UReplaceable pointer rep and a UReplaceableCallbacks
360
+ * function pointer struct repFunc. Functions in the repFunc struct
361
+ * will be called in order to modify the rep string.
362
+ *
363
+ * @param trans the transliterator
364
+ * @param rep a pointer to the string. This will be passed to the
365
+ * repFunc functions.
366
+ * @param repFunc a set of function pointers that will be used to
367
+ * modify the string pointed to by rep.
368
+ * @param start the beginning index, inclusive; <code>0 <= start <=
369
+ * limit</code>.
370
+ * @param limit pointer to the ending index, exclusive; <code>start <=
371
+ * limit <= repFunc->length(rep)</code>. Upon return, *limit will
372
+ * contain the new limit index. The text previously occupying
373
+ * <code>[start, limit)</code> has been transliterated, possibly to a
374
+ * string of a different length, at <code>[start,
375
+ * </code><em>new-limit</em><code>)</code>, where <em>new-limit</em>
376
+ * is the return value.
377
+ * @param status a pointer to the UErrorCode
378
+ * @stable ICU 2.0
379
+ */
380
+ U_STABLE void U_EXPORT2
381
+ utrans_trans(const UTransliterator* trans,
382
+ UReplaceable* rep,
383
+ UReplaceableCallbacks* repFunc,
384
+ int32_t start,
385
+ int32_t* limit,
386
+ UErrorCode* status);
387
+
388
+ /**
389
+ * Transliterate the portion of the UReplaceable text buffer that can
390
+ * be transliterated unambiguosly. This method is typically called
391
+ * after new text has been inserted, e.g. as a result of a keyboard
392
+ * event. The transliterator will try to transliterate characters of
393
+ * <code>rep</code> between <code>index.cursor</code> and
394
+ * <code>index.limit</code>. Characters before
395
+ * <code>index.cursor</code> will not be changed.
396
+ *
397
+ * <p>Upon return, values in <code>index</code> will be updated.
398
+ * <code>index.start</code> will be advanced to the first
399
+ * character that future calls to this method will read.
400
+ * <code>index.cursor</code> and <code>index.limit</code> will
401
+ * be adjusted to delimit the range of text that future calls to
402
+ * this method may change.
403
+ *
404
+ * <p>Typical usage of this method begins with an initial call
405
+ * with <code>index.start</code> and <code>index.limit</code>
406
+ * set to indicate the portion of <code>text</code> to be
407
+ * transliterated, and <code>index.cursor == index.start</code>.
408
+ * Thereafter, <code>index</code> can be used without
409
+ * modification in future calls, provided that all changes to
410
+ * <code>text</code> are made via this method.
411
+ *
412
+ * <p>This method assumes that future calls may be made that will
413
+ * insert new text into the buffer. As a result, it only performs
414
+ * unambiguous transliterations. After the last call to this method,
415
+ * there may be untransliterated text that is waiting for more input
416
+ * to resolve an ambiguity. In order to perform these pending
417
+ * transliterations, clients should call utrans_trans() with a start
418
+ * of index.start and a limit of index.end after the last call to this
419
+ * method has been made.
420
+ *
421
+ * @param trans the transliterator
422
+ * @param rep a pointer to the string. This will be passed to the
423
+ * repFunc functions.
424
+ * @param repFunc a set of function pointers that will be used to
425
+ * modify the string pointed to by rep.
426
+ * @param pos a struct containing the start and limit indices of the
427
+ * text to be read and the text to be transliterated
428
+ * @param status a pointer to the UErrorCode
429
+ * @stable ICU 2.0
430
+ */
431
+ U_STABLE void U_EXPORT2
432
+ utrans_transIncremental(const UTransliterator* trans,
433
+ UReplaceable* rep,
434
+ UReplaceableCallbacks* repFunc,
435
+ UTransPosition* pos,
436
+ UErrorCode* status);
437
+
438
+ /**
439
+ * Transliterate a segment of a UChar* string. The string is passed
440
+ * in in a UChar* buffer. The string is modified in place. If the
441
+ * result is longer than textCapacity, it is truncated. The actual
442
+ * length of the result is returned in *textLength, if textLength is
443
+ * non-NULL. *textLength may be greater than textCapacity, but only
444
+ * textCapacity UChars will be written to *text, including the zero
445
+ * terminator.
446
+ *
447
+ * @param trans the transliterator
448
+ * @param text a pointer to a buffer containing the text to be
449
+ * transliterated on input and the result text on output.
450
+ * @param textLength a pointer to the length of the string in text.
451
+ * If the length is -1 then the string is assumed to be
452
+ * zero-terminated. Upon return, the new length is stored in
453
+ * *textLength. If textLength is NULL then the string is assumed to
454
+ * be zero-terminated.
455
+ * @param textCapacity a pointer to the length of the text buffer.
456
+ * Upon return,
457
+ * @param start the beginning index, inclusive; <code>0 <= start <=
458
+ * limit</code>.
459
+ * @param limit pointer to the ending index, exclusive; <code>start <=
460
+ * limit <= repFunc->length(rep)</code>. Upon return, *limit will
461
+ * contain the new limit index. The text previously occupying
462
+ * <code>[start, limit)</code> has been transliterated, possibly to a
463
+ * string of a different length, at <code>[start,
464
+ * </code><em>new-limit</em><code>)</code>, where <em>new-limit</em>
465
+ * is the return value.
466
+ * @param status a pointer to the UErrorCode
467
+ * @stable ICU 2.0
468
+ */
469
+ U_STABLE void U_EXPORT2
470
+ utrans_transUChars(const UTransliterator* trans,
471
+ UChar* text,
472
+ int32_t* textLength,
473
+ int32_t textCapacity,
474
+ int32_t start,
475
+ int32_t* limit,
476
+ UErrorCode* status);
477
+
478
+ /**
479
+ * Transliterate the portion of the UChar* text buffer that can be
480
+ * transliterated unambiguosly. See utrans_transIncremental(). The
481
+ * string is passed in in a UChar* buffer. The string is modified in
482
+ * place. If the result is longer than textCapacity, it is truncated.
483
+ * The actual length of the result is returned in *textLength, if
484
+ * textLength is non-NULL. *textLength may be greater than
485
+ * textCapacity, but only textCapacity UChars will be written to
486
+ * *text, including the zero terminator. See utrans_transIncremental()
487
+ * for usage details.
488
+ *
489
+ * @param trans the transliterator
490
+ * @param text a pointer to a buffer containing the text to be
491
+ * transliterated on input and the result text on output.
492
+ * @param textLength a pointer to the length of the string in text.
493
+ * If the length is -1 then the string is assumed to be
494
+ * zero-terminated. Upon return, the new length is stored in
495
+ * *textLength. If textLength is NULL then the string is assumed to
496
+ * be zero-terminated.
497
+ * @param textCapacity the length of the text buffer
498
+ * @param pos a struct containing the start and limit indices of the
499
+ * text to be read and the text to be transliterated
500
+ * @param status a pointer to the UErrorCode
501
+ * @see utrans_transIncremental
502
+ * @stable ICU 2.0
503
+ */
504
+ U_STABLE void U_EXPORT2
505
+ utrans_transIncrementalUChars(const UTransliterator* trans,
506
+ UChar* text,
507
+ int32_t* textLength,
508
+ int32_t textCapacity,
509
+ UTransPosition* pos,
510
+ UErrorCode* status);
511
+
512
+ #ifndef U_HIDE_DRAFT_API
513
+ /**
514
+ * Create a rule string that can be passed to utrans_openU to recreate this
515
+ * transliterator.
516
+ *
517
+ * @param trans The transliterator
518
+ * @param escapeUnprintable if TRUE then convert unprintable characters to their
519
+ * hex escape representations, \\uxxxx or \\Uxxxxxxxx.
520
+ * Unprintable characters are those other than
521
+ * U+000A, U+0020..U+007E.
522
+ * @param result A pointer to a buffer to receive the rules.
523
+ * @param resultLength The maximum size of result.
524
+ * @param status A pointer to the UErrorCode. In case of error status, the
525
+ * contents of result are undefined.
526
+ * @return int32_t The length of the rule string (may be greater than resultLength,
527
+ * in which case an error is returned).
528
+ * @draft ICU 53
529
+ */
530
+ U_DRAFT int32_t U_EXPORT2
531
+ utrans_toRules( const UTransliterator* trans,
532
+ UBool escapeUnprintable,
533
+ UChar* result, int32_t resultLength,
534
+ UErrorCode* status);
535
+
536
+ /**
537
+ * Returns the set of all characters that may be modified in the input text by
538
+ * this UTransliterator, optionally ignoring the transliterator's current filter.
539
+ * @param trans The transliterator.
540
+ * @param ignoreFilter If FALSE, the returned set incorporates the
541
+ * UTransliterator's current filter; if the filter is changed,
542
+ * the return value of this function will change. If TRUE, the
543
+ * returned set ignores the effect of the UTransliterator's
544
+ * current filter.
545
+ * @param fillIn Pointer to a USet object to receive the modifiable characters
546
+ * set. Previous contents of fillIn are lost. <em>If fillIn is
547
+ * NULL, then a new USet is created and returned. The caller
548
+ * owns the result and must dispose of it by calling uset_close.</em>
549
+ * @param status A pointer to the UErrorCode.
550
+ * @return USet* Either fillIn, or if fillIn is NULL, a pointer to a
551
+ * newly-allocated USet that the user must close. In case of
552
+ * error, NULL is returned.
553
+ * @draft ICU 53
554
+ */
555
+ U_DRAFT USet* U_EXPORT2
556
+ utrans_getSourceSet(const UTransliterator* trans,
557
+ UBool ignoreFilter,
558
+ USet* fillIn,
559
+ UErrorCode* status);
560
+ #endif /* U_HIDE_DRAFT_API */
561
+
562
+ /* deprecated API ----------------------------------------------------------- */
563
+
564
+ #ifndef U_HIDE_DEPRECATED_API
565
+
566
+ /* see utrans.h documentation for why these functions are deprecated */
567
+
568
+ /**
569
+ * Deprecated, use utrans_openU() instead.
570
+ * Open a custom transliterator, given a custom rules string
571
+ * OR
572
+ * a system transliterator, given its ID.
573
+ * Any non-NULL result from this function should later be closed with
574
+ * utrans_close().
575
+ *
576
+ * @param id a valid ID, as returned by utrans_getAvailableID()
577
+ * @param dir the desired direction
578
+ * @param rules the transliterator rules. See the C++ header rbt.h
579
+ * for rules syntax. If NULL then a system transliterator matching
580
+ * the ID is returned.
581
+ * @param rulesLength the length of the rules, or -1 if the rules
582
+ * are zero-terminated.
583
+ * @param parseError a pointer to a UParseError struct to receive the
584
+ * details of any parsing errors. This parameter may be NULL if no
585
+ * parsing error details are desired.
586
+ * @param status a pointer to the UErrorCode
587
+ * @return a transliterator pointer that may be passed to other
588
+ * utrans_xxx() functions, or NULL if the open call fails.
589
+ * @deprecated ICU 2.8 Use utrans_openU() instead, see utrans.h
590
+ */
591
+ U_DEPRECATED UTransliterator* U_EXPORT2
592
+ utrans_open(const char* id,
593
+ UTransDirection dir,
594
+ const UChar* rules, /* may be Null */
595
+ int32_t rulesLength, /* -1 if null-terminated */
596
+ UParseError* parseError, /* may be Null */
597
+ UErrorCode* status);
598
+
599
+ /**
600
+ * Deprecated, use utrans_getUnicodeID() instead.
601
+ * Return the programmatic identifier for this transliterator.
602
+ * If this identifier is passed to utrans_open(), it will open
603
+ * a transliterator equivalent to this one, if the ID has been
604
+ * registered.
605
+ * @param trans the transliterator to return the ID of.
606
+ * @param buf the buffer in which to receive the ID. This may be
607
+ * NULL, in which case no characters are copied.
608
+ * @param bufCapacity the capacity of the buffer. Ignored if buf is
609
+ * NULL.
610
+ * @return the actual length of the ID, not including
611
+ * zero-termination. This may be greater than bufCapacity.
612
+ * @deprecated ICU 2.8 Use utrans_getUnicodeID() instead, see utrans.h
613
+ */
614
+ U_DEPRECATED int32_t U_EXPORT2
615
+ utrans_getID(const UTransliterator* trans,
616
+ char* buf,
617
+ int32_t bufCapacity);
618
+
619
+ /**
620
+ * Deprecated, use utrans_unregisterID() instead.
621
+ * Unregister a transliterator from the system. After this call the
622
+ * system will no longer recognize the given ID when passed to
623
+ * utrans_open(). If the id is invalid then nothing is done.
624
+ *
625
+ * @param id a zero-terminated ID
626
+ * @deprecated ICU 2.8 Use utrans_unregisterID() instead, see utrans.h
627
+ */
628
+ U_DEPRECATED void U_EXPORT2
629
+ utrans_unregister(const char* id);
630
+
631
+ /**
632
+ * Deprecated, use utrans_openIDs() instead.
633
+ * Return the ID of the index-th system transliterator. The result
634
+ * is placed in the given buffer. If the given buffer is too small,
635
+ * the initial substring is copied to buf. The result in buf is
636
+ * always zero-terminated.
637
+ *
638
+ * @param index the number of the transliterator to return. Must
639
+ * satisfy 0 <= index < utrans_countAvailableIDs(). If index is out
640
+ * of range then it is treated as if it were 0.
641
+ * @param buf the buffer in which to receive the ID. This may be
642
+ * NULL, in which case no characters are copied.
643
+ * @param bufCapacity the capacity of the buffer. Ignored if buf is
644
+ * NULL.
645
+ * @return the actual length of the index-th ID, not including
646
+ * zero-termination. This may be greater than bufCapacity.
647
+ * @deprecated ICU 2.8 Use utrans_openIDs() instead, see utrans.h
648
+ */
649
+ U_DEPRECATED int32_t U_EXPORT2
650
+ utrans_getAvailableID(int32_t index,
651
+ char* buf,
652
+ int32_t bufCapacity);
653
+
654
+ #endif /* U_HIDE_DEPRECATED_API */
655
+
656
+ #endif /* #if !UCONFIG_NO_TRANSLITERATION */
657
+
658
+ #endif