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,155 @@
1
+ /*
2
+ ******************************************************************************
3
+ * Copyright (C) 1997-2010, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ ******************************************************************************
6
+ * Date Name Description
7
+ * 06/23/00 aliu Creation.
8
+ ******************************************************************************
9
+ */
10
+
11
+ #ifndef __UREP_H
12
+ #define __UREP_H
13
+
14
+ #include "unicode/utypes.h"
15
+
16
+ U_CDECL_BEGIN
17
+
18
+ /********************************************************************
19
+ * General Notes
20
+ ********************************************************************
21
+ * TODO
22
+ * Add usage scenario
23
+ * Add test code
24
+ * Talk about pinning
25
+ * Talk about "can truncate result if out of memory"
26
+ */
27
+
28
+ /********************************************************************
29
+ * Data Structures
30
+ ********************************************************************/
31
+ /**
32
+ * \file
33
+ * \brief C API: Callbacks for UReplaceable
34
+ */
35
+ /**
36
+ * An opaque replaceable text object. This will be manipulated only
37
+ * through the caller-supplied UReplaceableFunctor struct. Related
38
+ * to the C++ class Replaceable.
39
+ * This is currently only used in the Transliterator C API, see utrans.h .
40
+ * @stable ICU 2.0
41
+ */
42
+ typedef void* UReplaceable;
43
+
44
+ /**
45
+ * A set of function pointers that transliterators use to manipulate a
46
+ * UReplaceable. The caller should supply the required functions to
47
+ * manipulate their text appropriately. Related to the C++ class
48
+ * Replaceable.
49
+ * @stable ICU 2.0
50
+ */
51
+ typedef struct UReplaceableCallbacks {
52
+
53
+ /**
54
+ * Function pointer that returns the number of UChar code units in
55
+ * this text.
56
+ *
57
+ * @param rep A pointer to "this" UReplaceable object.
58
+ * @return The length of the text.
59
+ * @stable ICU 2.0
60
+ */
61
+ int32_t (*length)(const UReplaceable* rep);
62
+
63
+ /**
64
+ * Function pointer that returns a UChar code units at the given
65
+ * offset into this text; 0 <= offset < n, where n is the value
66
+ * returned by (*length)(rep). See unistr.h for a description of
67
+ * charAt() vs. char32At().
68
+ *
69
+ * @param rep A pointer to "this" UReplaceable object.
70
+ * @param offset The index at which to fetch the UChar (code unit).
71
+ * @return The UChar (code unit) at offset, or U+FFFF if the offset is out of bounds.
72
+ * @stable ICU 2.0
73
+ */
74
+ UChar (*charAt)(const UReplaceable* rep,
75
+ int32_t offset);
76
+
77
+ /**
78
+ * Function pointer that returns a UChar32 code point at the given
79
+ * offset into this text. See unistr.h for a description of
80
+ * charAt() vs. char32At().
81
+ *
82
+ * @param rep A pointer to "this" UReplaceable object.
83
+ * @param offset The index at which to fetch the UChar32 (code point).
84
+ * @return The UChar32 (code point) at offset, or U+FFFF if the offset is out of bounds.
85
+ * @stable ICU 2.0
86
+ */
87
+ UChar32 (*char32At)(const UReplaceable* rep,
88
+ int32_t offset);
89
+
90
+ /**
91
+ * Function pointer that replaces text between start and limit in
92
+ * this text with the given text. Attributes (out of band info)
93
+ * should be retained.
94
+ *
95
+ * @param rep A pointer to "this" UReplaceable object.
96
+ * @param start the starting index of the text to be replaced,
97
+ * inclusive.
98
+ * @param limit the ending index of the text to be replaced,
99
+ * exclusive.
100
+ * @param text the new text to replace the UChars from
101
+ * start..limit-1.
102
+ * @param textLength the number of UChars at text, or -1 if text
103
+ * is null-terminated.
104
+ * @stable ICU 2.0
105
+ */
106
+ void (*replace)(UReplaceable* rep,
107
+ int32_t start,
108
+ int32_t limit,
109
+ const UChar* text,
110
+ int32_t textLength);
111
+
112
+ /**
113
+ * Function pointer that copies the characters in the range
114
+ * [<tt>start</tt>, <tt>limit</tt>) into the array <tt>dst</tt>.
115
+ *
116
+ * @param rep A pointer to "this" UReplaceable object.
117
+ * @param start offset of first character which will be copied
118
+ * into the array
119
+ * @param limit offset immediately following the last character to
120
+ * be copied
121
+ * @param dst array in which to copy characters. The length of
122
+ * <tt>dst</tt> must be at least <tt>(limit - start)</tt>.
123
+ * @stable ICU 2.1
124
+ */
125
+ void (*extract)(UReplaceable* rep,
126
+ int32_t start,
127
+ int32_t limit,
128
+ UChar* dst);
129
+
130
+ /**
131
+ * Function pointer that copies text between start and limit in
132
+ * this text to another index in the text. Attributes (out of
133
+ * band info) should be retained. After this call, there will be
134
+ * (at least) two copies of the characters originally located at
135
+ * start..limit-1.
136
+ *
137
+ * @param rep A pointer to "this" UReplaceable object.
138
+ * @param start the starting index of the text to be copied,
139
+ * inclusive.
140
+ * @param limit the ending index of the text to be copied,
141
+ * exclusive.
142
+ * @param dest the index at which the copy of the UChars should be
143
+ * inserted.
144
+ * @stable ICU 2.0
145
+ */
146
+ void (*copy)(UReplaceable* rep,
147
+ int32_t start,
148
+ int32_t limit,
149
+ int32_t dest);
150
+
151
+ } UReplaceableCallbacks;
152
+
153
+ U_CDECL_END
154
+
155
+ #endif
@@ -0,0 +1,887 @@
1
+ /*
2
+ **********************************************************************
3
+ * Copyright (C) 1997-2012,2014, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ **********************************************************************
6
+ *
7
+ * File URES.H (formerly CRESBUND.H)
8
+ *
9
+ * Modification History:
10
+ *
11
+ * Date Name Description
12
+ * 04/01/97 aliu Creation.
13
+ * 02/22/99 damiba overhaul.
14
+ * 04/04/99 helena Fixed internal header inclusion.
15
+ * 04/15/99 Madhu Updated Javadoc
16
+ * 06/14/99 stephen Removed functions taking a filename suffix.
17
+ * 07/20/99 stephen Language-independent ypedef to void*
18
+ * 11/09/99 weiv Added ures_getLocale()
19
+ * 06/24/02 weiv Added support for resource sharing
20
+ ******************************************************************************
21
+ */
22
+
23
+ #ifndef URES_H
24
+ #define URES_H
25
+
26
+ #include "unicode/utypes.h"
27
+ #include "unicode/uloc.h"
28
+ #include "unicode/localpointer.h"
29
+
30
+ /**
31
+ * \file
32
+ * \brief C API: Resource Bundle
33
+ *
34
+ * <h2>C API: Resource Bundle</h2>
35
+ *
36
+ * C API representing a collection of resource information pertaining to a given
37
+ * locale. A resource bundle provides a way of accessing locale- specific information in
38
+ * a data file. You create a resource bundle that manages the resources for a given
39
+ * locale and then ask it for individual resources.
40
+ * <P>
41
+ * Resource bundles in ICU4C are currently defined using text files which conform to the following
42
+ * <a href="http://source.icu-project.org/repos/icu/icuhtml/trunk/design/bnf_rb.txt">BNF definition</a>.
43
+ * More on resource bundle concepts and syntax can be found in the
44
+ * <a href="http://icu-project.org/userguide/ResourceManagement.html">Users Guide</a>.
45
+ * <P>
46
+ */
47
+
48
+ /**
49
+ * UResourceBundle is an opaque type for handles for resource bundles in C APIs.
50
+ * @stable ICU 2.0
51
+ */
52
+ struct UResourceBundle;
53
+
54
+ /**
55
+ * @stable ICU 2.0
56
+ */
57
+ typedef struct UResourceBundle UResourceBundle;
58
+
59
+ /**
60
+ * Numeric constants for types of resource items.
61
+ * @see ures_getType
62
+ * @stable ICU 2.0
63
+ */
64
+ typedef enum {
65
+ /** Resource type constant for "no resource". @stable ICU 2.6 */
66
+ URES_NONE=-1,
67
+
68
+ /** Resource type constant for 16-bit Unicode strings. @stable ICU 2.6 */
69
+ URES_STRING=0,
70
+
71
+ /** Resource type constant for binary data. @stable ICU 2.6 */
72
+ URES_BINARY=1,
73
+
74
+ /** Resource type constant for tables of key-value pairs. @stable ICU 2.6 */
75
+ URES_TABLE=2,
76
+
77
+ /**
78
+ * Resource type constant for aliases;
79
+ * internally stores a string which identifies the actual resource
80
+ * storing the data (can be in a different resource bundle).
81
+ * Resolved internally before delivering the actual resource through the API.
82
+ * @stable ICU 2.6
83
+ */
84
+ URES_ALIAS=3,
85
+
86
+ /**
87
+ * Resource type constant for a single 28-bit integer, interpreted as
88
+ * signed or unsigned by the ures_getInt() or ures_getUInt() function.
89
+ * @see ures_getInt
90
+ * @see ures_getUInt
91
+ * @stable ICU 2.6
92
+ */
93
+ URES_INT=7,
94
+
95
+ /** Resource type constant for arrays of resources. @stable ICU 2.6 */
96
+ URES_ARRAY=8,
97
+
98
+ /**
99
+ * Resource type constant for vectors of 32-bit integers.
100
+ * @see ures_getIntVector
101
+ * @stable ICU 2.6
102
+ */
103
+ URES_INT_VECTOR = 14,
104
+ #ifndef U_HIDE_DEPRECATED_API
105
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
106
+ RES_NONE=URES_NONE,
107
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
108
+ RES_STRING=URES_STRING,
109
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
110
+ RES_BINARY=URES_BINARY,
111
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
112
+ RES_TABLE=URES_TABLE,
113
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
114
+ RES_ALIAS=URES_ALIAS,
115
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
116
+ RES_INT=URES_INT,
117
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
118
+ RES_ARRAY=URES_ARRAY,
119
+ /** @deprecated ICU 2.6 Use the URES_ constant instead. */
120
+ RES_INT_VECTOR=URES_INT_VECTOR,
121
+ /** @deprecated ICU 2.6 Not used. */
122
+ RES_RESERVED=15,
123
+ #endif /* U_HIDE_DEPRECATED_API */
124
+
125
+ URES_LIMIT = 16
126
+ } UResType;
127
+
128
+ /*
129
+ * Functions to create and destroy resource bundles.
130
+ */
131
+
132
+ /**
133
+ * Opens a UResourceBundle, from which users can extract strings by using
134
+ * their corresponding keys.
135
+ * Note that the caller is responsible of calling <TT>ures_close</TT> on each succesfully
136
+ * opened resource bundle.
137
+ * @param packageName The packageName and locale together point to an ICU udata object,
138
+ * as defined by <code> udata_open( packageName, "res", locale, err) </code>
139
+ * or equivalent. Typically, packageName will refer to a (.dat) file, or to
140
+ * a package registered with udata_setAppData(). Using a full file or directory
141
+ * pathname for packageName is deprecated. If NULL, ICU data will be used.
142
+ * @param locale specifies the locale for which we want to open the resource
143
+ * if NULL, the default locale will be used. If strlen(locale) == 0
144
+ * root locale will be used.
145
+ *
146
+ * @param status fills in the outgoing error code.
147
+ * The UErrorCode err parameter is used to return status information to the user. To
148
+ * check whether the construction succeeded or not, you should check the value of
149
+ * U_SUCCESS(err). If you wish more detailed information, you can check for
150
+ * informational status results which still indicate success. U_USING_FALLBACK_WARNING
151
+ * indicates that a fall back locale was used. For example, 'de_CH' was requested,
152
+ * but nothing was found there, so 'de' was used. U_USING_DEFAULT_WARNING indicates that
153
+ * the default locale data or root locale data was used; neither the requested locale
154
+ * nor any of its fall back locales could be found. Please see the users guide for more
155
+ * information on this topic.
156
+ * @return a newly allocated resource bundle.
157
+ * @see ures_close
158
+ * @stable ICU 2.0
159
+ */
160
+ U_STABLE UResourceBundle* U_EXPORT2
161
+ ures_open(const char* packageName,
162
+ const char* locale,
163
+ UErrorCode* status);
164
+
165
+
166
+ /** This function does not care what kind of localeID is passed in. It simply opens a bundle with
167
+ * that name. Fallback mechanism is disabled for the new bundle. If the requested bundle contains
168
+ * an %%ALIAS directive, the results are undefined.
169
+ * @param packageName The packageName and locale together point to an ICU udata object,
170
+ * as defined by <code> udata_open( packageName, "res", locale, err) </code>
171
+ * or equivalent. Typically, packageName will refer to a (.dat) file, or to
172
+ * a package registered with udata_setAppData(). Using a full file or directory
173
+ * pathname for packageName is deprecated. If NULL, ICU data will be used.
174
+ * @param locale specifies the locale for which we want to open the resource
175
+ * if NULL, the default locale will be used. If strlen(locale) == 0
176
+ * root locale will be used.
177
+ *
178
+ * @param status fills in the outgoing error code. Either U_ZERO_ERROR or U_MISSING_RESOURCE_ERROR
179
+ * @return a newly allocated resource bundle or NULL if it doesn't exist.
180
+ * @see ures_close
181
+ * @stable ICU 2.0
182
+ */
183
+ U_STABLE UResourceBundle* U_EXPORT2
184
+ ures_openDirect(const char* packageName,
185
+ const char* locale,
186
+ UErrorCode* status);
187
+
188
+ /**
189
+ * Same as ures_open() but takes a const UChar *path.
190
+ * This path will be converted to char * using the default converter,
191
+ * then ures_open() is called.
192
+ *
193
+ * @param packageName The packageName and locale together point to an ICU udata object,
194
+ * as defined by <code> udata_open( packageName, "res", locale, err) </code>
195
+ * or equivalent. Typically, packageName will refer to a (.dat) file, or to
196
+ * a package registered with udata_setAppData(). Using a full file or directory
197
+ * pathname for packageName is deprecated. If NULL, ICU data will be used.
198
+ * @param locale specifies the locale for which we want to open the resource
199
+ * if NULL, the default locale will be used. If strlen(locale) == 0
200
+ * root locale will be used.
201
+ * @param status fills in the outgoing error code.
202
+ * @return a newly allocated resource bundle.
203
+ * @see ures_open
204
+ * @stable ICU 2.0
205
+ */
206
+ U_STABLE UResourceBundle* U_EXPORT2
207
+ ures_openU(const UChar* packageName,
208
+ const char* locale,
209
+ UErrorCode* status);
210
+
211
+ #ifndef U_HIDE_DEPRECATED_API
212
+ /**
213
+ * Returns the number of strings/arrays in resource bundles.
214
+ * Better to use ures_getSize, as this function will be deprecated.
215
+ *
216
+ *@param resourceBundle resource bundle containing the desired strings
217
+ *@param resourceKey key tagging the resource
218
+ *@param err fills in the outgoing error code
219
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
220
+ * could be a non-failing error
221
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_FALLBACK_WARNING </TT>
222
+ *@return: for <STRONG>Arrays</STRONG>: returns the number of resources in the array
223
+ * <STRONG>Tables</STRONG>: returns the number of resources in the table
224
+ * <STRONG>single string</STRONG>: returns 1
225
+ *@see ures_getSize
226
+ * @deprecated ICU 2.8 User ures_getSize instead
227
+ */
228
+ U_DEPRECATED int32_t U_EXPORT2
229
+ ures_countArrayItems(const UResourceBundle* resourceBundle,
230
+ const char* resourceKey,
231
+ UErrorCode* err);
232
+ #endif /* U_HIDE_DEPRECATED_API */
233
+
234
+ /**
235
+ * Close a resource bundle, all pointers returned from the various ures_getXXX calls
236
+ * on this particular bundle should be considered invalid henceforth.
237
+ *
238
+ * @param resourceBundle a pointer to a resourceBundle struct. Can be NULL.
239
+ * @see ures_open
240
+ * @stable ICU 2.0
241
+ */
242
+ U_STABLE void U_EXPORT2
243
+ ures_close(UResourceBundle* resourceBundle);
244
+
245
+ #if U_SHOW_CPLUSPLUS_API
246
+
247
+ U_NAMESPACE_BEGIN
248
+
249
+ /**
250
+ * \class LocalUResourceBundlePointer
251
+ * "Smart pointer" class, closes a UResourceBundle via ures_close().
252
+ * For most methods see the LocalPointerBase base class.
253
+ *
254
+ * @see LocalPointerBase
255
+ * @see LocalPointer
256
+ * @stable ICU 4.4
257
+ */
258
+ U_DEFINE_LOCAL_OPEN_POINTER(LocalUResourceBundlePointer, UResourceBundle, ures_close);
259
+
260
+ U_NAMESPACE_END
261
+
262
+ #endif
263
+
264
+ #ifndef U_HIDE_DEPRECATED_API
265
+ /**
266
+ * Return the version number associated with this ResourceBundle as a string. Please
267
+ * use ures_getVersion as this function is going to be deprecated.
268
+ *
269
+ * @param resourceBundle The resource bundle for which the version is checked.
270
+ * @return A version number string as specified in the resource bundle or its parent.
271
+ * The caller does not own this string.
272
+ * @see ures_getVersion
273
+ * @deprecated ICU 2.8 Use ures_getVersion instead.
274
+ */
275
+ U_DEPRECATED const char* U_EXPORT2
276
+ ures_getVersionNumber(const UResourceBundle* resourceBundle);
277
+ #endif /* U_HIDE_DEPRECATED_API */
278
+
279
+ /**
280
+ * Return the version number associated with this ResourceBundle as an
281
+ * UVersionInfo array.
282
+ *
283
+ * @param resB The resource bundle for which the version is checked.
284
+ * @param versionInfo A UVersionInfo array that is filled with the version number
285
+ * as specified in the resource bundle or its parent.
286
+ * @stable ICU 2.0
287
+ */
288
+ U_STABLE void U_EXPORT2
289
+ ures_getVersion(const UResourceBundle* resB,
290
+ UVersionInfo versionInfo);
291
+
292
+ #ifndef U_HIDE_DEPRECATED_API
293
+ /**
294
+ * Return the name of the Locale associated with this ResourceBundle. This API allows
295
+ * you to query for the real locale of the resource. For example, if you requested
296
+ * "en_US_CALIFORNIA" and only "en_US" bundle exists, "en_US" will be returned.
297
+ * For subresources, the locale where this resource comes from will be returned.
298
+ * If fallback has occured, getLocale will reflect this.
299
+ *
300
+ * @param resourceBundle resource bundle in question
301
+ * @param status just for catching illegal arguments
302
+ * @return A Locale name
303
+ * @deprecated ICU 2.8 Use ures_getLocaleByType instead.
304
+ */
305
+ U_DEPRECATED const char* U_EXPORT2
306
+ ures_getLocale(const UResourceBundle* resourceBundle,
307
+ UErrorCode* status);
308
+ #endif /* U_HIDE_DEPRECATED_API */
309
+
310
+ /**
311
+ * Return the name of the Locale associated with this ResourceBundle.
312
+ * You can choose between requested, valid and real locale.
313
+ *
314
+ * @param resourceBundle resource bundle in question
315
+ * @param type You can choose between requested, valid and actual
316
+ * locale. For description see the definition of
317
+ * ULocDataLocaleType in uloc.h
318
+ * @param status just for catching illegal arguments
319
+ * @return A Locale name
320
+ * @stable ICU 2.8
321
+ */
322
+ U_STABLE const char* U_EXPORT2
323
+ ures_getLocaleByType(const UResourceBundle* resourceBundle,
324
+ ULocDataLocaleType type,
325
+ UErrorCode* status);
326
+
327
+
328
+ #ifndef U_HIDE_INTERNAL_API
329
+ /**
330
+ * Same as ures_open() but uses the fill-in parameter instead of allocating
331
+ * a bundle, if r!=NULL.
332
+ * TODO need to revisit usefulness of this function
333
+ * and usage model for fillIn parameters without knowing sizeof(UResourceBundle)
334
+ * @param r The resourcebundle to open
335
+ * @param packageName The packageName and locale together point to an ICU udata object,
336
+ * as defined by <code> udata_open( packageName, "res", locale, err) </code>
337
+ * or equivalent. Typically, packageName will refer to a (.dat) file, or to
338
+ * a package registered with udata_setAppData(). Using a full file or directory
339
+ * pathname for packageName is deprecated. If NULL, ICU data will be used.
340
+ * @param localeID specifies the locale for which we want to open the resource
341
+ * @param status The error code
342
+ * @return a newly allocated resource bundle or NULL if it doesn't exist.
343
+ * @internal
344
+ */
345
+ U_INTERNAL void U_EXPORT2
346
+ ures_openFillIn(UResourceBundle *r,
347
+ const char* packageName,
348
+ const char* localeID,
349
+ UErrorCode* status);
350
+ #endif /* U_HIDE_INTERNAL_API */
351
+
352
+ /**
353
+ * Returns a string from a string resource type
354
+ *
355
+ * @param resourceBundle a string resource
356
+ * @param len fills in the length of resulting string
357
+ * @param status fills in the outgoing error code
358
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
359
+ * Always check the value of status. Don't count on returning NULL.
360
+ * could be a non-failing error
361
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
362
+ * @return a pointer to a zero-terminated UChar array which lives in a memory mapped/DLL file.
363
+ * @see ures_getBinary
364
+ * @see ures_getIntVector
365
+ * @see ures_getInt
366
+ * @see ures_getUInt
367
+ * @stable ICU 2.0
368
+ */
369
+ U_STABLE const UChar* U_EXPORT2
370
+ ures_getString(const UResourceBundle* resourceBundle,
371
+ int32_t* len,
372
+ UErrorCode* status);
373
+
374
+ /**
375
+ * Returns a UTF-8 string from a string resource.
376
+ * The UTF-8 string may be returnable directly as a pointer, or
377
+ * it may need to be copied, or transformed from UTF-16 using u_strToUTF8()
378
+ * or equivalent.
379
+ *
380
+ * If forceCopy==TRUE, then the string is always written to the dest buffer
381
+ * and dest is returned.
382
+ *
383
+ * If forceCopy==FALSE, then the string is returned as a pointer if possible,
384
+ * without needing a dest buffer (it can be NULL). If the string needs to be
385
+ * copied or transformed, then it may be placed into dest at an arbitrary offset.
386
+ *
387
+ * If the string is to be written to dest, then U_BUFFER_OVERFLOW_ERROR and
388
+ * U_STRING_NOT_TERMINATED_WARNING are set if appropriate, as usual.
389
+ *
390
+ * If the string is transformed from UTF-16, then a conversion error may occur
391
+ * if an unpaired surrogate is encountered. If the function is successful, then
392
+ * the output UTF-8 string is always well-formed.
393
+ *
394
+ * @param resB Resource bundle.
395
+ * @param dest Destination buffer. Can be NULL only if capacity=*length==0.
396
+ * @param length Input: Capacity of destination buffer.
397
+ * Output: Actual length of the UTF-8 string, not counting the
398
+ * terminating NUL, even in case of U_BUFFER_OVERFLOW_ERROR.
399
+ * Can be NULL, meaning capacity=0 and the string length is not
400
+ * returned to the caller.
401
+ * @param forceCopy If TRUE, then the output string will always be written to
402
+ * dest, with U_BUFFER_OVERFLOW_ERROR and
403
+ * U_STRING_NOT_TERMINATED_WARNING set if appropriate.
404
+ * If FALSE, then the dest buffer may or may not contain a
405
+ * copy of the string. dest may or may not be modified.
406
+ * If a copy needs to be written, then the UErrorCode parameter
407
+ * indicates overflow etc. as usual.
408
+ * @param status Pointer to a standard ICU error code. Its input value must
409
+ * pass the U_SUCCESS() test, or else the function returns
410
+ * immediately. Check for U_FAILURE() on output or use with
411
+ * function chaining. (See User Guide for details.)
412
+ * @return The pointer to the UTF-8 string. It may be dest, or at some offset
413
+ * from dest (only if !forceCopy), or in unrelated memory.
414
+ * Always NUL-terminated unless the string was written to dest and
415
+ * length==capacity (in which case U_STRING_NOT_TERMINATED_WARNING is set).
416
+ *
417
+ * @see ures_getString
418
+ * @see u_strToUTF8
419
+ * @stable ICU 3.6
420
+ */
421
+ U_STABLE const char * U_EXPORT2
422
+ ures_getUTF8String(const UResourceBundle *resB,
423
+ char *dest, int32_t *length,
424
+ UBool forceCopy,
425
+ UErrorCode *status);
426
+
427
+ /**
428
+ * Returns a binary data from a binary resource.
429
+ *
430
+ * @param resourceBundle a string resource
431
+ * @param len fills in the length of resulting byte chunk
432
+ * @param status fills in the outgoing error code
433
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
434
+ * Always check the value of status. Don't count on returning NULL.
435
+ * could be a non-failing error
436
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
437
+ * @return a pointer to a chunk of unsigned bytes which live in a memory mapped/DLL file.
438
+ * @see ures_getString
439
+ * @see ures_getIntVector
440
+ * @see ures_getInt
441
+ * @see ures_getUInt
442
+ * @stable ICU 2.0
443
+ */
444
+ U_STABLE const uint8_t* U_EXPORT2
445
+ ures_getBinary(const UResourceBundle* resourceBundle,
446
+ int32_t* len,
447
+ UErrorCode* status);
448
+
449
+ /**
450
+ * Returns a 32 bit integer array from a resource.
451
+ *
452
+ * @param resourceBundle an int vector resource
453
+ * @param len fills in the length of resulting byte chunk
454
+ * @param status fills in the outgoing error code
455
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
456
+ * Always check the value of status. Don't count on returning NULL.
457
+ * could be a non-failing error
458
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
459
+ * @return a pointer to a chunk of integers which live in a memory mapped/DLL file.
460
+ * @see ures_getBinary
461
+ * @see ures_getString
462
+ * @see ures_getInt
463
+ * @see ures_getUInt
464
+ * @stable ICU 2.0
465
+ */
466
+ U_STABLE const int32_t* U_EXPORT2
467
+ ures_getIntVector(const UResourceBundle* resourceBundle,
468
+ int32_t* len,
469
+ UErrorCode* status);
470
+
471
+ /**
472
+ * Returns an unsigned integer from a resource.
473
+ * This integer is originally 28 bits.
474
+ *
475
+ * @param resourceBundle a string resource
476
+ * @param status fills in the outgoing error code
477
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
478
+ * could be a non-failing error
479
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
480
+ * @return an integer value
481
+ * @see ures_getInt
482
+ * @see ures_getIntVector
483
+ * @see ures_getBinary
484
+ * @see ures_getString
485
+ * @stable ICU 2.0
486
+ */
487
+ U_STABLE uint32_t U_EXPORT2
488
+ ures_getUInt(const UResourceBundle* resourceBundle,
489
+ UErrorCode *status);
490
+
491
+ /**
492
+ * Returns a signed integer from a resource.
493
+ * This integer is originally 28 bit and the sign gets propagated.
494
+ *
495
+ * @param resourceBundle a string resource
496
+ * @param status fills in the outgoing error code
497
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
498
+ * could be a non-failing error
499
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
500
+ * @return an integer value
501
+ * @see ures_getUInt
502
+ * @see ures_getIntVector
503
+ * @see ures_getBinary
504
+ * @see ures_getString
505
+ * @stable ICU 2.0
506
+ */
507
+ U_STABLE int32_t U_EXPORT2
508
+ ures_getInt(const UResourceBundle* resourceBundle,
509
+ UErrorCode *status);
510
+
511
+ /**
512
+ * Returns the size of a resource. Size for scalar types is always 1,
513
+ * and for vector/table types is the number of child resources.
514
+ * @warning Integer array is treated as a scalar type. There are no
515
+ * APIs to access individual members of an integer array. It
516
+ * is always returned as a whole.
517
+ * @param resourceBundle a resource
518
+ * @return number of resources in a given resource.
519
+ * @stable ICU 2.0
520
+ */
521
+ U_STABLE int32_t U_EXPORT2
522
+ ures_getSize(const UResourceBundle *resourceBundle);
523
+
524
+ /**
525
+ * Returns the type of a resource. Available types are defined in enum UResType
526
+ *
527
+ * @param resourceBundle a resource
528
+ * @return type of the given resource.
529
+ * @see UResType
530
+ * @stable ICU 2.0
531
+ */
532
+ U_STABLE UResType U_EXPORT2
533
+ ures_getType(const UResourceBundle *resourceBundle);
534
+
535
+ /**
536
+ * Returns the key associated with a given resource. Not all the resources have a key - only
537
+ * those that are members of a table.
538
+ *
539
+ * @param resourceBundle a resource
540
+ * @return a key associated to this resource, or NULL if it doesn't have a key
541
+ * @stable ICU 2.0
542
+ */
543
+ U_STABLE const char * U_EXPORT2
544
+ ures_getKey(const UResourceBundle *resourceBundle);
545
+
546
+ /* ITERATION API
547
+ This API provides means for iterating through a resource
548
+ */
549
+
550
+ /**
551
+ * Resets the internal context of a resource so that iteration starts from the first element.
552
+ *
553
+ * @param resourceBundle a resource
554
+ * @stable ICU 2.0
555
+ */
556
+ U_STABLE void U_EXPORT2
557
+ ures_resetIterator(UResourceBundle *resourceBundle);
558
+
559
+ /**
560
+ * Checks whether the given resource has another element to iterate over.
561
+ *
562
+ * @param resourceBundle a resource
563
+ * @return TRUE if there are more elements, FALSE if there is no more elements
564
+ * @stable ICU 2.0
565
+ */
566
+ U_STABLE UBool U_EXPORT2
567
+ ures_hasNext(const UResourceBundle *resourceBundle);
568
+
569
+ /**
570
+ * Returns the next resource in a given resource or NULL if there are no more resources
571
+ * to iterate over. Features a fill-in parameter.
572
+ *
573
+ * @param resourceBundle a resource
574
+ * @param fillIn if NULL a new UResourceBundle struct is allocated and must be closed by the caller.
575
+ * Alternatively, you can supply a struct to be filled by this function.
576
+ * @param status fills in the outgoing error code. You may still get a non NULL result even if an
577
+ * error occured. Check status instead.
578
+ * @return a pointer to a UResourceBundle struct. If fill in param was NULL, caller must close it
579
+ * @stable ICU 2.0
580
+ */
581
+ U_STABLE UResourceBundle* U_EXPORT2
582
+ ures_getNextResource(UResourceBundle *resourceBundle,
583
+ UResourceBundle *fillIn,
584
+ UErrorCode *status);
585
+
586
+ /**
587
+ * Returns the next string in a given resource or NULL if there are no more resources
588
+ * to iterate over.
589
+ *
590
+ * @param resourceBundle a resource
591
+ * @param len fill in length of the string
592
+ * @param key fill in for key associated with this string. NULL if no key
593
+ * @param status fills in the outgoing error code. If an error occured, we may return NULL, but don't
594
+ * count on it. Check status instead!
595
+ * @return a pointer to a zero-terminated UChar array which lives in a memory mapped/DLL file.
596
+ * @stable ICU 2.0
597
+ */
598
+ U_STABLE const UChar* U_EXPORT2
599
+ ures_getNextString(UResourceBundle *resourceBundle,
600
+ int32_t* len,
601
+ const char ** key,
602
+ UErrorCode *status);
603
+
604
+ /**
605
+ * Returns the resource in a given resource at the specified index. Features a fill-in parameter.
606
+ *
607
+ * @param resourceBundle the resource bundle from which to get a sub-resource
608
+ * @param indexR an index to the wanted resource.
609
+ * @param fillIn if NULL a new UResourceBundle struct is allocated and must be closed by the caller.
610
+ * Alternatively, you can supply a struct to be filled by this function.
611
+ * @param status fills in the outgoing error code. Don't count on NULL being returned if an error has
612
+ * occured. Check status instead.
613
+ * @return a pointer to a UResourceBundle struct. If fill in param was NULL, caller must close it
614
+ * @stable ICU 2.0
615
+ */
616
+ U_STABLE UResourceBundle* U_EXPORT2
617
+ ures_getByIndex(const UResourceBundle *resourceBundle,
618
+ int32_t indexR,
619
+ UResourceBundle *fillIn,
620
+ UErrorCode *status);
621
+
622
+ /**
623
+ * Returns the string in a given resource at the specified index.
624
+ *
625
+ * @param resourceBundle a resource
626
+ * @param indexS an index to the wanted string.
627
+ * @param len fill in length of the string
628
+ * @param status fills in the outgoing error code. If an error occured, we may return NULL, but don't
629
+ * count on it. Check status instead!
630
+ * @return a pointer to a zero-terminated UChar array which lives in a memory mapped/DLL file.
631
+ * @stable ICU 2.0
632
+ */
633
+ U_STABLE const UChar* U_EXPORT2
634
+ ures_getStringByIndex(const UResourceBundle *resourceBundle,
635
+ int32_t indexS,
636
+ int32_t* len,
637
+ UErrorCode *status);
638
+
639
+ /**
640
+ * Returns a UTF-8 string from a resource at the specified index.
641
+ * The UTF-8 string may be returnable directly as a pointer, or
642
+ * it may need to be copied, or transformed from UTF-16 using u_strToUTF8()
643
+ * or equivalent.
644
+ *
645
+ * If forceCopy==TRUE, then the string is always written to the dest buffer
646
+ * and dest is returned.
647
+ *
648
+ * If forceCopy==FALSE, then the string is returned as a pointer if possible,
649
+ * without needing a dest buffer (it can be NULL). If the string needs to be
650
+ * copied or transformed, then it may be placed into dest at an arbitrary offset.
651
+ *
652
+ * If the string is to be written to dest, then U_BUFFER_OVERFLOW_ERROR and
653
+ * U_STRING_NOT_TERMINATED_WARNING are set if appropriate, as usual.
654
+ *
655
+ * If the string is transformed from UTF-16, then a conversion error may occur
656
+ * if an unpaired surrogate is encountered. If the function is successful, then
657
+ * the output UTF-8 string is always well-formed.
658
+ *
659
+ * @param resB Resource bundle.
660
+ * @param stringIndex An index to the wanted string.
661
+ * @param dest Destination buffer. Can be NULL only if capacity=*length==0.
662
+ * @param pLength Input: Capacity of destination buffer.
663
+ * Output: Actual length of the UTF-8 string, not counting the
664
+ * terminating NUL, even in case of U_BUFFER_OVERFLOW_ERROR.
665
+ * Can be NULL, meaning capacity=0 and the string length is not
666
+ * returned to the caller.
667
+ * @param forceCopy If TRUE, then the output string will always be written to
668
+ * dest, with U_BUFFER_OVERFLOW_ERROR and
669
+ * U_STRING_NOT_TERMINATED_WARNING set if appropriate.
670
+ * If FALSE, then the dest buffer may or may not contain a
671
+ * copy of the string. dest may or may not be modified.
672
+ * If a copy needs to be written, then the UErrorCode parameter
673
+ * indicates overflow etc. as usual.
674
+ * @param status Pointer to a standard ICU error code. Its input value must
675
+ * pass the U_SUCCESS() test, or else the function returns
676
+ * immediately. Check for U_FAILURE() on output or use with
677
+ * function chaining. (See User Guide for details.)
678
+ * @return The pointer to the UTF-8 string. It may be dest, or at some offset
679
+ * from dest (only if !forceCopy), or in unrelated memory.
680
+ * Always NUL-terminated unless the string was written to dest and
681
+ * length==capacity (in which case U_STRING_NOT_TERMINATED_WARNING is set).
682
+ *
683
+ * @see ures_getStringByIndex
684
+ * @see u_strToUTF8
685
+ * @stable ICU 3.6
686
+ */
687
+ U_STABLE const char * U_EXPORT2
688
+ ures_getUTF8StringByIndex(const UResourceBundle *resB,
689
+ int32_t stringIndex,
690
+ char *dest, int32_t *pLength,
691
+ UBool forceCopy,
692
+ UErrorCode *status);
693
+
694
+ /**
695
+ * Returns a resource in a given resource that has a given key. This procedure works only with table
696
+ * resources. Features a fill-in parameter.
697
+ *
698
+ * @param resourceBundle a resource
699
+ * @param key a key associated with the wanted resource
700
+ * @param fillIn if NULL a new UResourceBundle struct is allocated and must be closed by the caller.
701
+ * Alternatively, you can supply a struct to be filled by this function.
702
+ * @param status fills in the outgoing error code.
703
+ * @return a pointer to a UResourceBundle struct. If fill in param was NULL, caller must close it
704
+ * @stable ICU 2.0
705
+ */
706
+ U_STABLE UResourceBundle* U_EXPORT2
707
+ ures_getByKey(const UResourceBundle *resourceBundle,
708
+ const char* key,
709
+ UResourceBundle *fillIn,
710
+ UErrorCode *status);
711
+
712
+ /**
713
+ * Returns a string in a given resource that has a given key. This procedure works only with table
714
+ * resources.
715
+ *
716
+ * @param resB a resource
717
+ * @param key a key associated with the wanted string
718
+ * @param len fill in length of the string
719
+ * @param status fills in the outgoing error code. If an error occured, we may return NULL, but don't
720
+ * count on it. Check status instead!
721
+ * @return a pointer to a zero-terminated UChar array which lives in a memory mapped/DLL file.
722
+ * @stable ICU 2.0
723
+ */
724
+ U_STABLE const UChar* U_EXPORT2
725
+ ures_getStringByKey(const UResourceBundle *resB,
726
+ const char* key,
727
+ int32_t* len,
728
+ UErrorCode *status);
729
+
730
+ /**
731
+ * Returns a UTF-8 string from a resource and a key.
732
+ * This function works only with table resources.
733
+ *
734
+ * The UTF-8 string may be returnable directly as a pointer, or
735
+ * it may need to be copied, or transformed from UTF-16 using u_strToUTF8()
736
+ * or equivalent.
737
+ *
738
+ * If forceCopy==TRUE, then the string is always written to the dest buffer
739
+ * and dest is returned.
740
+ *
741
+ * If forceCopy==FALSE, then the string is returned as a pointer if possible,
742
+ * without needing a dest buffer (it can be NULL). If the string needs to be
743
+ * copied or transformed, then it may be placed into dest at an arbitrary offset.
744
+ *
745
+ * If the string is to be written to dest, then U_BUFFER_OVERFLOW_ERROR and
746
+ * U_STRING_NOT_TERMINATED_WARNING are set if appropriate, as usual.
747
+ *
748
+ * If the string is transformed from UTF-16, then a conversion error may occur
749
+ * if an unpaired surrogate is encountered. If the function is successful, then
750
+ * the output UTF-8 string is always well-formed.
751
+ *
752
+ * @param resB Resource bundle.
753
+ * @param key A key associated with the wanted resource
754
+ * @param dest Destination buffer. Can be NULL only if capacity=*length==0.
755
+ * @param pLength Input: Capacity of destination buffer.
756
+ * Output: Actual length of the UTF-8 string, not counting the
757
+ * terminating NUL, even in case of U_BUFFER_OVERFLOW_ERROR.
758
+ * Can be NULL, meaning capacity=0 and the string length is not
759
+ * returned to the caller.
760
+ * @param forceCopy If TRUE, then the output string will always be written to
761
+ * dest, with U_BUFFER_OVERFLOW_ERROR and
762
+ * U_STRING_NOT_TERMINATED_WARNING set if appropriate.
763
+ * If FALSE, then the dest buffer may or may not contain a
764
+ * copy of the string. dest may or may not be modified.
765
+ * If a copy needs to be written, then the UErrorCode parameter
766
+ * indicates overflow etc. as usual.
767
+ * @param status Pointer to a standard ICU error code. Its input value must
768
+ * pass the U_SUCCESS() test, or else the function returns
769
+ * immediately. Check for U_FAILURE() on output or use with
770
+ * function chaining. (See User Guide for details.)
771
+ * @return The pointer to the UTF-8 string. It may be dest, or at some offset
772
+ * from dest (only if !forceCopy), or in unrelated memory.
773
+ * Always NUL-terminated unless the string was written to dest and
774
+ * length==capacity (in which case U_STRING_NOT_TERMINATED_WARNING is set).
775
+ *
776
+ * @see ures_getStringByKey
777
+ * @see u_strToUTF8
778
+ * @stable ICU 3.6
779
+ */
780
+ U_STABLE const char * U_EXPORT2
781
+ ures_getUTF8StringByKey(const UResourceBundle *resB,
782
+ const char *key,
783
+ char *dest, int32_t *pLength,
784
+ UBool forceCopy,
785
+ UErrorCode *status);
786
+
787
+ #if U_SHOW_CPLUSPLUS_API
788
+ #include "unicode/unistr.h"
789
+
790
+ U_NAMESPACE_BEGIN
791
+ /**
792
+ * returns a string from a string resource type
793
+ *
794
+ * @param resB a resource
795
+ * @param status: fills in the outgoing error code
796
+ * could be <TT>U_MISSING_RESOURCE_ERROR</TT> if the key is not found
797
+ * could be a non-failing error
798
+ * e.g.: <TT>U_USING_FALLBACK_WARNING</TT>,<TT>U_USING_DEFAULT_WARNING </TT>
799
+ * @return a UnicodeString object. If there is an error, string is bogus
800
+ * @stable ICU 2.0
801
+ */
802
+ inline UnicodeString
803
+ ures_getUnicodeString(const UResourceBundle *resB,
804
+ UErrorCode* status)
805
+ {
806
+ int32_t len = 0;
807
+ const UChar *r = ures_getString(resB, &len, status);
808
+ return UnicodeString(TRUE, r, len);
809
+ }
810
+
811
+ /**
812
+ * Returns the next string in a resource or NULL if there are no more resources
813
+ * to iterate over.
814
+ *
815
+ * @param resB a resource
816
+ * @param key fill in for key associated with this string
817
+ * @param status fills in the outgoing error code
818
+ * @return an UnicodeString object.
819
+ * @stable ICU 2.0
820
+ */
821
+ inline UnicodeString
822
+ ures_getNextUnicodeString(UResourceBundle *resB,
823
+ const char ** key,
824
+ UErrorCode* status)
825
+ {
826
+ int32_t len = 0;
827
+ const UChar* r = ures_getNextString(resB, &len, key, status);
828
+ return UnicodeString(TRUE, r, len);
829
+ }
830
+
831
+ /**
832
+ * Returns the string in a given resource at the specified index.
833
+ *
834
+ * @param resB a resource
835
+ * @param indexS an index to the wanted string.
836
+ * @param status fills in the outgoing error code
837
+ * @return an UnicodeString object. If there is an error, string is bogus
838
+ * @stable ICU 2.0
839
+ */
840
+ inline UnicodeString
841
+ ures_getUnicodeStringByIndex(const UResourceBundle *resB,
842
+ int32_t indexS,
843
+ UErrorCode* status)
844
+ {
845
+ int32_t len = 0;
846
+ const UChar* r = ures_getStringByIndex(resB, indexS, &len, status);
847
+ return UnicodeString(TRUE, r, len);
848
+ }
849
+
850
+ /**
851
+ * Returns a string in a resource that has a given key. This procedure works only with table
852
+ * resources.
853
+ *
854
+ * @param resB a resource
855
+ * @param key a key associated with the wanted string
856
+ * @param status fills in the outgoing error code
857
+ * @return an UnicodeString object. If there is an error, string is bogus
858
+ * @stable ICU 2.0
859
+ */
860
+ inline UnicodeString
861
+ ures_getUnicodeStringByKey(const UResourceBundle *resB,
862
+ const char* key,
863
+ UErrorCode* status)
864
+ {
865
+ int32_t len = 0;
866
+ const UChar* r = ures_getStringByKey(resB, key, &len, status);
867
+ return UnicodeString(TRUE, r, len);
868
+ }
869
+
870
+ U_NAMESPACE_END
871
+
872
+ #endif
873
+
874
+ /**
875
+ * Create a string enumerator, owned by the caller, of all locales located within
876
+ * the specified resource tree.
877
+ * @param packageName name of the tree, such as (NULL) or U_ICUDATA_ALIAS or or "ICUDATA-coll"
878
+ * This call is similar to uloc_getAvailable().
879
+ * @param status error code
880
+ * @stable ICU 3.2
881
+ */
882
+ U_STABLE UEnumeration* U_EXPORT2
883
+ ures_openAvailableLocales(const char *packageName, UErrorCode *status);
884
+
885
+
886
+ #endif /*_URES*/
887
+ /*eof*/