pango 2.2.4-x64-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 (530) hide show
  1. checksums.yaml +7 -0
  2. data/README +33 -0
  3. data/Rakefile +65 -0
  4. data/ext/pango/depend +12 -0
  5. data/ext/pango/extconf.rb +90 -0
  6. data/ext/pango/pango.def +18 -0
  7. data/ext/pango/rbpango.c +318 -0
  8. data/ext/pango/rbpango.h +96 -0
  9. data/ext/pango/rbpangoanalysis.c +218 -0
  10. data/ext/pango/rbpangoattribute.c +499 -0
  11. data/ext/pango/rbpangoattriterator.c +141 -0
  12. data/ext/pango/rbpangoattrlist.c +101 -0
  13. data/ext/pango/rbpangocairo.c +122 -0
  14. data/ext/pango/rbpangocairocontext.c +131 -0
  15. data/ext/pango/rbpangocolor.c +120 -0
  16. data/ext/pango/rbpangocontext.c +309 -0
  17. data/ext/pango/rbpangoconversions.h +111 -0
  18. data/ext/pango/rbpangocoverage.c +106 -0
  19. data/ext/pango/rbpangoengine.c +73 -0
  20. data/ext/pango/rbpangofont.c +110 -0
  21. data/ext/pango/rbpangofontdescription.c +282 -0
  22. data/ext/pango/rbpangofontface.c +73 -0
  23. data/ext/pango/rbpangofontfamily.c +79 -0
  24. data/ext/pango/rbpangofontmap.c +102 -0
  25. data/ext/pango/rbpangofontmetrics.c +85 -0
  26. data/ext/pango/rbpangofontset.c +69 -0
  27. data/ext/pango/rbpangofontsetsimple.c +60 -0
  28. data/ext/pango/rbpangoglyphinfo.c +123 -0
  29. data/ext/pango/rbpangoglyphitem.c +125 -0
  30. data/ext/pango/rbpangoglyphstring.c +151 -0
  31. data/ext/pango/rbpangogravity.c +54 -0
  32. data/ext/pango/rbpangoitem.c +95 -0
  33. data/ext/pango/rbpangolanguage.c +86 -0
  34. data/ext/pango/rbpangolayout.c +572 -0
  35. data/ext/pango/rbpangolayoutiter.c +189 -0
  36. data/ext/pango/rbpangolayoutline.c +239 -0
  37. data/ext/pango/rbpangologattr.c +109 -0
  38. data/ext/pango/rbpangomatrix.c +143 -0
  39. data/ext/pango/rbpangoprivate.h +49 -0
  40. data/ext/pango/rbpangorectangle.c +170 -0
  41. data/ext/pango/rbpangorenderer.c +193 -0
  42. data/ext/pango/rbpangoscript.c +84 -0
  43. data/ext/pango/rbpangoscriptiter.c +92 -0
  44. data/ext/pango/rbpangotabarray.c +128 -0
  45. data/extconf.rb +49 -0
  46. data/lib/2.0/pango.so +0 -0
  47. data/lib/2.1/pango.so +0 -0
  48. data/lib/2.2/pango.so +0 -0
  49. data/lib/pango.rb +79 -0
  50. data/sample/attribute.rb +82 -0
  51. data/sample/break.rb +28 -0
  52. data/sample/gdk_layout.rb +27 -0
  53. data/sample/glyphstring.rb +61 -0
  54. data/sample/item.rb +37 -0
  55. data/sample/label.rb +23 -0
  56. data/sample/layout.rb +102 -0
  57. data/sample/pango_cairo.rb +66 -0
  58. data/sample/parse.rb +33 -0
  59. data/sample/sample.txt +10 -0
  60. data/sample/script.rb +23 -0
  61. data/test/pango-test-utils.rb +9 -0
  62. data/test/run-test.rb +28 -0
  63. data/test/test-analysis.rb +26 -0
  64. data/test/test-attribute.rb +19 -0
  65. data/test/test-color.rb +47 -0
  66. data/test/test-language.rb +7 -0
  67. data/test/test-layout.rb +34 -0
  68. data/test/test-log-attr.rb +26 -0
  69. data/test/test-matrix.rb +26 -0
  70. data/test/test-rectangle.rb +26 -0
  71. data/vendor/local/bin/derb.exe +0 -0
  72. data/vendor/local/bin/genbrk.exe +0 -0
  73. data/vendor/local/bin/genccode.exe +0 -0
  74. data/vendor/local/bin/gencfu.exe +0 -0
  75. data/vendor/local/bin/gencmn.exe +0 -0
  76. data/vendor/local/bin/gencnval.exe +0 -0
  77. data/vendor/local/bin/gendict.exe +0 -0
  78. data/vendor/local/bin/gennorm2.exe +0 -0
  79. data/vendor/local/bin/genrb.exe +0 -0
  80. data/vendor/local/bin/gensprep.exe +0 -0
  81. data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
  82. data/vendor/local/bin/hb-shape.exe +0 -0
  83. data/vendor/local/bin/hb-view.exe +0 -0
  84. data/vendor/local/bin/icu-config +820 -0
  85. data/vendor/local/bin/icuinfo.exe +0 -0
  86. data/vendor/local/bin/icupkg.exe +0 -0
  87. data/vendor/local/bin/libharfbuzz-0.dll +0 -0
  88. data/vendor/local/bin/libpango-1.0-0.dll +0 -0
  89. data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
  90. data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
  91. data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
  92. data/vendor/local/bin/makeconv.exe +0 -0
  93. data/vendor/local/bin/pango-querymodules.exe +0 -0
  94. data/vendor/local/bin/pango-view.exe +0 -0
  95. data/vendor/local/bin/pkgdata.exe +0 -0
  96. data/vendor/local/bin/uconv.exe +0 -0
  97. data/vendor/local/etc/pango/pango.modules +19 -0
  98. data/vendor/local/include/harfbuzz/hb-blob.h +126 -0
  99. data/vendor/local/include/harfbuzz/hb-buffer.h +344 -0
  100. data/vendor/local/include/harfbuzz/hb-common.h +344 -0
  101. data/vendor/local/include/harfbuzz/hb-deprecated.h +51 -0
  102. data/vendor/local/include/harfbuzz/hb-face.h +117 -0
  103. data/vendor/local/include/harfbuzz/hb-font.h +507 -0
  104. data/vendor/local/include/harfbuzz/hb-ft.h +62 -0
  105. data/vendor/local/include/harfbuzz/hb-glib.h +52 -0
  106. data/vendor/local/include/harfbuzz/hb-icu.h +52 -0
  107. data/vendor/local/include/harfbuzz/hb-ot-font.h +41 -0
  108. data/vendor/local/include/harfbuzz/hb-ot-layout.h +302 -0
  109. data/vendor/local/include/harfbuzz/hb-ot-shape.h +53 -0
  110. data/vendor/local/include/harfbuzz/hb-ot-tag.h +59 -0
  111. data/vendor/local/include/harfbuzz/hb-ot.h +43 -0
  112. data/vendor/local/include/harfbuzz/hb-set.h +154 -0
  113. data/vendor/local/include/harfbuzz/hb-shape-plan.h +89 -0
  114. data/vendor/local/include/harfbuzz/hb-shape.h +81 -0
  115. data/vendor/local/include/harfbuzz/hb-unicode.h +445 -0
  116. data/vendor/local/include/harfbuzz/hb-version.h +66 -0
  117. data/vendor/local/include/harfbuzz/hb.h +47 -0
  118. data/vendor/local/include/layout/LEFontInstance.h +550 -0
  119. data/vendor/local/include/layout/LEGlyphFilter.h +45 -0
  120. data/vendor/local/include/layout/LEGlyphStorage.h +546 -0
  121. data/vendor/local/include/layout/LEInsertionList.h +177 -0
  122. data/vendor/local/include/layout/LELanguages.h +112 -0
  123. data/vendor/local/include/layout/LEScripts.h +263 -0
  124. data/vendor/local/include/layout/LESwaps.h +100 -0
  125. data/vendor/local/include/layout/LETableReference.h +418 -0
  126. data/vendor/local/include/layout/LETypes.h +728 -0
  127. data/vendor/local/include/layout/LayoutEngine.h +518 -0
  128. data/vendor/local/include/layout/ParagraphLayout.h +747 -0
  129. data/vendor/local/include/layout/RunArrays.h +676 -0
  130. data/vendor/local/include/layout/loengine.h +225 -0
  131. data/vendor/local/include/layout/playout.h +466 -0
  132. data/vendor/local/include/layout/plruns.h +441 -0
  133. data/vendor/local/include/pango-1.0/pango/pango-attributes.h +514 -0
  134. data/vendor/local/include/pango-1.0/pango/pango-bidi-type.h +136 -0
  135. data/vendor/local/include/pango-1.0/pango/pango-break.h +173 -0
  136. data/vendor/local/include/pango-1.0/pango/pango-context.h +112 -0
  137. data/vendor/local/include/pango-1.0/pango/pango-coverage.h +79 -0
  138. data/vendor/local/include/pango-1.0/pango/pango-engine.h +429 -0
  139. data/vendor/local/include/pango-1.0/pango/pango-enum-types.h +69 -0
  140. data/vendor/local/include/pango-1.0/pango/pango-features.h +12 -0
  141. data/vendor/local/include/pango-1.0/pango/pango-font.h +622 -0
  142. data/vendor/local/include/pango-1.0/pango/pango-fontmap.h +167 -0
  143. data/vendor/local/include/pango-1.0/pango/pango-fontset.h +169 -0
  144. data/vendor/local/include/pango-1.0/pango/pango-glyph-item.h +158 -0
  145. data/vendor/local/include/pango-1.0/pango/pango-glyph.h +197 -0
  146. data/vendor/local/include/pango-1.0/pango/pango-gravity.h +128 -0
  147. data/vendor/local/include/pango-1.0/pango/pango-item.h +109 -0
  148. data/vendor/local/include/pango-1.0/pango/pango-language.h +61 -0
  149. data/vendor/local/include/pango-1.0/pango/pango-layout.h +340 -0
  150. data/vendor/local/include/pango-1.0/pango/pango-matrix.h +117 -0
  151. data/vendor/local/include/pango-1.0/pango/pango-modules.h +71 -0
  152. data/vendor/local/include/pango-1.0/pango/pango-ot.h +391 -0
  153. data/vendor/local/include/pango-1.0/pango/pango-renderer.h +260 -0
  154. data/vendor/local/include/pango-1.0/pango/pango-script.h +260 -0
  155. data/vendor/local/include/pango-1.0/pango/pango-tabs.h +87 -0
  156. data/vendor/local/include/pango-1.0/pango/pango-types.h +200 -0
  157. data/vendor/local/include/pango-1.0/pango/pango-utils.h +189 -0
  158. data/vendor/local/include/pango-1.0/pango/pango.h +48 -0
  159. data/vendor/local/include/pango-1.0/pango/pangocairo.h +169 -0
  160. data/vendor/local/include/pango-1.0/pango/pangofc-decoder.h +110 -0
  161. data/vendor/local/include/pango-1.0/pango/pangofc-font.h +153 -0
  162. data/vendor/local/include/pango-1.0/pango/pangofc-fontmap.h +289 -0
  163. data/vendor/local/include/pango-1.0/pango/pangoft2.h +133 -0
  164. data/vendor/local/include/pango-1.0/pango/pangowin32.h +128 -0
  165. data/vendor/local/include/unicode/alphaindex.h +752 -0
  166. data/vendor/local/include/unicode/appendable.h +232 -0
  167. data/vendor/local/include/unicode/basictz.h +214 -0
  168. data/vendor/local/include/unicode/brkiter.h +655 -0
  169. data/vendor/local/include/unicode/bytestream.h +257 -0
  170. data/vendor/local/include/unicode/bytestrie.h +519 -0
  171. data/vendor/local/include/unicode/bytestriebuilder.h +181 -0
  172. data/vendor/local/include/unicode/calendar.h +2519 -0
  173. data/vendor/local/include/unicode/caniter.h +208 -0
  174. data/vendor/local/include/unicode/chariter.h +722 -0
  175. data/vendor/local/include/unicode/choicfmt.h +594 -0
  176. data/vendor/local/include/unicode/coleitr.h +404 -0
  177. data/vendor/local/include/unicode/coll.h +1267 -0
  178. data/vendor/local/include/unicode/compactdecimalformat.h +330 -0
  179. data/vendor/local/include/unicode/curramt.h +130 -0
  180. data/vendor/local/include/unicode/currpinf.h +258 -0
  181. data/vendor/local/include/unicode/currunit.h +110 -0
  182. data/vendor/local/include/unicode/datefmt.h +883 -0
  183. data/vendor/local/include/unicode/dbbi.h +40 -0
  184. data/vendor/local/include/unicode/dcfmtsym.h +482 -0
  185. data/vendor/local/include/unicode/decimfmt.h +2479 -0
  186. data/vendor/local/include/unicode/docmain.h +215 -0
  187. data/vendor/local/include/unicode/dtfmtsym.h +912 -0
  188. data/vendor/local/include/unicode/dtintrv.h +158 -0
  189. data/vendor/local/include/unicode/dtitvfmt.h +985 -0
  190. data/vendor/local/include/unicode/dtitvinf.h +514 -0
  191. data/vendor/local/include/unicode/dtptngen.h +498 -0
  192. data/vendor/local/include/unicode/dtrule.h +250 -0
  193. data/vendor/local/include/unicode/enumset.h +64 -0
  194. data/vendor/local/include/unicode/errorcode.h +137 -0
  195. data/vendor/local/include/unicode/fieldpos.h +291 -0
  196. data/vendor/local/include/unicode/filteredbrk.h +131 -0
  197. data/vendor/local/include/unicode/fmtable.h +760 -0
  198. data/vendor/local/include/unicode/format.h +305 -0
  199. data/vendor/local/include/unicode/fpositer.h +117 -0
  200. data/vendor/local/include/unicode/gender.h +111 -0
  201. data/vendor/local/include/unicode/gregocal.h +777 -0
  202. data/vendor/local/include/unicode/icudataver.h +41 -0
  203. data/vendor/local/include/unicode/icuplug.h +371 -0
  204. data/vendor/local/include/unicode/idna.h +323 -0
  205. data/vendor/local/include/unicode/listformatter.h +167 -0
  206. data/vendor/local/include/unicode/localpointer.h +304 -0
  207. data/vendor/local/include/unicode/locdspnm.h +204 -0
  208. data/vendor/local/include/unicode/locid.h +815 -0
  209. data/vendor/local/include/unicode/measfmt.h +389 -0
  210. data/vendor/local/include/unicode/measunit.h +1443 -0
  211. data/vendor/local/include/unicode/measure.h +159 -0
  212. data/vendor/local/include/unicode/messagepattern.h +943 -0
  213. data/vendor/local/include/unicode/msgfmt.h +1093 -0
  214. data/vendor/local/include/unicode/normalizer2.h +658 -0
  215. data/vendor/local/include/unicode/normlzr.h +797 -0
  216. data/vendor/local/include/unicode/numfmt.h +1187 -0
  217. data/vendor/local/include/unicode/numsys.h +208 -0
  218. data/vendor/local/include/unicode/parseerr.h +92 -0
  219. data/vendor/local/include/unicode/parsepos.h +230 -0
  220. data/vendor/local/include/unicode/platform.h +751 -0
  221. data/vendor/local/include/unicode/plurfmt.h +615 -0
  222. data/vendor/local/include/unicode/plurrule.h +501 -0
  223. data/vendor/local/include/unicode/ptypes.h +126 -0
  224. data/vendor/local/include/unicode/putil.h +181 -0
  225. data/vendor/local/include/unicode/rbbi.h +782 -0
  226. data/vendor/local/include/unicode/rbnf.h +1032 -0
  227. data/vendor/local/include/unicode/rbtz.h +362 -0
  228. data/vendor/local/include/unicode/regex.h +1857 -0
  229. data/vendor/local/include/unicode/region.h +228 -0
  230. data/vendor/local/include/unicode/reldatefmt.h +498 -0
  231. data/vendor/local/include/unicode/rep.h +261 -0
  232. data/vendor/local/include/unicode/resbund.h +490 -0
  233. data/vendor/local/include/unicode/schriter.h +187 -0
  234. data/vendor/local/include/unicode/scientificformathelper.h +139 -0
  235. data/vendor/local/include/unicode/search.h +575 -0
  236. data/vendor/local/include/unicode/selfmt.h +367 -0
  237. data/vendor/local/include/unicode/simpletz.h +928 -0
  238. data/vendor/local/include/unicode/smpdtfmt.h +1592 -0
  239. data/vendor/local/include/unicode/sortkey.h +338 -0
  240. data/vendor/local/include/unicode/std_string.h +37 -0
  241. data/vendor/local/include/unicode/strenum.h +276 -0
  242. data/vendor/local/include/unicode/stringpiece.h +224 -0
  243. data/vendor/local/include/unicode/stringtriebuilder.h +402 -0
  244. data/vendor/local/include/unicode/stsearch.h +504 -0
  245. data/vendor/local/include/unicode/symtable.h +112 -0
  246. data/vendor/local/include/unicode/tblcoll.h +873 -0
  247. data/vendor/local/include/unicode/timezone.h +948 -0
  248. data/vendor/local/include/unicode/tmunit.h +129 -0
  249. data/vendor/local/include/unicode/tmutamt.h +168 -0
  250. data/vendor/local/include/unicode/tmutfmt.h +243 -0
  251. data/vendor/local/include/unicode/translit.h +1342 -0
  252. data/vendor/local/include/unicode/tzfmt.h +1098 -0
  253. data/vendor/local/include/unicode/tznames.h +404 -0
  254. data/vendor/local/include/unicode/tzrule.h +828 -0
  255. data/vendor/local/include/unicode/tztrans.h +195 -0
  256. data/vendor/local/include/unicode/ubidi.h +2186 -0
  257. data/vendor/local/include/unicode/ubrk.h +540 -0
  258. data/vendor/local/include/unicode/ucal.h +1560 -0
  259. data/vendor/local/include/unicode/ucasemap.h +423 -0
  260. data/vendor/local/include/unicode/ucat.h +158 -0
  261. data/vendor/local/include/unicode/uchar.h +3426 -0
  262. data/vendor/local/include/unicode/ucharstrie.h +576 -0
  263. data/vendor/local/include/unicode/ucharstriebuilder.h +185 -0
  264. data/vendor/local/include/unicode/uchriter.h +381 -0
  265. data/vendor/local/include/unicode/uclean.h +258 -0
  266. data/vendor/local/include/unicode/ucnv.h +2036 -0
  267. data/vendor/local/include/unicode/ucnv_cb.h +162 -0
  268. data/vendor/local/include/unicode/ucnv_err.h +463 -0
  269. data/vendor/local/include/unicode/ucnvsel.h +187 -0
  270. data/vendor/local/include/unicode/ucol.h +1474 -0
  271. data/vendor/local/include/unicode/ucoleitr.h +266 -0
  272. data/vendor/local/include/unicode/uconfig.h +430 -0
  273. data/vendor/local/include/unicode/ucsdet.h +413 -0
  274. data/vendor/local/include/unicode/ucurr.h +424 -0
  275. data/vendor/local/include/unicode/udat.h +1536 -0
  276. data/vendor/local/include/unicode/udata.h +430 -0
  277. data/vendor/local/include/unicode/udateintervalformat.h +181 -0
  278. data/vendor/local/include/unicode/udatpg.h +588 -0
  279. data/vendor/local/include/unicode/udisplaycontext.h +150 -0
  280. data/vendor/local/include/unicode/uenum.h +206 -0
  281. data/vendor/local/include/unicode/uformattable.h +280 -0
  282. data/vendor/local/include/unicode/ugender.h +82 -0
  283. data/vendor/local/include/unicode/uidna.h +762 -0
  284. data/vendor/local/include/unicode/uiter.h +707 -0
  285. data/vendor/local/include/unicode/uldnames.h +302 -0
  286. data/vendor/local/include/unicode/uloc.h +1256 -0
  287. data/vendor/local/include/unicode/ulocdata.h +277 -0
  288. data/vendor/local/include/unicode/umachine.h +356 -0
  289. data/vendor/local/include/unicode/umisc.h +60 -0
  290. data/vendor/local/include/unicode/umsg.h +623 -0
  291. data/vendor/local/include/unicode/unifilt.h +120 -0
  292. data/vendor/local/include/unicode/unifunct.h +125 -0
  293. data/vendor/local/include/unicode/unimatch.h +163 -0
  294. data/vendor/local/include/unicode/unirepl.h +97 -0
  295. data/vendor/local/include/unicode/uniset.h +1691 -0
  296. data/vendor/local/include/unicode/unistr.h +4470 -0
  297. data/vendor/local/include/unicode/unorm.h +561 -0
  298. data/vendor/local/include/unicode/unorm2.h +528 -0
  299. data/vendor/local/include/unicode/unum.h +1328 -0
  300. data/vendor/local/include/unicode/unumsys.h +170 -0
  301. data/vendor/local/include/unicode/uobject.h +320 -0
  302. data/vendor/local/include/unicode/upluralrules.h +145 -0
  303. data/vendor/local/include/unicode/uregex.h +1591 -0
  304. data/vendor/local/include/unicode/uregion.h +248 -0
  305. data/vendor/local/include/unicode/urename.h +1784 -0
  306. data/vendor/local/include/unicode/urep.h +155 -0
  307. data/vendor/local/include/unicode/ures.h +887 -0
  308. data/vendor/local/include/unicode/uscript.h +642 -0
  309. data/vendor/local/include/unicode/usearch.h +885 -0
  310. data/vendor/local/include/unicode/uset.h +1126 -0
  311. data/vendor/local/include/unicode/usetiter.h +318 -0
  312. data/vendor/local/include/unicode/ushape.h +474 -0
  313. data/vendor/local/include/unicode/uspoof.h +1064 -0
  314. data/vendor/local/include/unicode/usprep.h +269 -0
  315. data/vendor/local/include/unicode/ustdio.h +1018 -0
  316. data/vendor/local/include/unicode/ustream.h +68 -0
  317. data/vendor/local/include/unicode/ustring.h +1700 -0
  318. data/vendor/local/include/unicode/ustringtrie.h +95 -0
  319. data/vendor/local/include/unicode/utext.h +1600 -0
  320. data/vendor/local/include/unicode/utf.h +223 -0
  321. data/vendor/local/include/unicode/utf16.h +623 -0
  322. data/vendor/local/include/unicode/utf32.h +23 -0
  323. data/vendor/local/include/unicode/utf8.h +824 -0
  324. data/vendor/local/include/unicode/utf_old.h +1169 -0
  325. data/vendor/local/include/unicode/utmscale.h +481 -0
  326. data/vendor/local/include/unicode/utrace.h +359 -0
  327. data/vendor/local/include/unicode/utrans.h +658 -0
  328. data/vendor/local/include/unicode/utypes.h +723 -0
  329. data/vendor/local/include/unicode/uvernum.h +170 -0
  330. data/vendor/local/include/unicode/uversion.h +193 -0
  331. data/vendor/local/include/unicode/vtzone.h +455 -0
  332. data/vendor/local/lib/girepository-1.0/Pango-1.0.typelib +0 -0
  333. data/vendor/local/lib/girepository-1.0/PangoCairo-1.0.typelib +0 -0
  334. data/vendor/local/lib/girepository-1.0/PangoFT2-1.0.typelib +0 -0
  335. data/vendor/local/lib/icu/54.1/Makefile.inc +293 -0
  336. data/vendor/local/lib/icu/54.1/pkgdata.inc +17 -0
  337. data/vendor/local/lib/icu/Makefile.inc +293 -0
  338. data/vendor/local/lib/icu/pkgdata.inc +17 -0
  339. data/vendor/local/lib/icudt.dll +0 -0
  340. data/vendor/local/lib/icudt54.dll +0 -0
  341. data/vendor/local/lib/icuin.dll +0 -0
  342. data/vendor/local/lib/icuin54.dll +0 -0
  343. data/vendor/local/lib/icuio.dll +0 -0
  344. data/vendor/local/lib/icuio54.dll +0 -0
  345. data/vendor/local/lib/icule.dll +0 -0
  346. data/vendor/local/lib/icule54.dll +0 -0
  347. data/vendor/local/lib/iculx.dll +0 -0
  348. data/vendor/local/lib/iculx54.dll +0 -0
  349. data/vendor/local/lib/icutest.dll +0 -0
  350. data/vendor/local/lib/icutest54.dll +0 -0
  351. data/vendor/local/lib/icutu.dll +0 -0
  352. data/vendor/local/lib/icutu54.dll +0 -0
  353. data/vendor/local/lib/icuuc.dll +0 -0
  354. data/vendor/local/lib/icuuc54.dll +0 -0
  355. data/vendor/local/lib/libharfbuzz-icu.a +0 -0
  356. data/vendor/local/lib/libharfbuzz-icu.la +41 -0
  357. data/vendor/local/lib/libharfbuzz.dll.a +0 -0
  358. data/vendor/local/lib/libharfbuzz.la +41 -0
  359. data/vendor/local/lib/libicudt.dll.a +0 -0
  360. data/vendor/local/lib/libicuin.dll.a +0 -0
  361. data/vendor/local/lib/libicuio.dll.a +0 -0
  362. data/vendor/local/lib/libicule.dll.a +0 -0
  363. data/vendor/local/lib/libiculx.dll.a +0 -0
  364. data/vendor/local/lib/libicutest.dll.a +0 -0
  365. data/vendor/local/lib/libicutu.dll.a +0 -0
  366. data/vendor/local/lib/libicuuc.dll.a +0 -0
  367. data/vendor/local/lib/libpango-1.0.dll.a +0 -0
  368. data/vendor/local/lib/libpango-1.0.la +41 -0
  369. data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
  370. data/vendor/local/lib/libpangocairo-1.0.la +41 -0
  371. data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
  372. data/vendor/local/lib/libpangoft2-1.0.la +41 -0
  373. data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
  374. data/vendor/local/lib/libpangowin32-1.0.la +41 -0
  375. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll +0 -0
  376. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll.a +0 -0
  377. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.la +41 -0
  378. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll +0 -0
  379. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll.a +0 -0
  380. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.la +41 -0
  381. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll +0 -0
  382. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll.a +0 -0
  383. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.la +41 -0
  384. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll +0 -0
  385. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll.a +0 -0
  386. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.la +41 -0
  387. data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +13 -0
  388. data/vendor/local/lib/pkgconfig/harfbuzz.pc +11 -0
  389. data/vendor/local/lib/pkgconfig/icu-i18n.pc +38 -0
  390. data/vendor/local/lib/pkgconfig/icu-io.pc +38 -0
  391. data/vendor/local/lib/pkgconfig/icu-le.pc +38 -0
  392. data/vendor/local/lib/pkgconfig/icu-lx.pc +38 -0
  393. data/vendor/local/lib/pkgconfig/icu-uc.pc +38 -0
  394. data/vendor/local/lib/pkgconfig/pango.pc +14 -0
  395. data/vendor/local/lib/pkgconfig/pangocairo.pc +11 -0
  396. data/vendor/local/lib/pkgconfig/pangoft2.pc +12 -0
  397. data/vendor/local/lib/pkgconfig/pangowin32.pc +11 -0
  398. data/vendor/local/share/gir-1.0/Pango-1.0.gir +13329 -0
  399. data/vendor/local/share/gir-1.0/PangoCairo-1.0.gir +833 -0
  400. data/vendor/local/share/gir-1.0/PangoFT2-1.0.gir +354 -0
  401. data/vendor/local/share/gtk-doc/html/harfbuzz/annotation-glossary.html +75 -0
  402. data/vendor/local/share/gtk-doc/html/harfbuzz/api-index-full.html +1449 -0
  403. data/vendor/local/share/gtk-doc/html/harfbuzz/ch01.html +98 -0
  404. data/vendor/local/share/gtk-doc/html/harfbuzz/deprecated-api-index.html +46 -0
  405. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-blob.html +610 -0
  406. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-buffer.html +1780 -0
  407. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-common.html +1337 -0
  408. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-coretext.html +144 -0
  409. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-deprecated.html +99 -0
  410. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-face.html +630 -0
  411. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-font.html +2529 -0
  412. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ft.html +188 -0
  413. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-glib.html +120 -0
  414. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-gobject.html +50 -0
  415. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-graphite2.html +120 -0
  416. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-icu.html +120 -0
  417. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-layout.html +771 -0
  418. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-tag.html +172 -0
  419. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot.html +50 -0
  420. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-set.html +966 -0
  421. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape-plan.html +405 -0
  422. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape.html +286 -0
  423. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-unicode.html +1523 -0
  424. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-uniscribe.html +100 -0
  425. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +182 -0
  426. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb.html +50 -0
  427. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz.devhelp2 +378 -0
  428. data/vendor/local/share/gtk-doc/html/harfbuzz/home.png +0 -0
  429. data/vendor/local/share/gtk-doc/html/harfbuzz/index.html +105 -0
  430. data/vendor/local/share/gtk-doc/html/harfbuzz/index.sgml +496 -0
  431. data/vendor/local/share/gtk-doc/html/harfbuzz/left-insensitive.png +0 -0
  432. data/vendor/local/share/gtk-doc/html/harfbuzz/left.png +0 -0
  433. data/vendor/local/share/gtk-doc/html/harfbuzz/object-tree.html +59 -0
  434. data/vendor/local/share/gtk-doc/html/harfbuzz/right-insensitive.png +0 -0
  435. data/vendor/local/share/gtk-doc/html/harfbuzz/right.png +0 -0
  436. data/vendor/local/share/gtk-doc/html/harfbuzz/style.css +476 -0
  437. data/vendor/local/share/gtk-doc/html/harfbuzz/up-insensitive.png +0 -0
  438. data/vendor/local/share/gtk-doc/html/harfbuzz/up.png +0 -0
  439. data/vendor/local/share/gtk-doc/html/pango/PangoEngineLang.html +224 -0
  440. data/vendor/local/share/gtk-doc/html/pango/PangoEngineShape.html +255 -0
  441. data/vendor/local/share/gtk-doc/html/pango/PangoFcDecoder.html +246 -0
  442. data/vendor/local/share/gtk-doc/html/pango/PangoFcFont.html +500 -0
  443. data/vendor/local/share/gtk-doc/html/pango/PangoFcFontMap.html +1001 -0
  444. data/vendor/local/share/gtk-doc/html/pango/PangoMarkupFormat.html +301 -0
  445. data/vendor/local/share/gtk-doc/html/pango/PangoRenderer.html +1219 -0
  446. data/vendor/local/share/gtk-doc/html/pango/annotation-glossary.html +89 -0
  447. data/vendor/local/share/gtk-doc/html/pango/api-index-1-10.html +135 -0
  448. data/vendor/local/share/gtk-doc/html/pango/api-index-1-12.html +49 -0
  449. data/vendor/local/share/gtk-doc/html/pango/api-index-1-14.html +64 -0
  450. data/vendor/local/share/gtk-doc/html/pango/api-index-1-16.html +228 -0
  451. data/vendor/local/share/gtk-doc/html/pango/api-index-1-18.html +152 -0
  452. data/vendor/local/share/gtk-doc/html/pango/api-index-1-2.html +122 -0
  453. data/vendor/local/share/gtk-doc/html/pango/api-index-1-20.html +87 -0
  454. data/vendor/local/share/gtk-doc/html/pango/api-index-1-22.html +124 -0
  455. data/vendor/local/share/gtk-doc/html/pango/api-index-1-24.html +97 -0
  456. data/vendor/local/share/gtk-doc/html/pango/api-index-1-26.html +46 -0
  457. data/vendor/local/share/gtk-doc/html/pango/api-index-1-30.html +39 -0
  458. data/vendor/local/share/gtk-doc/html/pango/api-index-1-31-0.html +39 -0
  459. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32-4.html +53 -0
  460. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32.html +42 -0
  461. data/vendor/local/share/gtk-doc/html/pango/api-index-1-34.html +38 -0
  462. data/vendor/local/share/gtk-doc/html/pango/api-index-1-4.html +201 -0
  463. data/vendor/local/share/gtk-doc/html/pango/api-index-1-6.html +165 -0
  464. data/vendor/local/share/gtk-doc/html/pango/api-index-1-8.html +171 -0
  465. data/vendor/local/share/gtk-doc/html/pango/api-index-deprecated.html +284 -0
  466. data/vendor/local/share/gtk-doc/html/pango/api-index-full.html +2968 -0
  467. data/vendor/local/share/gtk-doc/html/pango/home.png +0 -0
  468. data/vendor/local/share/gtk-doc/html/pango/index.html +146 -0
  469. data/vendor/local/share/gtk-doc/html/pango/index.sgml +957 -0
  470. data/vendor/local/share/gtk-doc/html/pango/layout.gif +0 -0
  471. data/vendor/local/share/gtk-doc/html/pango/left-insensitive.png +0 -0
  472. data/vendor/local/share/gtk-doc/html/pango/left.png +0 -0
  473. data/vendor/local/share/gtk-doc/html/pango/lowlevel.html +68 -0
  474. data/vendor/local/share/gtk-doc/html/pango/pango-Bidirectional-Text.html +514 -0
  475. data/vendor/local/share/gtk-doc/html/pango/pango-Cairo-Rendering.html +1632 -0
  476. data/vendor/local/share/gtk-doc/html/pango/pango-CoreText-Fonts.html +115 -0
  477. data/vendor/local/share/gtk-doc/html/pango/pango-Coverage-Maps.html +508 -0
  478. data/vendor/local/share/gtk-doc/html/pango/pango-Engines.html +358 -0
  479. data/vendor/local/share/gtk-doc/html/pango/pango-Fonts.html +4154 -0
  480. data/vendor/local/share/gtk-doc/html/pango/pango-FreeType-Fonts-and-Rendering.html +956 -0
  481. data/vendor/local/share/gtk-doc/html/pango/pango-Glyph-Storage.html +2627 -0
  482. data/vendor/local/share/gtk-doc/html/pango/pango-Layout-Objects.html +4153 -0
  483. data/vendor/local/share/gtk-doc/html/pango/pango-Miscellaneous-Utilities.html +965 -0
  484. data/vendor/local/share/gtk-doc/html/pango/pango-Modules.html +331 -0
  485. data/vendor/local/share/gtk-doc/html/pango/pango-OpenType-Font-Handling.html +2202 -0
  486. data/vendor/local/share/gtk-doc/html/pango/pango-Scripts-and-Languages.html +1430 -0
  487. data/vendor/local/share/gtk-doc/html/pango/pango-Tab-Stops.html +582 -0
  488. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Attributes.html +3356 -0
  489. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Processing.html +2079 -0
  490. data/vendor/local/share/gtk-doc/html/pango/pango-Version-Checking.html +325 -0
  491. data/vendor/local/share/gtk-doc/html/pango/pango-Vertical-Text.html +523 -0
  492. data/vendor/local/share/gtk-doc/html/pango/pango-Win32-Fonts-and-Rendering.html +1028 -0
  493. data/vendor/local/share/gtk-doc/html/pango/pango-Xft-Fonts-and-Rendering.html +1275 -0
  494. data/vendor/local/share/gtk-doc/html/pango/pango-hierarchy.html +91 -0
  495. data/vendor/local/share/gtk-doc/html/pango/pango-querymodules.html +131 -0
  496. data/vendor/local/share/gtk-doc/html/pango/pango.devhelp2 +786 -0
  497. data/vendor/local/share/gtk-doc/html/pango/pango.html +63 -0
  498. data/vendor/local/share/gtk-doc/html/pango/rendering.html +47 -0
  499. data/vendor/local/share/gtk-doc/html/pango/right-insensitive.png +0 -0
  500. data/vendor/local/share/gtk-doc/html/pango/right.png +0 -0
  501. data/vendor/local/share/gtk-doc/html/pango/rotated-text.png +0 -0
  502. data/vendor/local/share/gtk-doc/html/pango/style.css +476 -0
  503. data/vendor/local/share/gtk-doc/html/pango/tools.html +33 -0
  504. data/vendor/local/share/gtk-doc/html/pango/up-insensitive.png +0 -0
  505. data/vendor/local/share/gtk-doc/html/pango/up.png +0 -0
  506. data/vendor/local/share/icu/54.1/config/mh-mingw64 +158 -0
  507. data/vendor/local/share/icu/54.1/install-sh +251 -0
  508. data/vendor/local/share/icu/54.1/license.html +385 -0
  509. data/vendor/local/share/icu/54.1/mkinstalldirs +43 -0
  510. data/vendor/local/share/license/harfbuzz/AUTHORS +9 -0
  511. data/vendor/local/share/license/harfbuzz/COPYING +36 -0
  512. data/vendor/local/share/license/pango/AUTHORS +2 -0
  513. data/vendor/local/share/license/pango/COPYING +482 -0
  514. data/vendor/local/share/man/man1/derb.1 +196 -0
  515. data/vendor/local/share/man/man1/genbrk.1 +112 -0
  516. data/vendor/local/share/man/man1/gencfu.1 +91 -0
  517. data/vendor/local/share/man/man1/gencnval.1 +91 -0
  518. data/vendor/local/share/man/man1/gendict.1 +131 -0
  519. data/vendor/local/share/man/man1/genrb.1 +146 -0
  520. data/vendor/local/share/man/man1/icu-config.1 +288 -0
  521. data/vendor/local/share/man/man1/makeconv.1 +112 -0
  522. data/vendor/local/share/man/man1/pango-querymodules.1 +106 -0
  523. data/vendor/local/share/man/man1/pango-view.1 +1 -0
  524. data/vendor/local/share/man/man1/pkgdata.1 +258 -0
  525. data/vendor/local/share/man/man1/uconv.1 +443 -0
  526. data/vendor/local/share/man/man8/genccode.8 +106 -0
  527. data/vendor/local/share/man/man8/gencmn.8 +129 -0
  528. data/vendor/local/share/man/man8/gensprep.8 +102 -0
  529. data/vendor/local/share/man/man8/icupkg.8 +204 -0
  530. metadata +599 -0
