pango 2.2.0-x86-mingw32 → 2.2.1-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.
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,258 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2009-2011, International Business Machines Corporation and *
4
+ * others. All Rights Reserved. *
5
+ *******************************************************************************
6
+ */
7
+ #ifndef CURRPINF_H
8
+ #define CURRPINF_H
9
+
10
+ #include "unicode/utypes.h"
11
+
12
+ /**
13
+ * \file
14
+ * \brief C++ API: Currency Plural Information used by Decimal Format
15
+ */
16
+
17
+ #if !UCONFIG_NO_FORMATTING
18
+
19
+ #include "unicode/unistr.h"
20
+
21
+ U_NAMESPACE_BEGIN
22
+
23
+ class Locale;
24
+ class PluralRules;
25
+ class Hashtable;
26
+
27
+ /**
28
+ * This class represents the information needed by
29
+ * DecimalFormat to format currency plural,
30
+ * such as "3.00 US dollars" or "1.00 US dollar".
31
+ * DecimalFormat creates for itself an instance of
32
+ * CurrencyPluralInfo from its locale data.
33
+ * If you need to change any of these symbols, you can get the
34
+ * CurrencyPluralInfo object from your
35
+ * DecimalFormat and modify it.
36
+ *
37
+ * Following are the information needed for currency plural format and parse:
38
+ * locale information,
39
+ * plural rule of the locale,
40
+ * currency plural pattern of the locale.
41
+ *
42
+ * @stable ICU 4.2
43
+ */
44
+ class U_I18N_API CurrencyPluralInfo : public UObject {
45
+ public:
46
+
47
+ /**
48
+ * Create a CurrencyPluralInfo object for the default locale.
49
+ * @param status output param set to success/failure code on exit
50
+ * @stable ICU 4.2
51
+ */
52
+ CurrencyPluralInfo(UErrorCode& status);
53
+
54
+ /**
55
+ * Create a CurrencyPluralInfo object for the given locale.
56
+ * @param locale the locale
57
+ * @param status output param set to success/failure code on exit
58
+ * @stable ICU 4.2
59
+ */
60
+ CurrencyPluralInfo(const Locale& locale, UErrorCode& status);
61
+
62
+ /**
63
+ * Copy constructor
64
+ *
65
+ * @stable ICU 4.2
66
+ */
67
+ CurrencyPluralInfo(const CurrencyPluralInfo& info);
68
+
69
+
70
+ /**
71
+ * Assignment operator
72
+ *
73
+ * @stable ICU 4.2
74
+ */
75
+ CurrencyPluralInfo& operator=(const CurrencyPluralInfo& info);
76
+
77
+
78
+ /**
79
+ * Destructor
80
+ *
81
+ * @stable ICU 4.2
82
+ */
83
+ virtual ~CurrencyPluralInfo();
84
+
85
+
86
+ /**
87
+ * Equal operator.
88
+ *
89
+ * @stable ICU 4.2
90
+ */
91
+ UBool operator==(const CurrencyPluralInfo& info) const;
92
+
93
+
94
+ /**
95
+ * Not equal operator
96
+ *
97
+ * @stable ICU 4.2
98
+ */
99
+ UBool operator!=(const CurrencyPluralInfo& info) const;
100
+
101
+
102
+ /**
103
+ * Clone
104
+ *
105
+ * @stable ICU 4.2
106
+ */
107
+ CurrencyPluralInfo* clone() const;
108
+
109
+
110
+ /**
111
+ * Gets plural rules of this locale, used for currency plural format
112
+ *
113
+ * @return plural rule
114
+ * @stable ICU 4.2
115
+ */
116
+ const PluralRules* getPluralRules() const;
117
+
118
+ /**
119
+ * Given a plural count, gets currency plural pattern of this locale,
120
+ * used for currency plural format
121
+ *
122
+ * @param pluralCount currency plural count
123
+ * @param result output param to receive the pattern
124
+ * @return a currency plural pattern based on plural count
125
+ * @stable ICU 4.2
126
+ */
127
+ UnicodeString& getCurrencyPluralPattern(const UnicodeString& pluralCount,
128
+ UnicodeString& result) const;
129
+
130
+ /**
131
+ * Get locale
132
+ *
133
+ * @return locale
134
+ * @stable ICU 4.2
135
+ */
136
+ const Locale& getLocale() const;
137
+
138
+ /**
139
+ * Set plural rules.
140
+ * The plural rule is set when CurrencyPluralInfo
141
+ * instance is created.
142
+ * You can call this method to reset plural rules only if you want
143
+ * to modify the default plural rule of the locale.
144
+ *
145
+ * @param ruleDescription new plural rule description
146
+ * @param status output param set to success/failure code on exit
147
+ * @stable ICU 4.2
148
+ */
149
+ void setPluralRules(const UnicodeString& ruleDescription,
150
+ UErrorCode& status);
151
+
152
+ /**
153
+ * Set currency plural pattern.
154
+ * The currency plural pattern is set when CurrencyPluralInfo
155
+ * instance is created.
156
+ * You can call this method to reset currency plural pattern only if
157
+ * you want to modify the default currency plural pattern of the locale.
158
+ *
159
+ * @param pluralCount the plural count for which the currency pattern will
160
+ * be overridden.
161
+ * @param pattern the new currency plural pattern
162
+ * @param status output param set to success/failure code on exit
163
+ * @stable ICU 4.2
164
+ */
165
+ void setCurrencyPluralPattern(const UnicodeString& pluralCount,
166
+ const UnicodeString& pattern,
167
+ UErrorCode& status);
168
+
169
+ /**
170
+ * Set locale
171
+ *
172
+ * @param loc the new locale to set
173
+ * @param status output param set to success/failure code on exit
174
+ * @stable ICU 4.2
175
+ */
176
+ void setLocale(const Locale& loc, UErrorCode& status);
177
+
178
+ /**
179
+ * ICU "poor man's RTTI", returns a UClassID for the actual class.
180
+ *
181
+ * @stable ICU 4.2
182
+ */
183
+ virtual UClassID getDynamicClassID() const;
184
+
185
+ /**
186
+ * ICU "poor man's RTTI", returns a UClassID for this class.
187
+ *
188
+ * @stable ICU 4.2
189
+ */
190
+ static UClassID U_EXPORT2 getStaticClassID();
191
+
192
+ private:
193
+ friend class DecimalFormat;
194
+
195
+ void initialize(const Locale& loc, UErrorCode& status);
196
+
197
+ void setupCurrencyPluralPattern(const Locale& loc, UErrorCode& status);
198
+
199
+ /*
200
+ * delete hash table
201
+ *
202
+ * @param hTable hash table to be deleted
203
+ */
204
+ void deleteHash(Hashtable* hTable);
205
+
206
+
207
+ /*
208
+ * initialize hash table
209
+ *
210
+ * @param status output param set to success/failure code on exit
211
+ * @return hash table initialized
212
+ */
213
+ Hashtable* initHash(UErrorCode& status);
214
+
215
+
216
+
217
+ /**
218
+ * copy hash table
219
+ *
220
+ * @param source the source to copy from
221
+ * @param target the target to copy to
222
+ * @param status error code
223
+ */
224
+ void copyHash(const Hashtable* source, Hashtable* target, UErrorCode& status);
225
+
226
+ //-------------------- private data member ---------------------
227
+ // map from plural count to currency plural pattern, for example
228
+ // a plural pattern defined in "CurrencyUnitPatterns" is
229
+ // "one{{0} {1}}", in which "one" is a plural count
230
+ // and "{0} {1}" is a currency plural pattern".
231
+ // The currency plural pattern saved in this mapping is the pattern
232
+ // defined in "CurrencyUnitPattern" by replacing
233
+ // {0} with the number format pattern,
234
+ // and {1} with 3 currency sign.
235
+ Hashtable* fPluralCountToCurrencyUnitPattern;
236
+
237
+ /*
238
+ * The plural rule is used to format currency plural name,
239
+ * for example: "3.00 US Dollars".
240
+ * If there are 3 currency signs in the currency patttern,
241
+ * the 3 currency signs will be replaced by currency plural name.
242
+ */
243
+ PluralRules* fPluralRules;
244
+
245
+ // locale
246
+ Locale* fLocale;
247
+ };
248
+
249
+
250
+ inline UBool
251
+ CurrencyPluralInfo::operator!=(const CurrencyPluralInfo& info) const { return !operator==(info); }
252
+
253
+ U_NAMESPACE_END
254
+
255
+ #endif /* #if !UCONFIG_NO_FORMATTING */
256
+
257
+ #endif // _CURRPINFO
258
+ //eof
@@ -0,0 +1,110 @@
1
+ /*
2
+ **********************************************************************
3
+ * Copyright (c) 2004-2014, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ **********************************************************************
6
+ * Author: Alan Liu
7
+ * Created: April 26, 2004
8
+ * Since: ICU 3.0
9
+ **********************************************************************
10
+ */
11
+ #ifndef __CURRENCYUNIT_H__
12
+ #define __CURRENCYUNIT_H__
13
+
14
+ #include "unicode/utypes.h"
15
+
16
+ #if !UCONFIG_NO_FORMATTING
17
+
18
+ #include "unicode/measunit.h"
19
+
20
+ /**
21
+ * \file
22
+ * \brief C++ API: Currency Unit Information.
23
+ */
24
+
25
+ U_NAMESPACE_BEGIN
26
+
27
+ /**
28
+ * A unit of currency, such as USD (U.S. dollars) or JPY (Japanese
29
+ * yen). This class is a thin wrapper over a UChar string that
30
+ * subclasses MeasureUnit, for use with Measure and MeasureFormat.
31
+ *
32
+ * @author Alan Liu
33
+ * @stable ICU 3.0
34
+ */
35
+ class U_I18N_API CurrencyUnit: public MeasureUnit {
36
+ public:
37
+ /**
38
+ * Construct an object with the given ISO currency code.
39
+ * @param isoCode the 3-letter ISO 4217 currency code; must not be
40
+ * NULL and must have length 3
41
+ * @param ec input-output error code. If the isoCode is invalid,
42
+ * then this will be set to a failing value.
43
+ * @stable ICU 3.0
44
+ */
45
+ CurrencyUnit(const UChar* isoCode, UErrorCode &ec);
46
+
47
+ /**
48
+ * Copy constructor
49
+ * @stable ICU 3.0
50
+ */
51
+ CurrencyUnit(const CurrencyUnit& other);
52
+
53
+ /**
54
+ * Assignment operator
55
+ * @stable ICU 3.0
56
+ */
57
+ CurrencyUnit& operator=(const CurrencyUnit& other);
58
+
59
+ /**
60
+ * Return a polymorphic clone of this object. The result will
61
+ * have the same class as returned by getDynamicClassID().
62
+ * @stable ICU 3.0
63
+ */
64
+ virtual UObject* clone() const;
65
+
66
+ /**
67
+ * Destructor
68
+ * @stable ICU 3.0
69
+ */
70
+ virtual ~CurrencyUnit();
71
+
72
+ /**
73
+ * Returns a unique class ID for this object POLYMORPHICALLY.
74
+ * This method implements a simple form of RTTI used by ICU.
75
+ * @return The class ID for this object. All objects of a given
76
+ * class have the same class ID. Objects of other classes have
77
+ * different class IDs.
78
+ * @stable ICU 3.0
79
+ */
80
+ virtual UClassID getDynamicClassID() const;
81
+
82
+ /**
83
+ * Returns the class ID for this class. This is used to compare to
84
+ * the return value of getDynamicClassID().
85
+ * @return The class ID for all objects of this class.
86
+ * @stable ICU 3.0
87
+ */
88
+ static UClassID U_EXPORT2 getStaticClassID();
89
+
90
+ /**
91
+ * Return the ISO currency code of this object.
92
+ * @stable ICU 3.0
93
+ */
94
+ inline const UChar* getISOCurrency() const;
95
+
96
+ private:
97
+ /**
98
+ * The ISO 4217 code of this object.
99
+ */
100
+ UChar isoCode[4];
101
+ };
102
+
103
+ inline const UChar* CurrencyUnit::getISOCurrency() const {
104
+ return isoCode;
105
+ }
106
+
107
+ U_NAMESPACE_END
108
+
109
+ #endif // !UCONFIG_NO_FORMATTING
110
+ #endif // __CURRENCYUNIT_H__
@@ -0,0 +1,883 @@
1
+ /*
2
+ ********************************************************************************
3
+ * Copyright (C) 1997-2014, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ ********************************************************************************
6
+ *
7
+ * File DATEFMT.H
8
+ *
9
+ * Modification History:
10
+ *
11
+ * Date Name Description
12
+ * 02/19/97 aliu Converted from java.
13
+ * 04/01/97 aliu Added support for centuries.
14
+ * 07/23/98 stephen JDK 1.2 sync
15
+ * 11/15/99 weiv Added support for week of year/day of week formatting
16
+ ********************************************************************************
17
+ */
18
+
19
+ #ifndef DATEFMT_H
20
+ #define DATEFMT_H
21
+
22
+ #include "unicode/utypes.h"
23
+
24
+ #if !UCONFIG_NO_FORMATTING
25
+
26
+ #include "unicode/udat.h"
27
+ #include "unicode/calendar.h"
28
+ #include "unicode/numfmt.h"
29
+ #include "unicode/format.h"
30
+ #include "unicode/locid.h"
31
+ #include "unicode/enumset.h"
32
+ #include "unicode/udisplaycontext.h"
33
+
34
+ /**
35
+ * \file
36
+ * \brief C++ API: Abstract class for converting dates.
37
+ */
38
+
39
+ U_NAMESPACE_BEGIN
40
+
41
+ class TimeZone;
42
+ class DateTimePatternGenerator;
43
+
44
+ // explicit template instantiation. see digitlst.h
45
+ #if defined (_MSC_VER)
46
+ template class U_I18N_API EnumSet<UDateFormatBooleanAttribute,
47
+ 0,
48
+ UDAT_BOOLEAN_ATTRIBUTE_COUNT>;
49
+ #endif
50
+
51
+ /**
52
+ * DateFormat is an abstract class for a family of classes that convert dates and
53
+ * times from their internal representations to textual form and back again in a
54
+ * language-independent manner. Converting from the internal representation (milliseconds
55
+ * since midnight, January 1, 1970) to text is known as "formatting," and converting
56
+ * from text to millis is known as "parsing." We currently define only one concrete
57
+ * subclass of DateFormat: SimpleDateFormat, which can handle pretty much all normal
58
+ * date formatting and parsing actions.
59
+ * <P>
60
+ * DateFormat helps you to format and parse dates for any locale. Your code can
61
+ * be completely independent of the locale conventions for months, days of the
62
+ * week, or even the calendar format: lunar vs. solar.
63
+ * <P>
64
+ * To format a date for the current Locale, use one of the static factory
65
+ * methods:
66
+ * <pre>
67
+ * \code
68
+ * DateFormat* dfmt = DateFormat::createDateInstance();
69
+ * UDate myDate = Calendar::getNow();
70
+ * UnicodeString myString;
71
+ * myString = dfmt->format( myDate, myString );
72
+ * \endcode
73
+ * </pre>
74
+ * If you are formatting multiple numbers, it is more efficient to get the
75
+ * format and use it multiple times so that the system doesn't have to fetch the
76
+ * information about the local language and country conventions multiple times.
77
+ * <pre>
78
+ * \code
79
+ * DateFormat* df = DateFormat::createDateInstance();
80
+ * UnicodeString myString;
81
+ * UDate myDateArr[] = { 0.0, 100000000.0, 2000000000.0 }; // test values
82
+ * for (int32_t i = 0; i < 3; ++i) {
83
+ * myString.remove();
84
+ * cout << df->format( myDateArr[i], myString ) << endl;
85
+ * }
86
+ * \endcode
87
+ * </pre>
88
+ * To get specific fields of a date, you can use UFieldPosition to
89
+ * get specific fields.
90
+ * <pre>
91
+ * \code
92
+ * DateFormat* dfmt = DateFormat::createDateInstance();
93
+ * FieldPosition pos(DateFormat::YEAR_FIELD);
94
+ * UnicodeString myString;
95
+ * myString = dfmt->format( myDate, myString );
96
+ * cout << myString << endl;
97
+ * cout << pos.getBeginIndex() << "," << pos. getEndIndex() << endl;
98
+ * \endcode
99
+ * </pre>
100
+ * To format a date for a different Locale, specify it in the call to
101
+ * createDateInstance().
102
+ * <pre>
103
+ * \code
104
+ * DateFormat* df =
105
+ * DateFormat::createDateInstance( DateFormat::SHORT, Locale::getFrance());
106
+ * \endcode
107
+ * </pre>
108
+ * You can use a DateFormat to parse also.
109
+ * <pre>
110
+ * \code
111
+ * UErrorCode status = U_ZERO_ERROR;
112
+ * UDate myDate = df->parse(myString, status);
113
+ * \endcode
114
+ * </pre>
115
+ * Use createDateInstance() to produce the normal date format for that country.
116
+ * There are other static factory methods available. Use createTimeInstance()
117
+ * to produce the normal time format for that country. Use createDateTimeInstance()
118
+ * to produce a DateFormat that formats both date and time. You can pass in
119
+ * different options to these factory methods to control the length of the
120
+ * result; from SHORT to MEDIUM to LONG to FULL. The exact result depends on the
121
+ * locale, but generally:
122
+ * <ul type=round>
123
+ * <li> SHORT is completely numeric, such as 12/13/52 or 3:30pm
124
+ * <li> MEDIUM is longer, such as Jan 12, 1952
125
+ * <li> LONG is longer, such as January 12, 1952 or 3:30:32pm
126
+ * <li> FULL is pretty completely specified, such as
127
+ * Tuesday, April 12, 1952 AD or 3:30:42pm PST.
128
+ * </ul>
129
+ * You can also set the time zone on the format if you wish. If you want even
130
+ * more control over the format or parsing, (or want to give your users more
131
+ * control), you can try casting the DateFormat you get from the factory methods
132
+ * to a SimpleDateFormat. This will work for the majority of countries; just
133
+ * remember to chck getDynamicClassID() before carrying out the cast.
134
+ * <P>
135
+ * You can also use forms of the parse and format methods with ParsePosition and
136
+ * FieldPosition to allow you to
137
+ * <ul type=round>
138
+ * <li> Progressively parse through pieces of a string.
139
+ * <li> Align any particular field, or find out where it is for selection
140
+ * on the screen.
141
+ * </ul>
142
+ *
143
+ * <p><em>User subclasses are not supported.</em> While clients may write
144
+ * subclasses, such code will not necessarily work and will not be
145
+ * guaranteed to work stably from release to release.
146
+ */
147
+ class U_I18N_API DateFormat : public Format {
148
+ public:
149
+
150
+ /**
151
+ * Constants for various style patterns. These reflect the order of items in
152
+ * the DateTimePatterns resource. There are 4 time patterns, 4 date patterns,
153
+ * the default date-time pattern, and 4 date-time patterns. Each block of 4 values
154
+ * in the resource occurs in the order full, long, medium, short.
155
+ * @stable ICU 2.4
156
+ */
157
+ enum EStyle
158
+ {
159
+ kNone = -1,
160
+
161
+ kFull = 0,
162
+ kLong = 1,
163
+ kMedium = 2,
164
+ kShort = 3,
165
+
166
+ kDateOffset = kShort + 1,
167
+ // kFull + kDateOffset = 4
168
+ // kLong + kDateOffset = 5
169
+ // kMedium + kDateOffset = 6
170
+ // kShort + kDateOffset = 7
171
+
172
+ kDateTime = 8,
173
+ // Default DateTime
174
+
175
+ kDateTimeOffset = kDateTime + 1,
176
+ // kFull + kDateTimeOffset = 9
177
+ // kLong + kDateTimeOffset = 10
178
+ // kMedium + kDateTimeOffset = 11
179
+ // kShort + kDateTimeOffset = 12
180
+
181
+ // relative dates
182
+ kRelative = (1 << 7),
183
+
184
+ kFullRelative = (kFull | kRelative),
185
+
186
+ kLongRelative = kLong | kRelative,
187
+
188
+ kMediumRelative = kMedium | kRelative,
189
+
190
+ kShortRelative = kShort | kRelative,
191
+
192
+
193
+ kDefault = kMedium,
194
+
195
+
196
+
197
+ /**
198
+ * These constants are provided for backwards compatibility only.
199
+ * Please use the C++ style constants defined above.
200
+ */
201
+ FULL = kFull,
202
+ LONG = kLong,
203
+ MEDIUM = kMedium,
204
+ SHORT = kShort,
205
+ DEFAULT = kDefault,
206
+ DATE_OFFSET = kDateOffset,
207
+ NONE = kNone,
208
+ DATE_TIME = kDateTime
209
+ };
210
+
211
+ /**
212
+ * Destructor.
213
+ * @stable ICU 2.0
214
+ */
215
+ virtual ~DateFormat();
216
+
217
+ /**
218
+ * Equality operator. Returns true if the two formats have the same behavior.
219
+ * @stable ICU 2.0
220
+ */
221
+ virtual UBool operator==(const Format&) const;
222
+
223
+
224
+ using Format::format;
225
+
226
+ /**
227
+ * Format an object to produce a string. This method handles Formattable
228
+ * objects with a UDate type. If a the Formattable object type is not a Date,
229
+ * then it returns a failing UErrorCode.
230
+ *
231
+ * @param obj The object to format. Must be a Date.
232
+ * @param appendTo Output parameter to receive result.
233
+ * Result is appended to existing contents.
234
+ * @param pos On input: an alignment field, if desired.
235
+ * On output: the offsets of the alignment field.
236
+ * @param status Output param filled with success/failure status.
237
+ * @return Reference to 'appendTo' parameter.
238
+ * @stable ICU 2.0
239
+ */
240
+ virtual UnicodeString& format(const Formattable& obj,
241
+ UnicodeString& appendTo,
242
+ FieldPosition& pos,
243
+ UErrorCode& status) const;
244
+
245
+ /**
246
+ * Format an object to produce a string. This method handles Formattable
247
+ * objects with a UDate type. If a the Formattable object type is not a Date,
248
+ * then it returns a failing UErrorCode.
249
+ *
250
+ * @param obj The object to format. Must be a Date.
251
+ * @param appendTo Output parameter to receive result.
252
+ * Result is appended to existing contents.
253
+ * @param posIter On return, can be used to iterate over positions
254
+ * of fields generated by this format call. Field values
255
+ * are defined in UDateFormatField. Can be NULL.
256
+ * @param status Output param filled with success/failure status.
257
+ * @return Reference to 'appendTo' parameter.
258
+ * @stable ICU 4.4
259
+ */
260
+ virtual UnicodeString& format(const Formattable& obj,
261
+ UnicodeString& appendTo,
262
+ FieldPositionIterator* posIter,
263
+ UErrorCode& status) const;
264
+ /**
265
+ * Formats a date into a date/time string. This is an abstract method which
266
+ * concrete subclasses must implement.
267
+ * <P>
268
+ * On input, the FieldPosition parameter may have its "field" member filled with
269
+ * an enum value specifying a field. On output, the FieldPosition will be filled
270
+ * in with the text offsets for that field.
271
+ * <P> For example, given a time text
272
+ * "1996.07.10 AD at 15:08:56 PDT", if the given fieldPosition.field is
273
+ * UDAT_YEAR_FIELD, the offsets fieldPosition.beginIndex and
274
+ * statfieldPositionus.getEndIndex will be set to 0 and 4, respectively.
275
+ * <P> Notice
276
+ * that if the same time field appears more than once in a pattern, the status will
277
+ * be set for the first occurence of that time field. For instance,
278
+ * formatting a UDate to the time string "1 PM PDT (Pacific Daylight Time)"
279
+ * using the pattern "h a z (zzzz)" and the alignment field
280
+ * DateFormat::TIMEZONE_FIELD, the offsets fieldPosition.beginIndex and
281
+ * fieldPosition.getEndIndex will be set to 5 and 8, respectively, for the first
282
+ * occurence of the timezone pattern character 'z'.
283
+ *
284
+ * @param cal Calendar set to the date and time to be formatted
285
+ * into a date/time string. When the calendar type is
286
+ * different from the internal calendar held by this
287
+ * DateFormat instance, the date and the time zone will
288
+ * be inherited from the input calendar, but other calendar
289
+ * field values will be calculated by the internal calendar.
290
+ * @param appendTo Output parameter to receive result.
291
+ * Result is appended to existing contents.
292
+ * @param fieldPosition On input: an alignment field, if desired (see examples above)
293
+ * On output: the offsets of the alignment field (see examples above)
294
+ * @return Reference to 'appendTo' parameter.
295
+ * @stable ICU 2.1
296
+ */
297
+ virtual UnicodeString& format( Calendar& cal,
298
+ UnicodeString& appendTo,
299
+ FieldPosition& fieldPosition) const = 0;
300
+
301
+ /**
302
+ * Formats a date into a date/time string. Subclasses should implement this method.
303
+ *
304
+ * @param cal Calendar set to the date and time to be formatted
305
+ * into a date/time string. When the calendar type is
306
+ * different from the internal calendar held by this
307
+ * DateFormat instance, the date and the time zone will
308
+ * be inherited from the input calendar, but other calendar
309
+ * field values will be calculated by the internal calendar.
310
+ * @param appendTo Output parameter to receive result.
311
+ * Result is appended to existing contents.
312
+ * @param posIter On return, can be used to iterate over positions
313
+ * of fields generated by this format call. Field values
314
+ * are defined in UDateFormatField. Can be NULL.
315
+ * @param status error status.
316
+ * @return Reference to 'appendTo' parameter.
317
+ * @stable ICU 4.4
318
+ */
319
+ virtual UnicodeString& format(Calendar& cal,
320
+ UnicodeString& appendTo,
321
+ FieldPositionIterator* posIter,
322
+ UErrorCode& status) const;
323
+ /**
324
+ * Formats a UDate into a date/time string.
325
+ * <P>
326
+ * On input, the FieldPosition parameter may have its "field" member filled with
327
+ * an enum value specifying a field. On output, the FieldPosition will be filled
328
+ * in with the text offsets for that field.
329
+ * <P> For example, given a time text
330
+ * "1996.07.10 AD at 15:08:56 PDT", if the given fieldPosition.field is
331
+ * UDAT_YEAR_FIELD, the offsets fieldPosition.beginIndex and
332
+ * statfieldPositionus.getEndIndex will be set to 0 and 4, respectively.
333
+ * <P> Notice
334
+ * that if the same time field appears more than once in a pattern, the status will
335
+ * be set for the first occurence of that time field. For instance,
336
+ * formatting a UDate to the time string "1 PM PDT (Pacific Daylight Time)"
337
+ * using the pattern "h a z (zzzz)" and the alignment field
338
+ * DateFormat::TIMEZONE_FIELD, the offsets fieldPosition.beginIndex and
339
+ * fieldPosition.getEndIndex will be set to 5 and 8, respectively, for the first
340
+ * occurence of the timezone pattern character 'z'.
341
+ *
342
+ * @param date UDate to be formatted into a date/time string.
343
+ * @param appendTo Output parameter to receive result.
344
+ * Result is appended to existing contents.
345
+ * @param fieldPosition On input: an alignment field, if desired (see examples above)
346
+ * On output: the offsets of the alignment field (see examples above)
347
+ * @return Reference to 'appendTo' parameter.
348
+ * @stable ICU 2.0
349
+ */
350
+ UnicodeString& format( UDate date,
351
+ UnicodeString& appendTo,
352
+ FieldPosition& fieldPosition) const;
353
+
354
+ /**
355
+ * Formats a UDate into a date/time string.
356
+ *
357
+ * @param date UDate to be formatted into a date/time string.
358
+ * @param appendTo Output parameter to receive result.
359
+ * Result is appended to existing contents.
360
+ * @param posIter On return, can be used to iterate over positions
361
+ * of fields generated by this format call. Field values
362
+ * are defined in UDateFormatField. Can be NULL.
363
+ * @param status error status.
364
+ * @return Reference to 'appendTo' parameter.
365
+ * @stable ICU 4.4
366
+ */
367
+ UnicodeString& format(UDate date,
368
+ UnicodeString& appendTo,
369
+ FieldPositionIterator* posIter,
370
+ UErrorCode& status) const;
371
+ /**
372
+ * Formats a UDate into a date/time string. If there is a problem, you won't
373
+ * know, using this method. Use the overloaded format() method which takes a
374
+ * FieldPosition& to detect formatting problems.
375
+ *
376
+ * @param date The UDate value to be formatted into a string.
377
+ * @param appendTo Output parameter to receive result.
378
+ * Result is appended to existing contents.
379
+ * @return Reference to 'appendTo' parameter.
380
+ * @stable ICU 2.0
381
+ */
382
+ UnicodeString& format(UDate date, UnicodeString& appendTo) const;
383
+
384
+ /**
385
+ * Parse a date/time string. For example, a time text "07/10/96 4:5 PM, PDT"
386
+ * will be parsed into a UDate that is equivalent to Date(837039928046).
387
+ * Parsing begins at the beginning of the string and proceeds as far as
388
+ * possible. Assuming no parse errors were encountered, this function
389
+ * doesn't return any information about how much of the string was consumed
390
+ * by the parsing. If you need that information, use the version of
391
+ * parse() that takes a ParsePosition.
392
+ * <P>
393
+ * By default, parsing is lenient: If the input is not in the form used by
394
+ * this object's format method but can still be parsed as a date, then the
395
+ * parse succeeds. Clients may insist on strict adherence to the format by
396
+ * calling setLenient(false).
397
+ * @see DateFormat::setLenient(boolean)
398
+ * <P>
399
+ * Note that the normal date formats associated with some calendars - such
400
+ * as the Chinese lunar calendar - do not specify enough fields to enable
401
+ * dates to be parsed unambiguously. In the case of the Chinese lunar
402
+ * calendar, while the year within the current 60-year cycle is specified,
403
+ * the number of such cycles since the start date of the calendar (in the
404
+ * ERA field of the Calendar object) is not normally part of the format,
405
+ * and parsing may assume the wrong era. For cases such as this it is
406
+ * recommended that clients parse using the method
407
+ * parse(const UnicodeString&, Calendar& cal, ParsePosition&)
408
+ * with the Calendar passed in set to the current date, or to a date
409
+ * within the era/cycle that should be assumed if absent in the format.
410
+ *
411
+ * @param text The date/time string to be parsed into a UDate value.
412
+ * @param status Output param to be set to success/failure code. If
413
+ * 'text' cannot be parsed, it will be set to a failure
414
+ * code.
415
+ * @return The parsed UDate value, if successful.
416
+ * @stable ICU 2.0
417
+ */
418
+ virtual UDate parse( const UnicodeString& text,
419
+ UErrorCode& status) const;
420
+
421
+ /**
422
+ * Parse a date/time string beginning at the given parse position. For
423
+ * example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date
424
+ * that is equivalent to Date(837039928046).
425
+ * <P>
426
+ * By default, parsing is lenient: If the input is not in the form used by
427
+ * this object's format method but can still be parsed as a date, then the
428
+ * parse succeeds. Clients may insist on strict adherence to the format by
429
+ * calling setLenient(false).
430
+ * @see DateFormat::setLenient(boolean)
431
+ *
432
+ * @param text The date/time string to be parsed.
433
+ * @param cal A Calendar set on input to the date and time to be used for
434
+ * missing values in the date/time string being parsed, and set
435
+ * on output to the parsed date/time. When the calendar type is
436
+ * different from the internal calendar held by this DateFormat
437
+ * instance, the internal calendar will be cloned to a work
438
+ * calendar set to the same milliseconds and time zone as the
439
+ * cal parameter, field values will be parsed based on the work
440
+ * calendar, then the result (milliseconds and time zone) will
441
+ * be set in this calendar.
442
+ * @param pos On input, the position at which to start parsing; on
443
+ * output, the position at which parsing terminated, or the
444
+ * start position if the parse failed.
445
+ * @stable ICU 2.1
446
+ */
447
+ virtual void parse( const UnicodeString& text,
448
+ Calendar& cal,
449
+ ParsePosition& pos) const = 0;
450
+
451
+ /**
452
+ * Parse a date/time string beginning at the given parse position. For
453
+ * example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date
454
+ * that is equivalent to Date(837039928046).
455
+ * <P>
456
+ * By default, parsing is lenient: If the input is not in the form used by
457
+ * this object's format method but can still be parsed as a date, then the
458
+ * parse succeeds. Clients may insist on strict adherence to the format by
459
+ * calling setLenient(false).
460
+ * @see DateFormat::setLenient(boolean)
461
+ * <P>
462
+ * Note that the normal date formats associated with some calendars - such
463
+ * as the Chinese lunar calendar - do not specify enough fields to enable
464
+ * dates to be parsed unambiguously. In the case of the Chinese lunar
465
+ * calendar, while the year within the current 60-year cycle is specified,
466
+ * the number of such cycles since the start date of the calendar (in the
467
+ * ERA field of the Calendar object) is not normally part of the format,
468
+ * and parsing may assume the wrong era. For cases such as this it is
469
+ * recommended that clients parse using the method
470
+ * parse(const UnicodeString&, Calendar& cal, ParsePosition&)
471
+ * with the Calendar passed in set to the current date, or to a date
472
+ * within the era/cycle that should be assumed if absent in the format.
473
+ *
474
+ * @param text The date/time string to be parsed into a UDate value.
475
+ * @param pos On input, the position at which to start parsing; on
476
+ * output, the position at which parsing terminated, or the
477
+ * start position if the parse failed.
478
+ * @return A valid UDate if the input could be parsed.
479
+ * @stable ICU 2.0
480
+ */
481
+ UDate parse( const UnicodeString& text,
482
+ ParsePosition& pos) const;
483
+
484
+ /**
485
+ * Parse a string to produce an object. This methods handles parsing of
486
+ * date/time strings into Formattable objects with UDate types.
487
+ * <P>
488
+ * Before calling, set parse_pos.index to the offset you want to start
489
+ * parsing at in the source. After calling, parse_pos.index is the end of
490
+ * the text you parsed. If error occurs, index is unchanged.
491
+ * <P>
492
+ * When parsing, leading whitespace is discarded (with a successful parse),
493
+ * while trailing whitespace is left as is.
494
+ * <P>
495
+ * See Format::parseObject() for more.
496
+ *
497
+ * @param source The string to be parsed into an object.
498
+ * @param result Formattable to be set to the parse result.
499
+ * If parse fails, return contents are undefined.
500
+ * @param parse_pos The position to start parsing at. Upon return
501
+ * this param is set to the position after the
502
+ * last character successfully parsed. If the
503
+ * source is not parsed successfully, this param
504
+ * will remain unchanged.
505
+ * @stable ICU 2.0
506
+ */
507
+ virtual void parseObject(const UnicodeString& source,
508
+ Formattable& result,
509
+ ParsePosition& parse_pos) const;
510
+
511
+ /**
512
+ * Create a default date/time formatter that uses the SHORT style for both
513
+ * the date and the time.
514
+ *
515
+ * @return A date/time formatter which the caller owns.
516
+ * @stable ICU 2.0
517
+ */
518
+ static DateFormat* U_EXPORT2 createInstance(void);
519
+
520
+ /**
521
+ * Creates a time formatter with the given formatting style for the given
522
+ * locale.
523
+ *
524
+ * @param style The given formatting style. For example,
525
+ * SHORT for "h:mm a" in the US locale. Relative
526
+ * time styles are not currently supported.
527
+ * @param aLocale The given locale.
528
+ * @return A time formatter which the caller owns.
529
+ * @stable ICU 2.0
530
+ */
531
+ static DateFormat* U_EXPORT2 createTimeInstance(EStyle style = kDefault,
532
+ const Locale& aLocale = Locale::getDefault());
533
+
534
+ /**
535
+ * Creates a date formatter with the given formatting style for the given
536
+ * const locale.
537
+ *
538
+ * @param style The given formatting style. For example, SHORT for "M/d/yy" in the
539
+ * US locale. As currently implemented, relative date formatting only
540
+ * affects a limited range of calendar days before or after the
541
+ * current date, based on the CLDR &lt;field type="day"&gt;/&lt;relative&gt; data:
542
+ * For example, in English, "Yesterday", "Today", and "Tomorrow".
543
+ * Outside of this range, dates are formatted using the corresponding
544
+ * non-relative style.
545
+ * @param aLocale The given locale.
546
+ * @return A date formatter which the caller owns.
547
+ * @stable ICU 2.0
548
+ */
549
+ static DateFormat* U_EXPORT2 createDateInstance(EStyle style = kDefault,
550
+ const Locale& aLocale = Locale::getDefault());
551
+
552
+ /**
553
+ * Creates a date/time formatter with the given formatting styles for the
554
+ * given locale.
555
+ *
556
+ * @param dateStyle The given formatting style for the date portion of the result.
557
+ * For example, SHORT for "M/d/yy" in the US locale. As currently
558
+ * implemented, relative date formatting only affects a limited range
559
+ * of calendar days before or after the current date, based on the
560
+ * CLDR &lt;field type="day"&gt;/&lt;relative&gt; data: For example, in English,
561
+ * "Yesterday", "Today", and "Tomorrow". Outside of this range, dates
562
+ * are formatted using the corresponding non-relative style.
563
+ * @param timeStyle The given formatting style for the time portion of the result.
564
+ * For example, SHORT for "h:mm a" in the US locale. Relative
565
+ * time styles are not currently supported.
566
+ * @param aLocale The given locale.
567
+ * @return A date/time formatter which the caller owns.
568
+ * @stable ICU 2.0
569
+ */
570
+ static DateFormat* U_EXPORT2 createDateTimeInstance(EStyle dateStyle = kDefault,
571
+ EStyle timeStyle = kDefault,
572
+ const Locale& aLocale = Locale::getDefault());
573
+
574
+ /**
575
+ * Gets the set of locales for which DateFormats are installed.
576
+ * @param count Filled in with the number of locales in the list that is returned.
577
+ * @return the set of locales for which DateFormats are installed. The caller
578
+ * does NOT own this list and must not delete it.
579
+ * @stable ICU 2.0
580
+ */
581
+ static const Locale* U_EXPORT2 getAvailableLocales(int32_t& count);
582
+
583
+ /**
584
+ * Returns whether both date/time parsing in the encapsulated Calendar object and DateFormat whitespace &
585
+ * numeric processing is lenient.
586
+ * @stable ICU 2.0
587
+ */
588
+ virtual UBool isLenient(void) const;
589
+
590
+ /**
591
+ * Specifies whether date/time parsing is to be lenient. With
592
+ * lenient parsing, the parser may use heuristics to interpret inputs that
593
+ * do not precisely match this object's format. Without lenient parsing,
594
+ * inputs must match this object's format more closely.
595
+ *
596
+ * Note: ICU 53 introduced finer grained control of leniency (and added
597
+ * new control points) making the preferred method a combination of
598
+ * setCalendarLenient() & setBooleanAttribute() calls.
599
+ * This method supports prior functionality but may not support all
600
+ * future leniency control & behavior of DateFormat. For control of pre 53 leniency,
601
+ * Calendar and DateFormat whitespace & numeric tolerance, this method is safe to
602
+ * use. However, mixing leniency control via this method and modification of the
603
+ * newer attributes via setBooleanAttribute() may produce undesirable
604
+ * results.
605
+ *
606
+ * @param lenient True specifies date/time interpretation to be lenient.
607
+ * @see Calendar::setLenient
608
+ * @stable ICU 2.0
609
+ */
610
+ virtual void setLenient(UBool lenient);
611
+
612
+
613
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
614
+ /**
615
+ * Returns whether date/time parsing in the encapsulated Calendar object processing is lenient.
616
+ * @draft ICU 53
617
+ */
618
+ virtual UBool isCalendarLenient(void) const;
619
+
620
+
621
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
622
+ /**
623
+ * Specifies whether encapsulated Calendar date/time parsing is to be lenient. With
624
+ * lenient parsing, the parser may use heuristics to interpret inputs that
625
+ * do not precisely match this object's format. Without lenient parsing,
626
+ * inputs must match this object's format more closely.
627
+ * @param lenient when true, parsing is lenient
628
+ * @see com.ibm.icu.util.Calendar#setLenient
629
+ * @draft ICU 53
630
+ */
631
+ virtual void setCalendarLenient(UBool lenient);
632
+
633
+
634
+ /**
635
+ * Gets the calendar associated with this date/time formatter.
636
+ * The calendar is owned by the formatter and must not be modified.
637
+ * Also, the calendar does not reflect the results of a parse operation.
638
+ * To parse to a calendar, use {@link #parse(const UnicodeString&, Calendar& cal, ParsePosition&) const parse(const UnicodeString&, Calendar& cal, ParsePosition&)}
639
+ * @return the calendar associated with this date/time formatter.
640
+ * @stable ICU 2.0
641
+ */
642
+ virtual const Calendar* getCalendar(void) const;
643
+
644
+ /**
645
+ * Set the calendar to be used by this date format. Initially, the default
646
+ * calendar for the specified or default locale is used. The caller should
647
+ * not delete the Calendar object after it is adopted by this call.
648
+ * Adopting a new calendar will change to the default symbols.
649
+ *
650
+ * @param calendarToAdopt Calendar object to be adopted.
651
+ * @stable ICU 2.0
652
+ */
653
+ virtual void adoptCalendar(Calendar* calendarToAdopt);
654
+
655
+ /**
656
+ * Set the calendar to be used by this date format. Initially, the default
657
+ * calendar for the specified or default locale is used.
658
+ *
659
+ * @param newCalendar Calendar object to be set.
660
+ * @stable ICU 2.0
661
+ */
662
+ virtual void setCalendar(const Calendar& newCalendar);
663
+
664
+
665
+ /**
666
+ * Gets the number formatter which this date/time formatter uses to format
667
+ * and parse the numeric portions of the pattern.
668
+ * @return the number formatter which this date/time formatter uses.
669
+ * @stable ICU 2.0
670
+ */
671
+ virtual const NumberFormat* getNumberFormat(void) const;
672
+
673
+ /**
674
+ * Allows you to set the number formatter. The caller should
675
+ * not delete the NumberFormat object after it is adopted by this call.
676
+ * @param formatToAdopt NumberFormat object to be adopted.
677
+ * @stable ICU 2.0
678
+ */
679
+ virtual void adoptNumberFormat(NumberFormat* formatToAdopt);
680
+
681
+ /**
682
+ * Allows you to set the number formatter.
683
+ * @param newNumberFormat NumberFormat object to be set.
684
+ * @stable ICU 2.0
685
+ */
686
+ virtual void setNumberFormat(const NumberFormat& newNumberFormat);
687
+
688
+ /**
689
+ * Returns a reference to the TimeZone used by this DateFormat's calendar.
690
+ * @return the time zone associated with the calendar of DateFormat.
691
+ * @stable ICU 2.0
692
+ */
693
+ virtual const TimeZone& getTimeZone(void) const;
694
+
695
+ /**
696
+ * Sets the time zone for the calendar of this DateFormat object. The caller
697
+ * no longer owns the TimeZone object and should not delete it after this call.
698
+ * @param zoneToAdopt the TimeZone to be adopted.
699
+ * @stable ICU 2.0
700
+ */
701
+ virtual void adoptTimeZone(TimeZone* zoneToAdopt);
702
+
703
+ /**
704
+ * Sets the time zone for the calendar of this DateFormat object.
705
+ * @param zone the new time zone.
706
+ * @stable ICU 2.0
707
+ */
708
+ virtual void setTimeZone(const TimeZone& zone);
709
+
710
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
711
+ /**
712
+ * Set a particular UDisplayContext value in the formatter, such as
713
+ * UDISPCTX_CAPITALIZATION_FOR_STANDALONE.
714
+ * @param value The UDisplayContext value to set.
715
+ * @param status Input/output status. If at entry this indicates a failure
716
+ * status, the function will do nothing; otherwise this will be
717
+ * updated with any new status from the function.
718
+ * @draft ICU 53
719
+ */
720
+ virtual void setContext(UDisplayContext value, UErrorCode& status);
721
+
722
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
723
+ /**
724
+ * Get the formatter's UDisplayContext value for the specified UDisplayContextType,
725
+ * such as UDISPCTX_TYPE_CAPITALIZATION.
726
+ * @param type The UDisplayContextType whose value to return
727
+ * @param status Input/output status. If at entry this indicates a failure
728
+ * status, the function will do nothing; otherwise this will be
729
+ * updated with any new status from the function.
730
+ * @return The UDisplayContextValue for the specified type.
731
+ * @draft ICU 53
732
+ */
733
+ virtual UDisplayContext getContext(UDisplayContextType type, UErrorCode& status) const;
734
+
735
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
736
+ /**
737
+ * Sets an boolean attribute on this DateFormat.
738
+ * May return U_UNSUPPORTED_ERROR if this instance does not support
739
+ * the specified attribute.
740
+ * @param attr the attribute to set
741
+ * @param newvalue new value
742
+ * @param status the error type
743
+ * @return *this - for chaining (example: format.setAttribute(...).setAttribute(...) )
744
+ * @draft ICU 53
745
+ */
746
+
747
+ virtual DateFormat& U_EXPORT2 setBooleanAttribute(UDateFormatBooleanAttribute attr,
748
+ UBool newvalue,
749
+ UErrorCode &status);
750
+
751
+ /* Cannot use #ifndef U_HIDE_DRAFT_API for the following draft method since it is virtual */
752
+ /**
753
+ * Returns a boolean from this DateFormat
754
+ * May return U_UNSUPPORTED_ERROR if this instance does not support
755
+ * the specified attribute.
756
+ * @param attr the attribute to set
757
+ * @param status the error type
758
+ * @return the attribute value. Undefined if there is an error.
759
+ * @draft ICU 53
760
+ */
761
+ virtual UBool U_EXPORT2 getBooleanAttribute(UDateFormatBooleanAttribute attr, UErrorCode &status) const;
762
+
763
+ protected:
764
+ /**
765
+ * Default constructor. Creates a DateFormat with no Calendar or NumberFormat
766
+ * associated with it. This constructor depends on the subclasses to fill in
767
+ * the calendar and numberFormat fields.
768
+ * @stable ICU 2.0
769
+ */
770
+ DateFormat();
771
+
772
+ /**
773
+ * Copy constructor.
774
+ * @stable ICU 2.0
775
+ */
776
+ DateFormat(const DateFormat&);
777
+
778
+ /**
779
+ * Default assignment operator.
780
+ * @stable ICU 2.0
781
+ */
782
+ DateFormat& operator=(const DateFormat&);
783
+
784
+ /**
785
+ * The calendar that DateFormat uses to produce the time field values needed
786
+ * to implement date/time formatting. Subclasses should generally initialize
787
+ * this to the default calendar for the locale associated with this DateFormat.
788
+ * @stable ICU 2.4
789
+ */
790
+ Calendar* fCalendar;
791
+
792
+ /**
793
+ * The number formatter that DateFormat uses to format numbers in dates and
794
+ * times. Subclasses should generally initialize this to the default number
795
+ * format for the locale associated with this DateFormat.
796
+ * @stable ICU 2.4
797
+ */
798
+ NumberFormat* fNumberFormat;
799
+
800
+
801
+ private:
802
+ /**
803
+ * Gets the date/time formatter with the given formatting styles for the
804
+ * given locale.
805
+ * @param dateStyle the given date formatting style.
806
+ * @param timeStyle the given time formatting style.
807
+ * @param inLocale the given locale.
808
+ * @return a date/time formatter, or 0 on failure.
809
+ */
810
+ static DateFormat* U_EXPORT2 create(EStyle timeStyle, EStyle dateStyle, const Locale& inLocale);
811
+
812
+
813
+ /**
814
+ * enum set of active boolean attributes for this instance
815
+ */
816
+ EnumSet<UDateFormatBooleanAttribute, 0, UDAT_BOOLEAN_ATTRIBUTE_COUNT> fBoolFlags;
817
+
818
+
819
+ UDisplayContext fCapitalizationContext;
820
+
821
+ public:
822
+ #ifndef U_HIDE_OBSOLETE_API
823
+ /**
824
+ * Field selector for FieldPosition for DateFormat fields.
825
+ * @obsolete ICU 3.4 use UDateFormatField instead, since this API will be
826
+ * removed in that release
827
+ */
828
+ enum EField
829
+ {
830
+ // Obsolete; use UDateFormatField instead
831
+ kEraField = UDAT_ERA_FIELD,
832
+ kYearField = UDAT_YEAR_FIELD,
833
+ kMonthField = UDAT_MONTH_FIELD,
834
+ kDateField = UDAT_DATE_FIELD,
835
+ kHourOfDay1Field = UDAT_HOUR_OF_DAY1_FIELD,
836
+ kHourOfDay0Field = UDAT_HOUR_OF_DAY0_FIELD,
837
+ kMinuteField = UDAT_MINUTE_FIELD,
838
+ kSecondField = UDAT_SECOND_FIELD,
839
+ kMillisecondField = UDAT_FRACTIONAL_SECOND_FIELD,
840
+ kDayOfWeekField = UDAT_DAY_OF_WEEK_FIELD,
841
+ kDayOfYearField = UDAT_DAY_OF_YEAR_FIELD,
842
+ kDayOfWeekInMonthField = UDAT_DAY_OF_WEEK_IN_MONTH_FIELD,
843
+ kWeekOfYearField = UDAT_WEEK_OF_YEAR_FIELD,
844
+ kWeekOfMonthField = UDAT_WEEK_OF_MONTH_FIELD,
845
+ kAmPmField = UDAT_AM_PM_FIELD,
846
+ kHour1Field = UDAT_HOUR1_FIELD,
847
+ kHour0Field = UDAT_HOUR0_FIELD,
848
+ kTimezoneField = UDAT_TIMEZONE_FIELD,
849
+ kYearWOYField = UDAT_YEAR_WOY_FIELD,
850
+ kDOWLocalField = UDAT_DOW_LOCAL_FIELD,
851
+ kExtendedYearField = UDAT_EXTENDED_YEAR_FIELD,
852
+ kJulianDayField = UDAT_JULIAN_DAY_FIELD,
853
+ kMillisecondsInDayField = UDAT_MILLISECONDS_IN_DAY_FIELD,
854
+
855
+ // Obsolete; use UDateFormatField instead
856
+ ERA_FIELD = UDAT_ERA_FIELD,
857
+ YEAR_FIELD = UDAT_YEAR_FIELD,
858
+ MONTH_FIELD = UDAT_MONTH_FIELD,
859
+ DATE_FIELD = UDAT_DATE_FIELD,
860
+ HOUR_OF_DAY1_FIELD = UDAT_HOUR_OF_DAY1_FIELD,
861
+ HOUR_OF_DAY0_FIELD = UDAT_HOUR_OF_DAY0_FIELD,
862
+ MINUTE_FIELD = UDAT_MINUTE_FIELD,
863
+ SECOND_FIELD = UDAT_SECOND_FIELD,
864
+ MILLISECOND_FIELD = UDAT_FRACTIONAL_SECOND_FIELD,
865
+ DAY_OF_WEEK_FIELD = UDAT_DAY_OF_WEEK_FIELD,
866
+ DAY_OF_YEAR_FIELD = UDAT_DAY_OF_YEAR_FIELD,
867
+ DAY_OF_WEEK_IN_MONTH_FIELD = UDAT_DAY_OF_WEEK_IN_MONTH_FIELD,
868
+ WEEK_OF_YEAR_FIELD = UDAT_WEEK_OF_YEAR_FIELD,
869
+ WEEK_OF_MONTH_FIELD = UDAT_WEEK_OF_MONTH_FIELD,
870
+ AM_PM_FIELD = UDAT_AM_PM_FIELD,
871
+ HOUR1_FIELD = UDAT_HOUR1_FIELD,
872
+ HOUR0_FIELD = UDAT_HOUR0_FIELD,
873
+ TIMEZONE_FIELD = UDAT_TIMEZONE_FIELD
874
+ };
875
+ #endif /* U_HIDE_OBSOLETE_API */
876
+ };
877
+
878
+ U_NAMESPACE_END
879
+
880
+ #endif /* #if !UCONFIG_NO_FORMATTING */
881
+
882
+ #endif // _DATEFMT
883
+ //eof