@@ -0,0 +1,1256 @@
1
+ /*
2
+ **********************************************************************
3
+ * Copyright (C) 1997-2014, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ **********************************************************************
6
+ *
7
+ * File ULOC.H
8
+ *
9
+ * Modification History:
10
+ *
11
+ * Date Name Description
12
+ * 04/01/97 aliu Creation.
13
+ * 08/22/98 stephen JDK 1.2 sync.
14
+ * 12/08/98 rtg New C API for Locale
15
+ * 03/30/99 damiba overhaul
16
+ * 03/31/99 helena Javadoc for uloc functions.
17
+ * 04/15/99 Madhu Updated Javadoc
18
+ ********************************************************************************
19
+ */
20
+
21
+ #ifndef ULOC_H
22
+ #define ULOC_H
23
+
24
+ #include "unicode/utypes.h"
25
+ #include "unicode/uenum.h"
26
+
27
+ /**
28
+ * \file
29
+ * \brief C API: Locale
30
+ *
31
+ * <h2> ULoc C API for Locale </h2>
32
+ * A <code>Locale</code> represents a specific geographical, political,
33
+ * or cultural region. An operation that requires a <code>Locale</code> to perform
34
+ * its task is called <em>locale-sensitive</em> and uses the <code>Locale</code>
35
+ * to tailor information for the user. For example, displaying a number
36
+ * is a locale-sensitive operation--the number should be formatted
37
+ * according to the customs/conventions of the user's native country,
38
+ * region, or culture. In the C APIs, a locales is simply a const char string.
39
+ *
40
+ * <P>
41
+ * You create a <code>Locale</code> with one of the three options listed below.
42
+ * Each of the component is separated by '_' in the locale string.
43
+ * \htmlonly<blockquote>\endhtmlonly
44
+ * <pre>
45
+ * \code
46
+ * newLanguage
47
+ *
48
+ * newLanguage + newCountry
49
+ *
50
+ * newLanguage + newCountry + newVariant
51
+ * \endcode
52
+ * </pre>
53
+ * \htmlonly</blockquote>\endhtmlonly
54
+ * The first option is a valid <STRONG>ISO
55
+ * Language Code.</STRONG> These codes are the lower-case two-letter
56
+ * codes as defined by ISO-639.
57
+ * You can find a full list of these codes at a number of sites, such as:
58
+ * <BR><a href ="http://www.ics.uci.edu/pub/ietf/http/related/iso639.txt">
59
+ * http://www.ics.uci.edu/pub/ietf/http/related/iso639.txt</a>
60
+ *
61
+ * <P>
62
+ * The second option includes an additonal <STRONG>ISO Country
63
+ * Code.</STRONG> These codes are the upper-case two-letter codes
64
+ * as defined by ISO-3166.
65
+ * You can find a full list of these codes at a number of sites, such as:
66
+ * <BR><a href="http://www.chemie.fu-berlin.de/diverse/doc/ISO_3166.html">
67
+ * http://www.chemie.fu-berlin.de/diverse/doc/ISO_3166.html</a>
68
+ *
69
+ * <P>
70
+ * The third option requires another additonal information--the
71
+ * <STRONG>Variant.</STRONG>
72
+ * The Variant codes are vendor and browser-specific.
73
+ * For example, use WIN for Windows, MAC for Macintosh, and POSIX for POSIX.
74
+ * Where there are two variants, separate them with an underscore, and
75
+ * put the most important one first. For
76
+ * example, a Traditional Spanish collation might be referenced, with
77
+ * "ES", "ES", "Traditional_WIN".
78
+ *
79
+ * <P>
80
+ * Because a <code>Locale</code> is just an identifier for a region,
81
+ * no validity check is performed when you specify a <code>Locale</code>.
82
+ * If you want to see whether particular resources are available for the
83
+ * <code>Locale</code> you asked for, you must query those resources. For
84
+ * example, ask the <code>UNumberFormat</code> for the locales it supports
85
+ * using its <code>getAvailable</code> method.
86
+ * <BR><STRONG>Note:</STRONG> When you ask for a resource for a particular
87
+ * locale, you get back the best available match, not necessarily
88
+ * precisely what you asked for. For more information, look at
89
+ * <code>UResourceBundle</code>.
90
+ *
91
+ * <P>
92
+ * The <code>Locale</code> provides a number of convenient constants
93
+ * that you can use to specify the commonly used
94
+ * locales. For example, the following refers to a locale
95
+ * for the United States:
96
+ * \htmlonly<blockquote>\endhtmlonly
97
+ * <pre>
98
+ * \code
99
+ * ULOC_US
100
+ * \endcode
101
+ * </pre>
102
+ * \htmlonly</blockquote>\endhtmlonly
103
+ *
104
+ * <P>
105
+ * Once you've specified a locale you can query it for information about
106
+ * itself. Use <code>uloc_getCountry</code> to get the ISO Country Code and
107
+ * <code>uloc_getLanguage</code> to get the ISO Language Code. You can
108
+ * use <code>uloc_getDisplayCountry</code> to get the
109
+ * name of the country suitable for displaying to the user. Similarly,
110
+ * you can use <code>uloc_getDisplayLanguage</code> to get the name of
111
+ * the language suitable for displaying to the user. Interestingly,
112
+ * the <code>uloc_getDisplayXXX</code> methods are themselves locale-sensitive
113
+ * and have two versions: one that uses the default locale and one
114
+ * that takes a locale as an argument and displays the name or country in
115
+ * a language appropriate to that locale.
116
+ *
117
+ * <P>
118
+ * The ICU provides a number of services that perform locale-sensitive
119
+ * operations. For example, the <code>unum_xxx</code> functions format
120
+ * numbers, currency, or percentages in a locale-sensitive manner.
121
+ * </P>
122
+ * \htmlonly<blockquote>\endhtmlonly
123
+ * <pre>
124
+ * \code
125
+ * UErrorCode success = U_ZERO_ERROR;
126
+ * UNumberFormat *nf;
127
+ * const char* myLocale = "fr_FR";
128
+ *
129
+ * nf = unum_open( UNUM_DEFAULT, NULL, success );
130
+ * unum_close(nf);
131
+ * nf = unum_open( UNUM_CURRENCY, NULL, success );
132
+ * unum_close(nf);
133
+ * nf = unum_open( UNUM_PERCENT, NULL, success );
134
+ * unum_close(nf);
135
+ * \endcode
136
+ * </pre>
137
+ * \htmlonly</blockquote>\endhtmlonly
138
+ * Each of these methods has two variants; one with an explicit locale
139
+ * and one without; the latter using the default locale.
140
+ * \htmlonly<blockquote>\endhtmlonly
141
+ * <pre>
142
+ * \code
143
+ *
144
+ * nf = unum_open( UNUM_DEFAULT, myLocale, success );
145
+ * unum_close(nf);
146
+ * nf = unum_open( UNUM_CURRENCY, myLocale, success );
147
+ * unum_close(nf);
148
+ * nf = unum_open( UNUM_PERCENT, myLocale, success );
149
+ * unum_close(nf);
150
+ * \endcode
151
+ * </pre>
152
+ * \htmlonly</blockquote>\endhtmlonly
153
+ * A <code>Locale</code> is the mechanism for identifying the kind of services
154
+ * (<code>UNumberFormat</code>) that you would like to get. The locale is
155
+ * <STRONG>just</STRONG> a mechanism for identifying these services.
156
+ *
157
+ * <P>
158
+ * Each international serivce that performs locale-sensitive operations
159
+ * allows you
160
+ * to get all the available objects of that type. You can sift
161
+ * through these objects by language, country, or variant,
162
+ * and use the display names to present a menu to the user.
163
+ * For example, you can create a menu of all the collation objects
164
+ * suitable for a given language. Such classes implement these
165
+ * three class methods:
166
+ * \htmlonly<blockquote>\endhtmlonly
167
+ * <pre>
168
+ * \code
169
+ * const char* uloc_getAvailable(int32_t index);
170
+ * int32_t uloc_countAvailable();
171
+ * int32_t
172
+ * uloc_getDisplayName(const char* localeID,
173
+ * const char* inLocaleID,
174
+ * UChar* result,
175
+ * int32_t maxResultSize,
176
+ * UErrorCode* err);
177
+ *
178
+ * \endcode
179
+ * </pre>
180
+ * \htmlonly</blockquote>\endhtmlonly
181
+ * <P>
182
+ * Concerning POSIX/RFC1766 Locale IDs,
183
+ * the getLanguage/getCountry/getVariant/getName functions do understand
184
+ * the POSIX type form of language_COUNTRY.ENCODING\@VARIANT
185
+ * and if there is not an ICU-stype variant, uloc_getVariant() for example
186
+ * will return the one listed after the \@at sign. As well, the hyphen
187
+ * "-" is recognized as a country/variant separator similarly to RFC1766.
188
+ * So for example, "en-us" will be interpreted as en_US.
189
+ * As a result, uloc_getName() is far from a no-op, and will have the
190
+ * effect of converting POSIX/RFC1766 IDs into ICU form, although it does
191
+ * NOT map any of the actual codes (i.e. russian->ru) in any way.
192
+ * Applications should call uloc_getName() at the point where a locale ID
193
+ * is coming from an external source (user entry, OS, web browser)
194
+ * and pass the resulting string to other ICU functions. For example,
195
+ * don't use de-de\@EURO as an argument to resourcebundle.
196
+ *
197
+ * @see UResourceBundle
198
+ */
199
+
200
+ /** Useful constant for this language. @stable ICU 2.0 */
201
+ #define ULOC_CHINESE "zh"
202
+ /** Useful constant for this language. @stable ICU 2.0 */
203
+ #define ULOC_ENGLISH "en"
204
+ /** Useful constant for this language. @stable ICU 2.0 */
205
+ #define ULOC_FRENCH "fr"
206
+ /** Useful constant for this language. @stable ICU 2.0 */
207
+ #define ULOC_GERMAN "de"
208
+ /** Useful constant for this language. @stable ICU 2.0 */
209
+ #define ULOC_ITALIAN "it"
210
+ /** Useful constant for this language. @stable ICU 2.0 */
211
+ #define ULOC_JAPANESE "ja"
212
+ /** Useful constant for this language. @stable ICU 2.0 */
213
+ #define ULOC_KOREAN "ko"
214
+ /** Useful constant for this language. @stable ICU 2.0 */
215
+ #define ULOC_SIMPLIFIED_CHINESE "zh_CN"
216
+ /** Useful constant for this language. @stable ICU 2.0 */
217
+ #define ULOC_TRADITIONAL_CHINESE "zh_TW"
218
+
219
+ /** Useful constant for this country/region. @stable ICU 2.0 */
220
+ #define ULOC_CANADA "en_CA"
221
+ /** Useful constant for this country/region. @stable ICU 2.0 */
222
+ #define ULOC_CANADA_FRENCH "fr_CA"
223
+ /** Useful constant for this country/region. @stable ICU 2.0 */
224
+ #define ULOC_CHINA "zh_CN"
225
+ /** Useful constant for this country/region. @stable ICU 2.0 */
226
+ #define ULOC_PRC "zh_CN"
227
+ /** Useful constant for this country/region. @stable ICU 2.0 */
228
+ #define ULOC_FRANCE "fr_FR"
229
+ /** Useful constant for this country/region. @stable ICU 2.0 */
230
+ #define ULOC_GERMANY "de_DE"
231
+ /** Useful constant for this country/region. @stable ICU 2.0 */
232
+ #define ULOC_ITALY "it_IT"
233
+ /** Useful constant for this country/region. @stable ICU 2.0 */
234
+ #define ULOC_JAPAN "ja_JP"
235
+ /** Useful constant for this country/region. @stable ICU 2.0 */
236
+ #define ULOC_KOREA "ko_KR"
237
+ /** Useful constant for this country/region. @stable ICU 2.0 */
238
+ #define ULOC_TAIWAN "zh_TW"
239
+ /** Useful constant for this country/region. @stable ICU 2.0 */
240
+ #define ULOC_UK "en_GB"
241
+ /** Useful constant for this country/region. @stable ICU 2.0 */
242
+ #define ULOC_US "en_US"
243
+
244
+ /**
245
+ * Useful constant for the maximum size of the language part of a locale ID.
246
+ * (including the terminating NULL).
247
+ * @stable ICU 2.0
248
+ */
249
+ #define ULOC_LANG_CAPACITY 12
250
+
251
+ /**
252
+ * Useful constant for the maximum size of the country part of a locale ID
253
+ * (including the terminating NULL).
254
+ * @stable ICU 2.0
255
+ */
256
+ #define ULOC_COUNTRY_CAPACITY 4
257
+ /**
258
+ * Useful constant for the maximum size of the whole locale ID
259
+ * (including the terminating NULL and all keywords).
260
+ * @stable ICU 2.0
261
+ */
262
+ #define ULOC_FULLNAME_CAPACITY 157
263
+
264
+ /**
265
+ * Useful constant for the maximum size of the script part of a locale ID
266
+ * (including the terminating NULL).
267
+ * @stable ICU 2.8
268
+ */
269
+ #define ULOC_SCRIPT_CAPACITY 6
270
+
271
+ /**
272
+ * Useful constant for the maximum size of keywords in a locale
273
+ * @stable ICU 2.8
274
+ */
275
+ #define ULOC_KEYWORDS_CAPACITY 96
276
+
277
+ /**
278
+ * Useful constant for the maximum total size of keywords and their values in a locale
279
+ * @stable ICU 2.8
280
+ */
281
+ #define ULOC_KEYWORD_AND_VALUES_CAPACITY 100
282
+
283
+ /**
284
+ * Invariant character separating keywords from the locale string
285
+ * @stable ICU 2.8
286
+ */
287
+ #define ULOC_KEYWORD_SEPARATOR '@'
288
+
289
+ /**
290
+ * Unicode code point for '@' separating keywords from the locale string.
291
+ * @see ULOC_KEYWORD_SEPARATOR
292
+ * @stable ICU 4.6
293
+ */
294
+ #define ULOC_KEYWORD_SEPARATOR_UNICODE 0x40
295
+
296
+ /**
297
+ * Invariant character for assigning value to a keyword
298
+ * @stable ICU 2.8
299
+ */
300
+ #define ULOC_KEYWORD_ASSIGN '='
301
+
302
+ /**
303
+ * Unicode code point for '=' for assigning value to a keyword.
304
+ * @see ULOC_KEYWORD_ASSIGN
305
+ * @stable ICU 4.6
306
+ */
307
+ #define ULOC_KEYWORD_ASSIGN_UNICODE 0x3D
308
+
309
+ /**
310
+ * Invariant character separating keywords
311
+ * @stable ICU 2.8
312
+ */
313
+ #define ULOC_KEYWORD_ITEM_SEPARATOR ';'
314
+
315
+ /**
316
+ * Unicode code point for ';' separating keywords
317
+ * @see ULOC_KEYWORD_ITEM_SEPARATOR
318
+ * @stable ICU 4.6
319
+ */
320
+ #define ULOC_KEYWORD_ITEM_SEPARATOR_UNICODE 0x3B
321
+
322
+ /**
323
+ * Constants for *_getLocale()
324
+ * Allow user to select whether she wants information on
325
+ * requested, valid or actual locale.
326
+ * For example, a collator for "en_US_CALIFORNIA" was
327
+ * requested. In the current state of ICU (2.0),
328
+ * the requested locale is "en_US_CALIFORNIA",
329
+ * the valid locale is "en_US" (most specific locale supported by ICU)
330
+ * and the actual locale is "root" (the collation data comes unmodified
331
+ * from the UCA)
332
+ * The locale is considered supported by ICU if there is a core ICU bundle
333
+ * for that locale (although it may be empty).
334
+ * @stable ICU 2.1
335
+ */
336
+ typedef enum {
337
+ /** This is locale the data actually comes from
338
+ * @stable ICU 2.1
339
+ */
340
+ ULOC_ACTUAL_LOCALE = 0,
341
+ /** This is the most specific locale supported by ICU
342
+ * @stable ICU 2.1
343
+ */
344
+ ULOC_VALID_LOCALE = 1,
345
+
346
+ #ifndef U_HIDE_DEPRECATED_API
347
+ /** This is the requested locale
348
+ * @deprecated ICU 2.8
349
+ */
350
+ ULOC_REQUESTED_LOCALE = 2,
351
+ #endif /* U_HIDE_DEPRECATED_API */
352
+
353
+ ULOC_DATA_LOCALE_TYPE_LIMIT = 3
354
+ } ULocDataLocaleType ;
355
+
356
+ #ifndef U_HIDE_SYSTEM_API
357
+ /**
358
+ * Gets ICU's default locale.
359
+ * The returned string is a snapshot in time, and will remain valid
360
+ * and unchanged even when uloc_setDefault() is called.
361
+ * The returned storage is owned by ICU, and must not be altered or deleted
362
+ * by the caller.
363
+ *
364
+ * @return the ICU default locale
365
+ * @system
366
+ * @stable ICU 2.0
367
+ */
368
+ U_STABLE const char* U_EXPORT2
369
+ uloc_getDefault(void);
370
+
371
+ /**
372
+ * Sets ICU's default locale.
373
+ * By default (without calling this function), ICU's default locale will be based
374
+ * on information obtained from the underlying system environment.
375
+ * <p>
376
+ * Changes to ICU's default locale do not propagate back to the
377
+ * system environment.
378
+ * <p>
379
+ * Changes to ICU's default locale to not affect any ICU services that
380
+ * may already be open based on the previous default locale value.
381
+ *
382
+ * @param localeID the new ICU default locale. A value of NULL will try to get
383
+ * the system's default locale.
384
+ * @param status the error information if the setting of default locale fails
385
+ * @system
386
+ * @stable ICU 2.0
387
+ */
388
+ U_STABLE void U_EXPORT2
389
+ uloc_setDefault(const char* localeID,
390
+ UErrorCode* status);
391
+ #endif /* U_HIDE_SYSTEM_API */
392
+
393
+ /**
394
+ * Gets the language code for the specified locale.
395
+ *
396
+ * @param localeID the locale to get the ISO language code with
397
+ * @param language the language code for localeID
398
+ * @param languageCapacity the size of the language buffer to store the
399
+ * language code with
400
+ * @param err error information if retrieving the language code failed
401
+ * @return the actual buffer size needed for the language code. If it's greater
402
+ * than languageCapacity, the returned language code will be truncated.
403
+ * @stable ICU 2.0
404
+ */
405
+ U_STABLE int32_t U_EXPORT2
406
+ uloc_getLanguage(const char* localeID,
407
+ char* language,
408
+ int32_t languageCapacity,
409
+ UErrorCode* err);
410
+
411
+ /**
412
+ * Gets the script code for the specified locale.
413
+ *
414
+ * @param localeID the locale to get the ISO language code with
415
+ * @param script the language code for localeID
416
+ * @param scriptCapacity the size of the language buffer to store the
417
+ * language code with
418
+ * @param err error information if retrieving the language code failed
419
+ * @return the actual buffer size needed for the language code. If it's greater
420
+ * than scriptCapacity, the returned language code will be truncated.
421
+ * @stable ICU 2.8
422
+ */
423
+ U_STABLE int32_t U_EXPORT2
424
+ uloc_getScript(const char* localeID,
425
+ char* script,
426
+ int32_t scriptCapacity,
427
+ UErrorCode* err);
428
+
429
+ /**
430
+ * Gets the country code for the specified locale.
431
+ *
432
+ * @param localeID the locale to get the country code with
433
+ * @param country the country code for localeID
434
+ * @param countryCapacity the size of the country buffer to store the
435
+ * country code with
436
+ * @param err error information if retrieving the country code failed
437
+ * @return the actual buffer size needed for the country code. If it's greater
438
+ * than countryCapacity, the returned country code will be truncated.
439
+ * @stable ICU 2.0
440
+ */
441
+ U_STABLE int32_t U_EXPORT2
442
+ uloc_getCountry(const char* localeID,
443
+ char* country,
444
+ int32_t countryCapacity,
445
+ UErrorCode* err);
446
+
447
+ /**
448
+ * Gets the variant code for the specified locale.
449
+ *
450
+ * @param localeID the locale to get the variant code with
451
+ * @param variant the variant code for localeID
452
+ * @param variantCapacity the size of the variant buffer to store the
453
+ * variant code with
454
+ * @param err error information if retrieving the variant code failed
455
+ * @return the actual buffer size needed for the variant code. If it's greater
456
+ * than variantCapacity, the returned variant code will be truncated.
457
+ * @stable ICU 2.0
458
+ */
459
+ U_STABLE int32_t U_EXPORT2
460
+ uloc_getVariant(const char* localeID,
461
+ char* variant,
462
+ int32_t variantCapacity,
463
+ UErrorCode* err);
464
+
465
+
466
+ /**
467
+ * Gets the full name for the specified locale.
468
+ * Note: This has the effect of 'canonicalizing' the ICU locale ID to
469
+ * a certain extent. Upper and lower case are set as needed.
470
+ * It does NOT map aliased names in any way.
471
+ * See the top of this header file.
472
+ * This API supports preflighting.
473
+ *
474
+ * @param localeID the locale to get the full name with
475
+ * @param name fill in buffer for the name without keywords.
476
+ * @param nameCapacity capacity of the fill in buffer.
477
+ * @param err error information if retrieving the full name failed
478
+ * @return the actual buffer size needed for the full name. If it's greater
479
+ * than nameCapacity, the returned full name will be truncated.
480
+ * @stable ICU 2.0
481
+ */
482
+ U_STABLE int32_t U_EXPORT2
483
+ uloc_getName(const char* localeID,
484
+ char* name,
485
+ int32_t nameCapacity,
486
+ UErrorCode* err);
487
+
488
+ /**
489
+ * Gets the full name for the specified locale.
490
+ * Note: This has the effect of 'canonicalizing' the string to
491
+ * a certain extent. Upper and lower case are set as needed,
492
+ * and if the components were in 'POSIX' format they are changed to
493
+ * ICU format. It does NOT map aliased names in any way.
494
+ * See the top of this header file.
495
+ *
496
+ * @param localeID the locale to get the full name with
497
+ * @param name the full name for localeID
498
+ * @param nameCapacity the size of the name buffer to store the
499
+ * full name with
500
+ * @param err error information if retrieving the full name failed
501
+ * @return the actual buffer size needed for the full name. If it's greater
502
+ * than nameCapacity, the returned full name will be truncated.
503
+ * @stable ICU 2.8
504
+ */
505
+ U_STABLE int32_t U_EXPORT2
506
+ uloc_canonicalize(const char* localeID,
507
+ char* name,
508
+ int32_t nameCapacity,
509
+ UErrorCode* err);
510
+
511
+ /**
512
+ * Gets the ISO language code for the specified locale.
513
+ *
514
+ * @param localeID the locale to get the ISO language code with
515
+ * @return language the ISO language code for localeID
516
+ * @stable ICU 2.0
517
+ */
518
+ U_STABLE const char* U_EXPORT2
519
+ uloc_getISO3Language(const char* localeID);
520
+
521
+
522
+ /**
523
+ * Gets the ISO country code for the specified locale.
524
+ *
525
+ * @param localeID the locale to get the ISO country code with
526
+ * @return country the ISO country code for localeID
527
+ * @stable ICU 2.0
528
+ */
529
+ U_STABLE const char* U_EXPORT2
530
+ uloc_getISO3Country(const char* localeID);
531
+
532
+ /**
533
+ * Gets the Win32 LCID value for the specified locale.
534
+ * If the ICU locale is not recognized by Windows, 0 will be returned.
535
+ *
536
+ * @param localeID the locale to get the Win32 LCID value with
537
+ * @return country the Win32 LCID for localeID
538
+ * @stable ICU 2.0
539
+ */
540
+ U_STABLE uint32_t U_EXPORT2
541
+ uloc_getLCID(const char* localeID);
542
+
543
+ /**
544
+ * Gets the language name suitable for display for the specified locale.
545
+ *
546
+ * @param locale the locale to get the ISO language code with
547
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
548
+ * if the locale's language code is "en", passing Locale::getFrench() for
549
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
550
+ * for inLocale would result in "Englisch".
551
+ * @param language the displayable language code for localeID
552
+ * @param languageCapacity the size of the language buffer to store the
553
+ * displayable language code with
554
+ * @param status error information if retrieving the displayable language code failed
555
+ * @return the actual buffer size needed for the displayable language code. If it's greater
556
+ * than languageCapacity, the returned language code will be truncated.
557
+ * @stable ICU 2.0
558
+ */
559
+ U_STABLE int32_t U_EXPORT2
560
+ uloc_getDisplayLanguage(const char* locale,
561
+ const char* displayLocale,
562
+ UChar* language,
563
+ int32_t languageCapacity,
564
+ UErrorCode* status);
565
+
566
+ /**
567
+ * Gets the script name suitable for display for the specified locale.
568
+ *
569
+ * @param locale the locale to get the displayable script code with. NULL may be used to specify the default.
570
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
571
+ * if the locale's language code is "en", passing Locale::getFrench() for
572
+ * inLocale would result in "", while passing Locale::getGerman()
573
+ * for inLocale would result in "". NULL may be used to specify the default.
574
+ * @param script the displayable country code for localeID
575
+ * @param scriptCapacity the size of the script buffer to store the
576
+ * displayable script code with
577
+ * @param status error information if retrieving the displayable script code failed
578
+ * @return the actual buffer size needed for the displayable script code. If it's greater
579
+ * than scriptCapacity, the returned displayable script code will be truncated.
580
+ * @stable ICU 2.8
581
+ */
582
+ U_STABLE int32_t U_EXPORT2
583
+ uloc_getDisplayScript(const char* locale,
584
+ const char* displayLocale,
585
+ UChar* script,
586
+ int32_t scriptCapacity,
587
+ UErrorCode* status);
588
+
589
+ /**
590
+ * Gets the country name suitable for display for the specified locale.
591
+ *
592
+ * @param locale the locale to get the displayable country code with. NULL may be used to specify the default.
593
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
594
+ * if the locale's language code is "en", passing Locale::getFrench() for
595
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
596
+ * for inLocale would result in "Englisch". NULL may be used to specify the default.
597
+ * @param country the displayable country code for localeID
598
+ * @param countryCapacity the size of the country buffer to store the
599
+ * displayable country code with
600
+ * @param status error information if retrieving the displayable country code failed
601
+ * @return the actual buffer size needed for the displayable country code. If it's greater
602
+ * than countryCapacity, the returned displayable country code will be truncated.
603
+ * @stable ICU 2.0
604
+ */
605
+ U_STABLE int32_t U_EXPORT2
606
+ uloc_getDisplayCountry(const char* locale,
607
+ const char* displayLocale,
608
+ UChar* country,
609
+ int32_t countryCapacity,
610
+ UErrorCode* status);
611
+
612
+
613
+ /**
614
+ * Gets the variant name suitable for display for the specified locale.
615
+ *
616
+ * @param locale the locale to get the displayable variant code with. NULL may be used to specify the default.
617
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
618
+ * if the locale's language code is "en", passing Locale::getFrench() for
619
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
620
+ * for inLocale would result in "Englisch". NULL may be used to specify the default.
621
+ * @param variant the displayable variant code for localeID
622
+ * @param variantCapacity the size of the variant buffer to store the
623
+ * displayable variant code with
624
+ * @param status error information if retrieving the displayable variant code failed
625
+ * @return the actual buffer size needed for the displayable variant code. If it's greater
626
+ * than variantCapacity, the returned displayable variant code will be truncated.
627
+ * @stable ICU 2.0
628
+ */
629
+ U_STABLE int32_t U_EXPORT2
630
+ uloc_getDisplayVariant(const char* locale,
631
+ const char* displayLocale,
632
+ UChar* variant,
633
+ int32_t variantCapacity,
634
+ UErrorCode* status);
635
+
636
+ /**
637
+ * Gets the keyword name suitable for display for the specified locale.
638
+ * E.g: for the locale string de_DE\@collation=PHONEBOOK, this API gets the display
639
+ * string for the keyword collation.
640
+ * Usage:
641
+ * <code>
642
+ * UErrorCode status = U_ZERO_ERROR;
643
+ * const char* keyword =NULL;
644
+ * int32_t keywordLen = 0;
645
+ * int32_t keywordCount = 0;
646
+ * UChar displayKeyword[256];
647
+ * int32_t displayKeywordLen = 0;
648
+ * UEnumeration* keywordEnum = uloc_openKeywords("de_DE@collation=PHONEBOOK;calendar=TRADITIONAL", &status);
649
+ * for(keywordCount = uenum_count(keywordEnum, &status); keywordCount > 0 ; keywordCount--){
650
+ * if(U_FAILURE(status)){
651
+ * ...something went wrong so handle the error...
652
+ * break;
653
+ * }
654
+ * // the uenum_next returns NUL terminated string
655
+ * keyword = uenum_next(keywordEnum, &keywordLen, &status);
656
+ * displayKeywordLen = uloc_getDisplayKeyword(keyword, "en_US", displayKeyword, 256);
657
+ * ... do something interesting .....
658
+ * }
659
+ * uenum_close(keywordEnum);
660
+ * </code>
661
+ * @param keyword The keyword whose display string needs to be returned.
662
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
663
+ * if the locale's language code is "en", passing Locale::getFrench() for
664
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
665
+ * for inLocale would result in "Englisch". NULL may be used to specify the default.
666
+ * @param dest the buffer to which the displayable keyword should be written.
667
+ * @param destCapacity The size of the buffer (number of UChars). If it is 0, then
668
+ * dest may be NULL and the function will only return the length of the
669
+ * result without writing any of the result string (pre-flighting).
670
+ * @param status error information if retrieving the displayable string failed.
671
+ * Should not be NULL and should not indicate failure on entry.
672
+ * @return the actual buffer size needed for the displayable variant code.
673
+ * @see #uloc_openKeywords
674
+ * @stable ICU 2.8
675
+ */
676
+ U_STABLE int32_t U_EXPORT2
677
+ uloc_getDisplayKeyword(const char* keyword,
678
+ const char* displayLocale,
679
+ UChar* dest,
680
+ int32_t destCapacity,
681
+ UErrorCode* status);
682
+ /**
683
+ * Gets the value of the keyword suitable for display for the specified locale.
684
+ * E.g: for the locale string de_DE\@collation=PHONEBOOK, this API gets the display
685
+ * string for PHONEBOOK, in the display locale, when "collation" is specified as the keyword.
686
+ *
687
+ * @param locale The locale to get the displayable variant code with. NULL may be used to specify the default.
688
+ * @param keyword The keyword for whose value should be used.
689
+ * @param displayLocale Specifies the locale to be used to display the name. In other words,
690
+ * if the locale's language code is "en", passing Locale::getFrench() for
691
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
692
+ * for inLocale would result in "Englisch". NULL may be used to specify the default.
693
+ * @param dest the buffer to which the displayable keyword should be written.
694
+ * @param destCapacity The size of the buffer (number of UChars). If it is 0, then
695
+ * dest may be NULL and the function will only return the length of the
696
+ * result without writing any of the result string (pre-flighting).
697
+ * @param status error information if retrieving the displayable string failed.
698
+ * Should not be NULL and must not indicate failure on entry.
699
+ * @return the actual buffer size needed for the displayable variant code.
700
+ * @stable ICU 2.8
701
+ */
702
+ U_STABLE int32_t U_EXPORT2
703
+ uloc_getDisplayKeywordValue( const char* locale,
704
+ const char* keyword,
705
+ const char* displayLocale,
706
+ UChar* dest,
707
+ int32_t destCapacity,
708
+ UErrorCode* status);
709
+ /**
710
+ * Gets the full name suitable for display for the specified locale.
711
+ *
712
+ * @param localeID the locale to get the displayable name with. NULL may be used to specify the default.
713
+ * @param inLocaleID Specifies the locale to be used to display the name. In other words,
714
+ * if the locale's language code is "en", passing Locale::getFrench() for
715
+ * inLocale would result in "Anglais", while passing Locale::getGerman()
716
+ * for inLocale would result in "Englisch". NULL may be used to specify the default.
717
+ * @param result the displayable name for localeID
718
+ * @param maxResultSize the size of the name buffer to store the
719
+ * displayable full name with
720
+ * @param err error information if retrieving the displayable name failed
721
+ * @return the actual buffer size needed for the displayable name. If it's greater
722
+ * than maxResultSize, the returned displayable name will be truncated.
723
+ * @stable ICU 2.0
724
+ */
725
+ U_STABLE int32_t U_EXPORT2
726
+ uloc_getDisplayName(const char* localeID,
727
+ const char* inLocaleID,
728
+ UChar* result,
729
+ int32_t maxResultSize,
730
+ UErrorCode* err);
731
+
732
+
733
+ /**
734
+ * Gets the specified locale from a list of all available locales.
735
+ * The return value is a pointer to an item of
736
+ * a locale name array. Both this array and the pointers
737
+ * it contains are owned by ICU and should not be deleted or written through
738
+ * by the caller. The locale name is terminated by a null pointer.
739
+ * @param n the specific locale name index of the available locale list
740
+ * @return a specified locale name of all available locales
741
+ * @stable ICU 2.0
742
+ */
743
+ U_STABLE const char* U_EXPORT2
744
+ uloc_getAvailable(int32_t n);
745
+
746
+ /**
747
+ * Gets the size of the all available locale list.
748
+ *
749
+ * @return the size of the locale list
750
+ * @stable ICU 2.0
751
+ */
752
+ U_STABLE int32_t U_EXPORT2 uloc_countAvailable(void);
753
+
754
+ /**
755
+ *
756
+ * Gets a list of all available 2-letter language codes defined in ISO 639,
757
+ * plus additional 3-letter codes determined to be useful for locale generation as
758
+ * defined by Unicode CLDR. This is a pointer
759
+ * to an array of pointers to arrays of char. All of these pointers are owned
760
+ * by ICU-- do not delete them, and do not write through them. The array is
761
+ * terminated with a null pointer.
762
+ * @return a list of all available language codes
763
+ * @stable ICU 2.0
764
+ */
765
+ U_STABLE const char* const* U_EXPORT2
766
+ uloc_getISOLanguages(void);
767
+
768
+ /**
769
+ *
770
+ * Gets a list of all available 2-letter country codes defined in ISO 639. This is a
771
+ * pointer to an array of pointers to arrays of char. All of these pointers are
772
+ * owned by ICU-- do not delete them, and do not write through them. The array is
773
+ * terminated with a null pointer.
774
+ * @return a list of all available country codes
775
+ * @stable ICU 2.0
776
+ */
777
+ U_STABLE const char* const* U_EXPORT2
778
+ uloc_getISOCountries(void);
779
+
780
+ /**
781
+ * Truncate the locale ID string to get the parent locale ID.
782
+ * Copies the part of the string before the last underscore.
783
+ * The parent locale ID will be an empty string if there is no
784
+ * underscore, or if there is only one underscore at localeID[0].
785
+ *
786
+ * @param localeID Input locale ID string.
787
+ * @param parent Output string buffer for the parent locale ID.
788
+ * @param parentCapacity Size of the output buffer.
789
+ * @param err A UErrorCode value.
790
+ * @return The length of the parent locale ID.
791
+ * @stable ICU 2.0
792
+ */
793
+ U_STABLE int32_t U_EXPORT2
794
+ uloc_getParent(const char* localeID,
795
+ char* parent,
796
+ int32_t parentCapacity,
797
+ UErrorCode* err);
798
+
799
+
800
+
801
+
802
+ /**
803
+ * Gets the full name for the specified locale, like uloc_getName(),
804
+ * but without keywords.
805
+ *
806
+ * Note: This has the effect of 'canonicalizing' the string to
807
+ * a certain extent. Upper and lower case are set as needed,
808
+ * and if the components were in 'POSIX' format they are changed to
809
+ * ICU format. It does NOT map aliased names in any way.
810
+ * See the top of this header file.
811
+ *
812
+ * This API strips off the keyword part, so "de_DE\@collation=phonebook"
813
+ * will become "de_DE".
814
+ * This API supports preflighting.
815
+ *
816
+ * @param localeID the locale to get the full name with
817
+ * @param name fill in buffer for the name without keywords.
818
+ * @param nameCapacity capacity of the fill in buffer.
819
+ * @param err error information if retrieving the full name failed
820
+ * @return the actual buffer size needed for the full name. If it's greater
821
+ * than nameCapacity, the returned full name will be truncated.
822
+ * @stable ICU 2.8
823
+ */
824
+ U_STABLE int32_t U_EXPORT2
825
+ uloc_getBaseName(const char* localeID,
826
+ char* name,
827
+ int32_t nameCapacity,
828
+ UErrorCode* err);
829
+
830
+ /**
831
+ * Gets an enumeration of keywords for the specified locale. Enumeration
832
+ * must get disposed of by the client using uenum_close function.
833
+ *
834
+ * @param localeID the locale to get the variant code with
835
+ * @param status error information if retrieving the keywords failed
836
+ * @return enumeration of keywords or NULL if there are no keywords.
837
+ * @stable ICU 2.8
838
+ */
839
+ U_STABLE UEnumeration* U_EXPORT2
840
+ uloc_openKeywords(const char* localeID,
841
+ UErrorCode* status);
842
+
843
+ /**
844
+ * Get the value for a keyword. Locale name does not need to be normalized.
845
+ *
846
+ * @param localeID locale name containing the keyword ("de_DE@currency=EURO;collation=PHONEBOOK")
847
+ * @param keywordName name of the keyword for which we want the value. Case insensitive.
848
+ * @param buffer receiving buffer
849
+ * @param bufferCapacity capacity of receiving buffer
850
+ * @param status containing error code - buffer not big enough.
851
+ * @return the length of keyword value
852
+ * @stable ICU 2.8
853
+ */
854
+ U_STABLE int32_t U_EXPORT2
855
+ uloc_getKeywordValue(const char* localeID,
856
+ const char* keywordName,
857
+ char* buffer, int32_t bufferCapacity,
858
+ UErrorCode* status);
859
+
860
+
861
+ /**
862
+ * Sets or removes the value of the specified keyword.
863
+ *
864
+ * For removing all keywords, use uloc_getBaseName().
865
+ *
866
+ * NOTE: Unlike almost every other ICU function which takes a
867
+ * buffer, this function will NOT truncate the output text. If a
868
+ * BUFFER_OVERFLOW_ERROR is received, it means that the original
869
+ * buffer is untouched. This is done to prevent incorrect or possibly
870
+ * even malformed locales from being generated and used.
871
+ *
872
+ * @param keywordName name of the keyword to be set. Case insensitive.
873
+ * @param keywordValue value of the keyword to be set. If 0-length or
874
+ * NULL, will result in the keyword being removed. No error is given if
875
+ * that keyword does not exist.
876
+ * @param buffer input buffer containing locale to be modified.
877
+ * @param bufferCapacity capacity of receiving buffer
878
+ * @param status containing error code - buffer not big enough.
879
+ * @return the length needed for the buffer
880
+ * @see uloc_getKeywordValue
881
+ * @stable ICU 3.2
882
+ */
883
+ U_STABLE int32_t U_EXPORT2
884
+ uloc_setKeywordValue(const char* keywordName,
885
+ const char* keywordValue,
886
+ char* buffer, int32_t bufferCapacity,
887
+ UErrorCode* status);
888
+
889
+ #ifndef U_HIDE_DRAFT_API
890
+ /**
891
+ * Returns whether the locale's script is written right-to-left.
892
+ * If there is no script subtag, then the likely script is used, see uloc_addLikelySubtags().
893
+ * If no likely script is known, then FALSE is returned.
894
+ *
895
+ * A script is right-to-left according to the CLDR script metadata
896
+ * which corresponds to whether the script's letters have Bidi_Class=R or AL.
897
+ *
898
+ * Returns TRUE for "ar" and "en-Hebr", FALSE for "zh" and "fa-Cyrl".
899
+ *
900
+ * @param locale input locale ID
901
+ * @return TRUE if the locale's script is written right-to-left
902
+ * @draft ICU 54
903
+ */
904
+ U_DRAFT UBool U_EXPORT2
905
+ uloc_isRightToLeft(const char *locale);
906
+ #endif /* U_HIDE_DRAFT_API */
907
+
908
+ /**
909
+ * enums for the return value for the character and line orientation
910
+ * functions.
911
+ * @stable ICU 4.0
912
+ */
913
+ typedef enum {
914
+ ULOC_LAYOUT_LTR = 0, /* left-to-right. */
915
+ ULOC_LAYOUT_RTL = 1, /* right-to-left. */
916
+ ULOC_LAYOUT_TTB = 2, /* top-to-bottom. */
917
+ ULOC_LAYOUT_BTT = 3, /* bottom-to-top. */
918
+ ULOC_LAYOUT_UNKNOWN
919
+ } ULayoutType;
920
+
921
+ /**
922
+ * Get the layout character orientation for the specified locale.
923
+ *
924
+ * @param localeId locale name
925
+ * @param status Error status
926
+ * @return an enum indicating the layout orientation for characters.
927
+ * @stable ICU 4.0
928
+ */
929
+ U_STABLE ULayoutType U_EXPORT2
930
+ uloc_getCharacterOrientation(const char* localeId,
931
+ UErrorCode *status);
932
+
933
+ /**
934
+ * Get the layout line orientation for the specified locale.
935
+ *
936
+ * @param localeId locale name
937
+ * @param status Error status
938
+ * @return an enum indicating the layout orientation for lines.
939
+ * @stable ICU 4.0
940
+ */
941
+ U_STABLE ULayoutType U_EXPORT2
942
+ uloc_getLineOrientation(const char* localeId,
943
+ UErrorCode *status);
944
+
945
+ /**
946
+ * enums for the 'outResult' parameter return value
947
+ * @see uloc_acceptLanguageFromHTTP
948
+ * @see uloc_acceptLanguage
949
+ * @stable ICU 3.2
950
+ */
951
+ typedef enum {
952
+ ULOC_ACCEPT_FAILED = 0, /* No exact match was found. */
953
+ ULOC_ACCEPT_VALID = 1, /* An exact match was found. */
954
+ ULOC_ACCEPT_FALLBACK = 2 /* A fallback was found, for example,
955
+ Accept list contained 'ja_JP'
956
+ which matched available locale 'ja'. */
957
+ } UAcceptResult;
958
+
959
+
960
+ /**
961
+ * Based on a HTTP header from a web browser and a list of available locales,
962
+ * determine an acceptable locale for the user.
963
+ * @param result - buffer to accept the result locale
964
+ * @param resultAvailable the size of the result buffer.
965
+ * @param outResult - An out parameter that contains the fallback status
966
+ * @param httpAcceptLanguage - "Accept-Language:" header as per HTTP.
967
+ * @param availableLocales - list of available locales to match
968
+ * @param status Error status, may be BUFFER_OVERFLOW_ERROR
969
+ * @return length needed for the locale.
970
+ * @stable ICU 3.2
971
+ */
972
+ U_STABLE int32_t U_EXPORT2
973
+ uloc_acceptLanguageFromHTTP(char *result, int32_t resultAvailable,
974
+ UAcceptResult *outResult,
975
+ const char *httpAcceptLanguage,
976
+ UEnumeration* availableLocales,
977
+ UErrorCode *status);
978
+
979
+ /**
980
+ * Based on a list of available locales,
981
+ * determine an acceptable locale for the user.
982
+ * @param result - buffer to accept the result locale
983
+ * @param resultAvailable the size of the result buffer.
984
+ * @param outResult - An out parameter that contains the fallback status
985
+ * @param acceptList - list of acceptable languages
986
+ * @param acceptListCount - count of acceptList items
987
+ * @param availableLocales - list of available locales to match
988
+ * @param status Error status, may be BUFFER_OVERFLOW_ERROR
989
+ * @return length needed for the locale.
990
+ * @stable ICU 3.2
991
+ */
992
+ U_STABLE int32_t U_EXPORT2
993
+ uloc_acceptLanguage(char *result, int32_t resultAvailable,
994
+ UAcceptResult *outResult, const char **acceptList,
995
+ int32_t acceptListCount,
996
+ UEnumeration* availableLocales,
997
+ UErrorCode *status);
998
+
999
+
1000
+ /**
1001
+ * Gets the ICU locale ID for the specified Win32 LCID value.
1002
+ *
1003
+ * @param hostID the Win32 LCID to translate
1004
+ * @param locale the output buffer for the ICU locale ID, which will be NUL-terminated
1005
+ * if there is room.
1006
+ * @param localeCapacity the size of the output buffer
1007
+ * @param status an error is returned if the LCID is unrecognized or the output buffer
1008
+ * is too small
1009
+ * @return actual the actual size of the locale ID, not including NUL-termination
1010
+ * @stable ICU 3.8
1011
+ */
1012
+ U_STABLE int32_t U_EXPORT2
1013
+ uloc_getLocaleForLCID(uint32_t hostID, char *locale, int32_t localeCapacity,
1014
+ UErrorCode *status);
1015
+
1016
+
1017
+ /**
1018
+ * Add the likely subtags for a provided locale ID, per the algorithm described
1019
+ * in the following CLDR technical report:
1020
+ *
1021
+ * http://www.unicode.org/reports/tr35/#Likely_Subtags
1022
+ *
1023
+ * If localeID is already in the maximal form, or there is no data available
1024
+ * for maximization, it will be copied to the output buffer. For example,
1025
+ * "und-Zzzz" cannot be maximized, since there is no reasonable maximization.
1026
+ *
1027
+ * Examples:
1028
+ *
1029
+ * "en" maximizes to "en_Latn_US"
1030
+ *
1031
+ * "de" maximizes to "de_Latn_US"
1032
+ *
1033
+ * "sr" maximizes to "sr_Cyrl_RS"
1034
+ *
1035
+ * "sh" maximizes to "sr_Latn_RS" (Note this will not reverse.)
1036
+ *
1037
+ * "zh_Hani" maximizes to "zh_Hans_CN" (Note this will not reverse.)
1038
+ *
1039
+ * @param localeID The locale to maximize
1040
+ * @param maximizedLocaleID The maximized locale
1041
+ * @param maximizedLocaleIDCapacity The capacity of the maximizedLocaleID buffer
1042
+ * @param err Error information if maximizing the locale failed. If the length
1043
+ * of the localeID and the null-terminator is greater than the maximum allowed size,
1044
+ * or the localeId is not well-formed, the error code is U_ILLEGAL_ARGUMENT_ERROR.
1045
+ * @return The actual buffer size needed for the maximized locale. If it's
1046
+ * greater than maximizedLocaleIDCapacity, the returned ID will be truncated.
1047
+ * On error, the return value is -1.
1048
+ * @stable ICU 4.0
1049
+ */
1050
+ U_STABLE int32_t U_EXPORT2
1051
+ uloc_addLikelySubtags(const char* localeID,
1052
+ char* maximizedLocaleID,
1053
+ int32_t maximizedLocaleIDCapacity,
1054
+ UErrorCode* err);
1055
+
1056
+
1057
+ /**
1058
+ * Minimize the subtags for a provided locale ID, per the algorithm described
1059
+ * in the following CLDR technical report:
1060
+ *
1061
+ * http://www.unicode.org/reports/tr35/#Likely_Subtags
1062
+ *
1063
+ * If localeID is already in the minimal form, or there is no data available
1064
+ * for minimization, it will be copied to the output buffer. Since the
1065
+ * minimization algorithm relies on proper maximization, see the comments
1066
+ * for uloc_addLikelySubtags for reasons why there might not be any data.
1067
+ *
1068
+ * Examples:
1069
+ *
1070
+ * "en_Latn_US" minimizes to "en"
1071
+ *
1072
+ * "de_Latn_US" minimizes to "de"
1073
+ *
1074
+ * "sr_Cyrl_RS" minimizes to "sr"
1075
+ *
1076
+ * "zh_Hant_TW" minimizes to "zh_TW" (The region is preferred to the
1077
+ * script, and minimizing to "zh" would imply "zh_Hans_CN".)
1078
+ *
1079
+ * @param localeID The locale to minimize
1080
+ * @param minimizedLocaleID The minimized locale
1081
+ * @param minimizedLocaleIDCapacity The capacity of the minimizedLocaleID buffer
1082
+ * @param err Error information if minimizing the locale failed. If the length
1083
+ * of the localeID and the null-terminator is greater than the maximum allowed size,
1084
+ * or the localeId is not well-formed, the error code is U_ILLEGAL_ARGUMENT_ERROR.
1085
+ * @return The actual buffer size needed for the minimized locale. If it's
1086
+ * greater than minimizedLocaleIDCapacity, the returned ID will be truncated.
1087
+ * On error, the return value is -1.
1088
+ * @stable ICU 4.0
1089
+ */
1090
+ U_STABLE int32_t U_EXPORT2
1091
+ uloc_minimizeSubtags(const char* localeID,
1092
+ char* minimizedLocaleID,
1093
+ int32_t minimizedLocaleIDCapacity,
1094
+ UErrorCode* err);
1095
+
1096
+ /**
1097
+ * Returns a locale ID for the specified BCP47 language tag string.
1098
+ * If the specified language tag contains any ill-formed subtags,
1099
+ * the first such subtag and all following subtags are ignored.
1100
+ * <p>
1101
+ * This implements the 'Language-Tag' production of BCP47, and so
1102
+ * supports grandfathered (regular and irregular) as well as private
1103
+ * use language tags. Private use tags are represented as 'x-whatever',
1104
+ * and grandfathered tags are converted to their canonical replacements
1105
+ * where they exist. Note that a few grandfathered tags have no modern
1106
+ * replacement, these will be converted using the fallback described in
1107
+ * the first paragraph, so some information might be lost.
1108
+ * @param langtag the input BCP47 language tag.
1109
+ * @param localeID the output buffer receiving a locale ID for the
1110
+ * specified BCP47 language tag.
1111
+ * @param localeIDCapacity the size of the locale ID output buffer.
1112
+ * @param parsedLength if not NULL, successfully parsed length
1113
+ * for the input language tag is set.
1114
+ * @param err error information if receiving the locald ID
1115
+ * failed.
1116
+ * @return the length of the locale ID.
1117
+ * @stable ICU 4.2
1118
+ */
1119
+ U_STABLE int32_t U_EXPORT2
1120
+ uloc_forLanguageTag(const char* langtag,
1121
+ char* localeID,
1122
+ int32_t localeIDCapacity,
1123
+ int32_t* parsedLength,
1124
+ UErrorCode* err);
1125
+
1126
+ /**
1127
+ * Returns a well-formed language tag for this locale ID.
1128
+ * <p>
1129
+ * <b>Note</b>: When <code>strict</code> is FALSE, any locale
1130
+ * fields which do not satisfy the BCP47 syntax requirement will
1131
+ * be omitted from the result. When <code>strict</code> is
1132
+ * TRUE, this function sets U_ILLEGAL_ARGUMENT_ERROR to the
1133
+ * <code>err</code> if any locale fields do not satisfy the
1134
+ * BCP47 syntax requirement.
1135
+ * @param localeID the input locale ID
1136
+ * @param langtag the output buffer receiving BCP47 language
1137
+ * tag for the locale ID.
1138
+ * @param langtagCapacity the size of the BCP47 language tag
1139
+ * output buffer.
1140
+ * @param strict boolean value indicating if the function returns
1141
+ * an error for an ill-formed input locale ID.
1142
+ * @param err error information if receiving the language
1143
+ * tag failed.
1144
+ * @return The length of the BCP47 language tag.
1145
+ * @stable ICU 4.2
1146
+ */
1147
+ U_STABLE int32_t U_EXPORT2
1148
+ uloc_toLanguageTag(const char* localeID,
1149
+ char* langtag,
1150
+ int32_t langtagCapacity,
1151
+ UBool strict,
1152
+ UErrorCode* err);
1153
+
1154
+ #ifndef U_HIDE_DRAFT_API
1155
+ /**
1156
+ * Converts the specified keyword (legacy key, or BCP 47 Unicode locale
1157
+ * extension key) to the equivalent BCP 47 Unicode locale extension key.
1158
+ * For example, BCP 47 Unicode locale extension key "co" is returned for
1159
+ * the input keyword "collation".
1160
+ * <p>
1161
+ * When the specified keyword is unknown, but satisfies the BCP syntax,
1162
+ * then the pointer to the input keyword itself will be returned.
1163
+ * For example,
1164
+ * <code>uloc_toUnicodeLocaleKey("ZZ")</code> returns "ZZ".
1165
+ *
1166
+ * @param keyword the input locale keyword (either legacy key
1167
+ * such as "collation" or BCP 47 Unicode locale extension
1168
+ * key such as "co").
1169
+ * @return the well-formed BCP 47 Unicode locale extension key,
1170
+ * or NULL if the specified locale keyword cannot be
1171
+ * mapped to a well-formed BCP 47 Unicode locale extension
1172
+ * key.
1173
+ * @see uloc_toLegacyKey
1174
+ * @draft ICU 54
1175
+ */
1176
+ U_DRAFT const char* U_EXPORT2
1177
+ uloc_toUnicodeLocaleKey(const char* keyword);
1178
+
1179
+ /**
1180
+ * Converts the specified keyword value (legacy type, or BCP 47
1181
+ * Unicode locale extension type) to the well-formed BCP 47 Unicode locale
1182
+ * extension type for the specified keyword (category). For example, BCP 47
1183
+ * Unicode locale extension type "phonebk" is returned for the input
1184
+ * keyword value "phonebook", with the keyword "collation" (or "co").
1185
+ * <p>
1186
+ * When the specified keyword is not recognized, but the specified value
1187
+ * satisfies the syntax of the BCP 47 Unicode locale extension type,
1188
+ * or when the specified keyword allows 'variable' type and the specified
1189
+ * value satisfies the syntax, then the pointer to the input type value itself
1190
+ * will be returned.
1191
+ * For example,
1192
+ * <code>uloc_toUnicodeLocaleType("Foo", "Bar")</code> returns "Bar",
1193
+ * <code>uloc_toUnicodeLocaleType("variableTop", "00A4")</code> returns "00A4".
1194
+ *
1195
+ * @param keyword the locale keyword (either legacy key such as
1196
+ * "collation" or BCP 47 Unicode locale extension
1197
+ * key such as "co").
1198
+ * @param value the locale keyword value (either legacy type
1199
+ * such as "phonebook" or BCP 47 Unicode locale extension
1200
+ * type such as "phonebk").
1201
+ * @return the well-formed BCP47 Unicode locale extension type,
1202
+ * or NULL if the locale keyword value cannot be mapped to
1203
+ * a well-formed BCP 47 Unicode locale extension type.
1204
+ * @see uloc_toLegacyType
1205
+ * @draft ICU 54
1206
+ */
1207
+ U_DRAFT const char* U_EXPORT2
1208
+ uloc_toUnicodeLocaleType(const char* keyword, const char* value);
1209
+
1210
+ /**
1211
+ * Converts the specified keyword (BCP 47 Unicode locale extension key, or
1212
+ * legacy key) to the legacy key. For example, legacy key "collation" is
1213
+ * returned for the input BCP 47 Unicode locale extension key "co".
1214
+ *
1215
+ * @param keyword the input locale keyword (either BCP 47 Unicode locale
1216
+ * extension key or legacy key).
1217
+ * @return the well-formed legacy key, or NULL if the specified
1218
+ * keyword cannot be mapped to a well-formed legacy key.
1219
+ * @see toUnicodeLocaleKey
1220
+ * @draft ICU 54
1221
+ */
1222
+ U_DRAFT const char* U_EXPORT2
1223
+ uloc_toLegacyKey(const char* keyword);
1224
+
1225
+ /**
1226
+ * Converts the specified keyword value (BCP 47 Unicode locale extension type,
1227
+ * or legacy type or type alias) to the canonical legacy type. For example,
1228
+ * the legacy type "phonebook" is returned for the input BCP 47 Unicode
1229
+ * locale extension type "phonebk" with the keyword "collation" (or "co").
1230
+ * <p>
1231
+ * When the specified keyword is not recognized, but the specified value
1232
+ * satisfies the syntax of legacy key, or when the specified keyword
1233
+ * allows 'variable' type and the specified value satisfies the syntax,
1234
+ * then the pointer to the input type value itself will be returned.
1235
+ * For example,
1236
+ * <code>uloc_toLegacyType("Foo", "Bar")</code> returns "Bar",
1237
+ * <code>uloc_toLegacyType("vt", "00A4")</code> returns "00A4".
1238
+ *
1239
+ * @param keyword the locale keyword (either legacy keyword such as
1240
+ * "collation" or BCP 47 Unicode locale extension
1241
+ * key such as "co").
1242
+ * @param value the locale keyword value (either BCP 47 Unicode locale
1243
+ * extension type such as "phonebk" or legacy keyword value
1244
+ * such as "phonebook").
1245
+ * @return the well-formed legacy type, or NULL if the specified
1246
+ * keyword value cannot be mapped to a well-formed legacy
1247
+ * type.
1248
+ * @see toUnicodeLocaleType
1249
+ * @draft ICU 54
1250
+ */
1251
+ U_DRAFT const char* U_EXPORT2
1252
+ uloc_toLegacyType(const char* keyword, const char* value);
1253
+
1254
+ #endif /* U_HIDE_DRAFT_API */
1255
+
1256
+ #endif /*_ULOC*/