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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +21 -2
  3. data/lib/2.0/pango.so +0 -0
  4. data/vendor/local/bin/derb.exe +0 -0
  5. data/vendor/local/bin/genbrk.exe +0 -0
  6. data/vendor/local/bin/genccode.exe +0 -0
  7. data/vendor/local/bin/gencfu.exe +0 -0
  8. data/vendor/local/bin/gencmn.exe +0 -0
  9. data/vendor/local/bin/gencnval.exe +0 -0
  10. data/vendor/local/bin/gendict.exe +0 -0
  11. data/vendor/local/bin/gennorm2.exe +0 -0
  12. data/vendor/local/bin/genrb.exe +0 -0
  13. data/vendor/local/bin/gensprep.exe +0 -0
  14. data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
  15. data/vendor/local/bin/hb-shape.exe +0 -0
  16. data/vendor/local/bin/hb-view.exe +0 -0
  17. data/vendor/local/bin/icu-config +820 -0
  18. data/vendor/local/bin/icuinfo.exe +0 -0
  19. data/vendor/local/bin/icupkg.exe +0 -0
  20. data/vendor/local/bin/libharfbuzz-0.dll +0 -0
  21. data/vendor/local/bin/libpango-1.0-0.dll +0 -0
  22. data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
  23. data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
  24. data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
  25. data/vendor/local/bin/libstdc++-6.dll +0 -0
  26. data/vendor/local/bin/makeconv.exe +0 -0
  27. data/vendor/local/bin/pango-querymodules.exe +0 -0
  28. data/vendor/local/bin/pango-view.exe +0 -0
  29. data/vendor/local/bin/pkgdata.exe +0 -0
  30. data/vendor/local/bin/uconv.exe +0 -0
  31. data/vendor/local/etc/pango/pango.modules +3 -3
  32. data/vendor/local/include/harfbuzz/hb-blob.h +3 -4
  33. data/vendor/local/include/harfbuzz/hb-buffer.h +22 -1
  34. data/vendor/local/include/harfbuzz/hb-common.h +23 -18
  35. data/vendor/local/include/harfbuzz/hb-icu.h +52 -0
  36. data/vendor/local/include/harfbuzz/hb-ot-font.h +41 -0
  37. data/vendor/local/include/harfbuzz/hb-ot-layout.h +11 -3
  38. data/vendor/local/include/harfbuzz/hb-ot-shape.h +10 -11
  39. data/vendor/local/include/harfbuzz/hb-ot.h +1 -0
  40. data/vendor/local/include/harfbuzz/hb-version.h +7 -7
  41. data/vendor/local/include/layout/LEFontInstance.h +550 -0
  42. data/vendor/local/include/layout/LEGlyphFilter.h +45 -0
  43. data/vendor/local/include/layout/LEGlyphStorage.h +546 -0
  44. data/vendor/local/include/layout/LEInsertionList.h +177 -0
  45. data/vendor/local/include/layout/LELanguages.h +112 -0
  46. data/vendor/local/include/layout/LEScripts.h +263 -0
  47. data/vendor/local/include/layout/LESwaps.h +100 -0
  48. data/vendor/local/include/layout/LETableReference.h +418 -0
  49. data/vendor/local/include/layout/LETypes.h +728 -0
  50. data/vendor/local/include/layout/LayoutEngine.h +518 -0
  51. data/vendor/local/include/layout/ParagraphLayout.h +747 -0
  52. data/vendor/local/include/layout/RunArrays.h +676 -0
  53. data/vendor/local/include/layout/loengine.h +225 -0
  54. data/vendor/local/include/layout/playout.h +466 -0
  55. data/vendor/local/include/layout/plruns.h +441 -0
  56. data/vendor/local/include/pango-1.0/pango/pango-features.h +2 -2
  57. data/vendor/local/include/pango-1.0/pango/pango-font.h +3 -1
  58. data/vendor/local/include/pango-1.0/pango/pango-item.h +11 -2
  59. data/vendor/local/include/unicode/alphaindex.h +752 -0
  60. data/vendor/local/include/unicode/appendable.h +232 -0
  61. data/vendor/local/include/unicode/basictz.h +214 -0
  62. data/vendor/local/include/unicode/brkiter.h +655 -0
  63. data/vendor/local/include/unicode/bytestream.h +257 -0
  64. data/vendor/local/include/unicode/bytestrie.h +519 -0
  65. data/vendor/local/include/unicode/bytestriebuilder.h +181 -0
  66. data/vendor/local/include/unicode/calendar.h +2519 -0
  67. data/vendor/local/include/unicode/caniter.h +208 -0
  68. data/vendor/local/include/unicode/chariter.h +722 -0
  69. data/vendor/local/include/unicode/choicfmt.h +594 -0
  70. data/vendor/local/include/unicode/coleitr.h +404 -0
  71. data/vendor/local/include/unicode/coll.h +1267 -0
  72. data/vendor/local/include/unicode/compactdecimalformat.h +330 -0
  73. data/vendor/local/include/unicode/curramt.h +130 -0
  74. data/vendor/local/include/unicode/currpinf.h +258 -0
  75. data/vendor/local/include/unicode/currunit.h +110 -0
  76. data/vendor/local/include/unicode/datefmt.h +883 -0
  77. data/vendor/local/include/unicode/dbbi.h +40 -0
  78. data/vendor/local/include/unicode/dcfmtsym.h +482 -0
  79. data/vendor/local/include/unicode/decimfmt.h +2479 -0
  80. data/vendor/local/include/unicode/docmain.h +215 -0
  81. data/vendor/local/include/unicode/dtfmtsym.h +912 -0
  82. data/vendor/local/include/unicode/dtintrv.h +158 -0
  83. data/vendor/local/include/unicode/dtitvfmt.h +985 -0
  84. data/vendor/local/include/unicode/dtitvinf.h +514 -0
  85. data/vendor/local/include/unicode/dtptngen.h +498 -0
  86. data/vendor/local/include/unicode/dtrule.h +250 -0
  87. data/vendor/local/include/unicode/enumset.h +64 -0
  88. data/vendor/local/include/unicode/errorcode.h +137 -0
  89. data/vendor/local/include/unicode/fieldpos.h +291 -0
  90. data/vendor/local/include/unicode/filteredbrk.h +131 -0
  91. data/vendor/local/include/unicode/fmtable.h +760 -0
  92. data/vendor/local/include/unicode/format.h +305 -0
  93. data/vendor/local/include/unicode/fpositer.h +117 -0
  94. data/vendor/local/include/unicode/gender.h +111 -0
  95. data/vendor/local/include/unicode/gregocal.h +777 -0
  96. data/vendor/local/include/unicode/icudataver.h +41 -0
  97. data/vendor/local/include/unicode/icuplug.h +371 -0
  98. data/vendor/local/include/unicode/idna.h +323 -0
  99. data/vendor/local/include/unicode/listformatter.h +167 -0
  100. data/vendor/local/include/unicode/localpointer.h +304 -0
  101. data/vendor/local/include/unicode/locdspnm.h +204 -0
  102. data/vendor/local/include/unicode/locid.h +815 -0
  103. data/vendor/local/include/unicode/measfmt.h +389 -0
  104. data/vendor/local/include/unicode/measunit.h +1443 -0
  105. data/vendor/local/include/unicode/measure.h +159 -0
  106. data/vendor/local/include/unicode/messagepattern.h +943 -0
  107. data/vendor/local/include/unicode/msgfmt.h +1093 -0
  108. data/vendor/local/include/unicode/normalizer2.h +658 -0
  109. data/vendor/local/include/unicode/normlzr.h +797 -0
  110. data/vendor/local/include/unicode/numfmt.h +1187 -0
  111. data/vendor/local/include/unicode/numsys.h +208 -0
  112. data/vendor/local/include/unicode/parseerr.h +92 -0
  113. data/vendor/local/include/unicode/parsepos.h +230 -0
  114. data/vendor/local/include/unicode/platform.h +751 -0
  115. data/vendor/local/include/unicode/plurfmt.h +615 -0
  116. data/vendor/local/include/unicode/plurrule.h +501 -0
  117. data/vendor/local/include/unicode/ptypes.h +126 -0
  118. data/vendor/local/include/unicode/putil.h +181 -0
  119. data/vendor/local/include/unicode/rbbi.h +782 -0
  120. data/vendor/local/include/unicode/rbnf.h +1032 -0
  121. data/vendor/local/include/unicode/rbtz.h +362 -0
  122. data/vendor/local/include/unicode/regex.h +1857 -0
  123. data/vendor/local/include/unicode/region.h +228 -0
  124. data/vendor/local/include/unicode/reldatefmt.h +498 -0
  125. data/vendor/local/include/unicode/rep.h +261 -0
  126. data/vendor/local/include/unicode/resbund.h +490 -0
  127. data/vendor/local/include/unicode/schriter.h +187 -0
  128. data/vendor/local/include/unicode/scientificformathelper.h +139 -0
  129. data/vendor/local/include/unicode/search.h +575 -0
  130. data/vendor/local/include/unicode/selfmt.h +367 -0
  131. data/vendor/local/include/unicode/simpletz.h +928 -0
  132. data/vendor/local/include/unicode/smpdtfmt.h +1592 -0
  133. data/vendor/local/include/unicode/sortkey.h +338 -0
  134. data/vendor/local/include/unicode/std_string.h +37 -0
  135. data/vendor/local/include/unicode/strenum.h +276 -0
  136. data/vendor/local/include/unicode/stringpiece.h +224 -0
  137. data/vendor/local/include/unicode/stringtriebuilder.h +402 -0
  138. data/vendor/local/include/unicode/stsearch.h +504 -0
  139. data/vendor/local/include/unicode/symtable.h +112 -0
  140. data/vendor/local/include/unicode/tblcoll.h +873 -0
  141. data/vendor/local/include/unicode/timezone.h +948 -0
  142. data/vendor/local/include/unicode/tmunit.h +129 -0
  143. data/vendor/local/include/unicode/tmutamt.h +168 -0
  144. data/vendor/local/include/unicode/tmutfmt.h +243 -0
  145. data/vendor/local/include/unicode/translit.h +1342 -0
  146. data/vendor/local/include/unicode/tzfmt.h +1098 -0
  147. data/vendor/local/include/unicode/tznames.h +404 -0
  148. data/vendor/local/include/unicode/tzrule.h +828 -0
  149. data/vendor/local/include/unicode/tztrans.h +195 -0
  150. data/vendor/local/include/unicode/ubidi.h +2186 -0
  151. data/vendor/local/include/unicode/ubrk.h +540 -0
  152. data/vendor/local/include/unicode/ucal.h +1560 -0
  153. data/vendor/local/include/unicode/ucasemap.h +423 -0
  154. data/vendor/local/include/unicode/ucat.h +158 -0
  155. data/vendor/local/include/unicode/uchar.h +3426 -0
  156. data/vendor/local/include/unicode/ucharstrie.h +576 -0
  157. data/vendor/local/include/unicode/ucharstriebuilder.h +185 -0
  158. data/vendor/local/include/unicode/uchriter.h +381 -0
  159. data/vendor/local/include/unicode/uclean.h +258 -0
  160. data/vendor/local/include/unicode/ucnv.h +2036 -0
  161. data/vendor/local/include/unicode/ucnv_cb.h +162 -0
  162. data/vendor/local/include/unicode/ucnv_err.h +463 -0
  163. data/vendor/local/include/unicode/ucnvsel.h +187 -0
  164. data/vendor/local/include/unicode/ucol.h +1474 -0
  165. data/vendor/local/include/unicode/ucoleitr.h +266 -0
  166. data/vendor/local/include/unicode/uconfig.h +430 -0
  167. data/vendor/local/include/unicode/ucsdet.h +413 -0
  168. data/vendor/local/include/unicode/ucurr.h +424 -0
  169. data/vendor/local/include/unicode/udat.h +1536 -0
  170. data/vendor/local/include/unicode/udata.h +430 -0
  171. data/vendor/local/include/unicode/udateintervalformat.h +181 -0
  172. data/vendor/local/include/unicode/udatpg.h +588 -0
  173. data/vendor/local/include/unicode/udisplaycontext.h +150 -0
  174. data/vendor/local/include/unicode/uenum.h +206 -0
  175. data/vendor/local/include/unicode/uformattable.h +280 -0
  176. data/vendor/local/include/unicode/ugender.h +82 -0
  177. data/vendor/local/include/unicode/uidna.h +762 -0
  178. data/vendor/local/include/unicode/uiter.h +707 -0
  179. data/vendor/local/include/unicode/uldnames.h +302 -0
  180. data/vendor/local/include/unicode/uloc.h +1256 -0
  181. data/vendor/local/include/unicode/ulocdata.h +277 -0
  182. data/vendor/local/include/unicode/umachine.h +356 -0
  183. data/vendor/local/include/unicode/umisc.h +60 -0
  184. data/vendor/local/include/unicode/umsg.h +623 -0
  185. data/vendor/local/include/unicode/unifilt.h +120 -0
  186. data/vendor/local/include/unicode/unifunct.h +125 -0
  187. data/vendor/local/include/unicode/unimatch.h +163 -0
  188. data/vendor/local/include/unicode/unirepl.h +97 -0
  189. data/vendor/local/include/unicode/uniset.h +1691 -0
  190. data/vendor/local/include/unicode/unistr.h +4470 -0
  191. data/vendor/local/include/unicode/unorm.h +561 -0
  192. data/vendor/local/include/unicode/unorm2.h +528 -0
  193. data/vendor/local/include/unicode/unum.h +1328 -0
  194. data/vendor/local/include/unicode/unumsys.h +170 -0
  195. data/vendor/local/include/unicode/uobject.h +320 -0
  196. data/vendor/local/include/unicode/upluralrules.h +145 -0
  197. data/vendor/local/include/unicode/uregex.h +1591 -0
  198. data/vendor/local/include/unicode/uregion.h +248 -0
  199. data/vendor/local/include/unicode/urename.h +1784 -0
  200. data/vendor/local/include/unicode/urep.h +155 -0
  201. data/vendor/local/include/unicode/ures.h +887 -0
  202. data/vendor/local/include/unicode/uscript.h +642 -0
  203. data/vendor/local/include/unicode/usearch.h +885 -0
  204. data/vendor/local/include/unicode/uset.h +1126 -0
  205. data/vendor/local/include/unicode/usetiter.h +318 -0
  206. data/vendor/local/include/unicode/ushape.h +474 -0
  207. data/vendor/local/include/unicode/uspoof.h +1064 -0
  208. data/vendor/local/include/unicode/usprep.h +269 -0
  209. data/vendor/local/include/unicode/ustdio.h +1018 -0
  210. data/vendor/local/include/unicode/ustream.h +68 -0
  211. data/vendor/local/include/unicode/ustring.h +1700 -0
  212. data/vendor/local/include/unicode/ustringtrie.h +95 -0
  213. data/vendor/local/include/unicode/utext.h +1600 -0
  214. data/vendor/local/include/unicode/utf.h +223 -0
  215. data/vendor/local/include/unicode/utf16.h +623 -0
  216. data/vendor/local/include/unicode/utf32.h +23 -0
  217. data/vendor/local/include/unicode/utf8.h +824 -0
  218. data/vendor/local/include/unicode/utf_old.h +1169 -0
  219. data/vendor/local/include/unicode/utmscale.h +481 -0
  220. data/vendor/local/include/unicode/utrace.h +359 -0
  221. data/vendor/local/include/unicode/utrans.h +658 -0
  222. data/vendor/local/include/unicode/utypes.h +723 -0
  223. data/vendor/local/include/unicode/uvernum.h +170 -0
  224. data/vendor/local/include/unicode/uversion.h +193 -0
  225. data/vendor/local/include/unicode/vtzone.h +455 -0
  226. data/vendor/local/lib/girepository-1.0/Pango-1.0.typelib +0 -0
  227. data/vendor/local/lib/girepository-1.0/PangoCairo-1.0.typelib +0 -0
  228. data/vendor/local/lib/girepository-1.0/PangoFT2-1.0.typelib +0 -0
  229. data/vendor/local/lib/icu/54.1/Makefile.inc +293 -0
  230. data/vendor/local/lib/icu/54.1/pkgdata.inc +17 -0
  231. data/vendor/local/lib/icu/Makefile.inc +293 -0
  232. data/vendor/local/lib/icu/pkgdata.inc +17 -0
  233. data/vendor/local/lib/icudt.dll +0 -0
  234. data/vendor/local/lib/icudt54.dll +0 -0
  235. data/vendor/local/lib/icuin.dll +0 -0
  236. data/vendor/local/lib/icuin54.dll +0 -0
  237. data/vendor/local/lib/icuio.dll +0 -0
  238. data/vendor/local/lib/icuio54.dll +0 -0
  239. data/vendor/local/lib/icule.dll +0 -0
  240. data/vendor/local/lib/icule54.dll +0 -0
  241. data/vendor/local/lib/iculx.dll +0 -0
  242. data/vendor/local/lib/iculx54.dll +0 -0
  243. data/vendor/local/lib/icutest.dll +0 -0
  244. data/vendor/local/lib/icutest54.dll +0 -0
  245. data/vendor/local/lib/icutu.dll +0 -0
  246. data/vendor/local/lib/icutu54.dll +0 -0
  247. data/vendor/local/lib/icuuc.dll +0 -0
  248. data/vendor/local/lib/icuuc54.dll +0 -0
  249. data/vendor/local/lib/libharfbuzz-icu.a +0 -0
  250. data/vendor/local/lib/libharfbuzz-icu.la +41 -0
  251. data/vendor/local/lib/libharfbuzz.dll.a +0 -0
  252. data/vendor/local/lib/libharfbuzz.la +3 -3
  253. data/vendor/local/lib/libicudt.dll.a +0 -0
  254. data/vendor/local/lib/libicuin.dll.a +0 -0
  255. data/vendor/local/lib/libicuio.dll.a +0 -0
  256. data/vendor/local/lib/libicule.dll.a +0 -0
  257. data/vendor/local/lib/libiculx.dll.a +0 -0
  258. data/vendor/local/lib/libicutest.dll.a +0 -0
  259. data/vendor/local/lib/libicutu.dll.a +0 -0
  260. data/vendor/local/lib/libicuuc.dll.a +0 -0
  261. data/vendor/local/lib/libpango-1.0.dll.a +0 -0
  262. data/vendor/local/lib/libpango-1.0.la +2 -2
  263. data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
  264. data/vendor/local/lib/libpangocairo-1.0.la +2 -2
  265. data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
  266. data/vendor/local/lib/libpangoft2-1.0.la +2 -2
  267. data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
  268. data/vendor/local/lib/libpangowin32-1.0.la +2 -2
  269. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll +0 -0
  270. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll.a +0 -0
  271. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.la +1 -1
  272. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll +0 -0
  273. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll.a +0 -0
  274. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.la +1 -1
  275. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll +0 -0
  276. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll.a +0 -0
  277. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.la +1 -1
  278. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll +0 -0
  279. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll.a +0 -0
  280. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.la +1 -1
  281. data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +13 -0
  282. data/vendor/local/lib/pkgconfig/harfbuzz.pc +1 -1
  283. data/vendor/local/lib/pkgconfig/icu-i18n.pc +38 -0
  284. data/vendor/local/lib/pkgconfig/icu-io.pc +38 -0
  285. data/vendor/local/lib/pkgconfig/icu-le.pc +38 -0
  286. data/vendor/local/lib/pkgconfig/icu-lx.pc +38 -0
  287. data/vendor/local/lib/pkgconfig/icu-uc.pc +38 -0
  288. data/vendor/local/lib/pkgconfig/pango.pc +1 -1
  289. data/vendor/local/lib/pkgconfig/pangocairo.pc +1 -1
  290. data/vendor/local/lib/pkgconfig/pangoft2.pc +1 -1
  291. data/vendor/local/lib/pkgconfig/pangowin32.pc +1 -1
  292. data/vendor/local/share/gir-1.0/Pango-1.0.gir +3009 -462
  293. data/vendor/local/share/gir-1.0/PangoCairo-1.0.gir +64 -22
  294. data/vendor/local/share/gir-1.0/PangoFT2-1.0.gir +4 -2
  295. data/vendor/local/share/gtk-doc/html/harfbuzz/annotation-glossary.html +30 -26
  296. data/vendor/local/share/gtk-doc/html/harfbuzz/api-index-full.html +343 -313
  297. data/vendor/local/share/gtk-doc/html/harfbuzz/ch01.html +5 -5
  298. data/vendor/local/share/gtk-doc/html/harfbuzz/deprecated-api-index.html +6 -8
  299. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-blob.html +442 -247
  300. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-buffer.html +1389 -654
  301. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-common.html +954 -698
  302. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-coretext.html +95 -18
  303. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-deprecated.html +36 -27
  304. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-face.html +477 -191
  305. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-font.html +1951 -1039
  306. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ft.html +123 -65
  307. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-glib.html +66 -21
  308. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-gobject.html +11 -13
  309. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-graphite2.html +67 -23
  310. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-icu.html +66 -21
  311. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-layout.html +574 -347
  312. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-tag.html +104 -37
  313. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot.html +10 -27
  314. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-set.html +744 -318
  315. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape-plan.html +294 -153
  316. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape.html +196 -104
  317. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-unicode.html +1100 -757
  318. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-uniscribe.html +51 -18
  319. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +110 -84
  320. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb.html +11 -13
  321. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz.devhelp2 +289 -503
  322. data/vendor/local/share/gtk-doc/html/harfbuzz/index.html +3 -3
  323. data/vendor/local/share/gtk-doc/html/harfbuzz/index.sgml +161 -316
  324. data/vendor/local/share/gtk-doc/html/harfbuzz/object-tree.html +31 -4
  325. data/vendor/local/share/gtk-doc/html/harfbuzz/style.css +260 -105
  326. data/vendor/local/share/gtk-doc/html/pango/PangoEngineLang.html +143 -105
  327. data/vendor/local/share/gtk-doc/html/pango/PangoEngineShape.html +150 -108
  328. data/vendor/local/share/gtk-doc/html/pango/PangoFcDecoder.html +163 -112
  329. data/vendor/local/share/gtk-doc/html/pango/PangoFcFont.html +348 -229
  330. data/vendor/local/share/gtk-doc/html/pango/PangoFcFontMap.html +746 -514
  331. data/vendor/local/share/gtk-doc/html/pango/PangoMarkupFormat.html +9 -9
  332. data/vendor/local/share/gtk-doc/html/pango/PangoRenderer.html +853 -623
  333. data/vendor/local/share/gtk-doc/html/pango/annotation-glossary.html +29 -13
  334. data/vendor/local/share/gtk-doc/html/pango/api-index-1-10.html +31 -33
  335. data/vendor/local/share/gtk-doc/html/pango/api-index-1-12.html +10 -12
  336. data/vendor/local/share/gtk-doc/html/pango/api-index-1-14.html +12 -14
  337. data/vendor/local/share/gtk-doc/html/pango/api-index-1-16.html +53 -55
  338. data/vendor/local/share/gtk-doc/html/pango/api-index-1-18.html +28 -30
  339. data/vendor/local/share/gtk-doc/html/pango/api-index-1-2.html +29 -31
  340. data/vendor/local/share/gtk-doc/html/pango/api-index-1-20.html +17 -19
  341. data/vendor/local/share/gtk-doc/html/pango/api-index-1-22.html +28 -30
  342. data/vendor/local/share/gtk-doc/html/pango/api-index-1-24.html +17 -19
  343. data/vendor/local/share/gtk-doc/html/pango/api-index-1-26.html +9 -11
  344. data/vendor/local/share/gtk-doc/html/pango/api-index-1-30.html +6 -6
  345. data/vendor/local/share/gtk-doc/html/pango/api-index-1-31-0.html +6 -6
  346. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32-4.html +11 -13
  347. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32.html +7 -9
  348. data/vendor/local/share/gtk-doc/html/pango/api-index-1-34.html +5 -5
  349. data/vendor/local/share/gtk-doc/html/pango/api-index-1-4.html +49 -51
  350. data/vendor/local/share/gtk-doc/html/pango/api-index-1-6.html +36 -38
  351. data/vendor/local/share/gtk-doc/html/pango/api-index-1-8.html +37 -39
  352. data/vendor/local/share/gtk-doc/html/pango/api-index-deprecated.html +68 -70
  353. data/vendor/local/share/gtk-doc/html/pango/api-index-full.html +568 -570
  354. data/vendor/local/share/gtk-doc/html/pango/index.html +3 -3
  355. data/vendor/local/share/gtk-doc/html/pango/index.sgml +229 -399
  356. data/vendor/local/share/gtk-doc/html/pango/lowlevel.html +4 -4
  357. data/vendor/local/share/gtk-doc/html/pango/pango-Bidirectional-Text.html +345 -259
  358. data/vendor/local/share/gtk-doc/html/pango/pango-Cairo-Rendering.html +979 -664
  359. data/vendor/local/share/gtk-doc/html/pango/pango-CoreText-Fonts.html +70 -43
  360. data/vendor/local/share/gtk-doc/html/pango/pango-Coverage-Maps.html +349 -229
  361. data/vendor/local/share/gtk-doc/html/pango/pango-Engines.html +236 -153
  362. data/vendor/local/share/gtk-doc/html/pango/pango-Fonts.html +3100 -2159
  363. data/vendor/local/share/gtk-doc/html/pango/pango-FreeType-Fonts-and-Rendering.html +659 -472
  364. data/vendor/local/share/gtk-doc/html/pango/pango-Glyph-Storage.html +1952 -1384
  365. data/vendor/local/share/gtk-doc/html/pango/pango-Layout-Objects.html +3050 -2135
  366. data/vendor/local/share/gtk-doc/html/pango/pango-Miscellaneous-Utilities.html +676 -463
  367. data/vendor/local/share/gtk-doc/html/pango/pango-Modules.html +223 -146
  368. data/vendor/local/share/gtk-doc/html/pango/pango-OpenType-Font-Handling.html +1589 -1199
  369. data/vendor/local/share/gtk-doc/html/pango/pango-Scripts-and-Languages.html +1072 -842
  370. data/vendor/local/share/gtk-doc/html/pango/pango-Tab-Stops.html +406 -276
  371. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Attributes.html +2541 -1792
  372. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Processing.html +1479 -1033
  373. data/vendor/local/share/gtk-doc/html/pango/pango-Version-Checking.html +214 -154
  374. data/vendor/local/share/gtk-doc/html/pango/pango-Vertical-Text.html +374 -291
  375. data/vendor/local/share/gtk-doc/html/pango/pango-Win32-Fonts-and-Rendering.html +733 -498
  376. data/vendor/local/share/gtk-doc/html/pango/pango-Xft-Fonts-and-Rendering.html +893 -617
  377. data/vendor/local/share/gtk-doc/html/pango/pango-hierarchy.html +59 -59
  378. data/vendor/local/share/gtk-doc/html/pango/pango-querymodules.html +5 -5
  379. data/vendor/local/share/gtk-doc/html/pango/pango.devhelp2 +578 -782
  380. data/vendor/local/share/gtk-doc/html/pango/pango.html +4 -4
  381. data/vendor/local/share/gtk-doc/html/pango/rendering.html +4 -4
  382. data/vendor/local/share/gtk-doc/html/pango/style.css +260 -105
  383. data/vendor/local/share/gtk-doc/html/pango/tools.html +4 -4
  384. data/vendor/local/share/icu/54.1/config/mh-mingw +158 -0
  385. data/vendor/local/share/icu/54.1/install-sh +251 -0
  386. data/vendor/local/share/icu/54.1/license.html +385 -0
  387. data/vendor/local/share/icu/54.1/mkinstalldirs +43 -0
  388. data/vendor/local/share/license/harfbuzz/AUTHORS +1 -0
  389. data/vendor/local/share/man/man1/derb.1 +196 -0
  390. data/vendor/local/share/man/man1/genbrk.1 +112 -0
  391. data/vendor/local/share/man/man1/gencfu.1 +91 -0
  392. data/vendor/local/share/man/man1/gencnval.1 +91 -0
  393. data/vendor/local/share/man/man1/gendict.1 +131 -0
  394. data/vendor/local/share/man/man1/genrb.1 +146 -0
  395. data/vendor/local/share/man/man1/icu-config.1 +288 -0
  396. data/vendor/local/share/man/man1/makeconv.1 +112 -0
  397. data/vendor/local/share/man/man1/pango-querymodules.1 +2 -2
  398. data/vendor/local/share/man/man1/pango-view.1 +1 -118
  399. data/vendor/local/share/man/man1/pkgdata.1 +258 -0
  400. data/vendor/local/share/man/man1/uconv.1 +443 -0
  401. data/vendor/local/share/man/man8/genccode.8 +106 -0
  402. data/vendor/local/share/man/man8/gencmn.8 +129 -0
  403. data/vendor/local/share/man/man8/gensprep.8 +102 -0
  404. data/vendor/local/share/man/man8/icupkg.8 +204 -0
  405. metadata +266 -14
  406. data/lib/1.9/pango.so +0 -0
  407. data/lib/2.1/pango.so +0 -0
@@ -0,0 +1,158 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2008-2009, International Business Machines Corporation and
4
+ * others. All Rights Reserved.
5
+ *******************************************************************************
6
+ *
7
+ * File DTINTRV.H
8
+ *
9
+ *******************************************************************************
10
+ */
11
+
12
+ #ifndef __DTINTRV_H__
13
+ #define __DTINTRV_H__
14
+
15
+ #include "unicode/utypes.h"
16
+ #include "unicode/uobject.h"
17
+
18
+ /**
19
+ * \file
20
+ * \brief C++ API: Date Interval data type
21
+ */
22
+
23
+
24
+ U_NAMESPACE_BEGIN
25
+
26
+
27
+ /**
28
+ * This class represents a date interval.
29
+ * It is a pair of UDate representing from UDate 1 to UDate 2.
30
+ * @stable ICU 4.0
31
+ **/
32
+ class U_COMMON_API DateInterval : public UObject {
33
+ public:
34
+
35
+ /**
36
+ * Construct a DateInterval given a from date and a to date.
37
+ * @param fromDate The from date in date interval.
38
+ * @param toDate The to date in date interval.
39
+ * @stable ICU 4.0
40
+ */
41
+ DateInterval(UDate fromDate, UDate toDate);
42
+
43
+ /**
44
+ * destructor
45
+ * @stable ICU 4.0
46
+ */
47
+ virtual ~DateInterval();
48
+
49
+ /**
50
+ * Get the from date.
51
+ * @return the from date in dateInterval.
52
+ * @stable ICU 4.0
53
+ */
54
+ UDate getFromDate() const;
55
+
56
+ /**
57
+ * Get the to date.
58
+ * @return the to date in dateInterval.
59
+ * @stable ICU 4.0
60
+ */
61
+ UDate getToDate() const;
62
+
63
+
64
+ /**
65
+ * Return the class ID for this class. This is useful only for comparing to
66
+ * a return value from getDynamicClassID(). For example:
67
+ * <pre>
68
+ * . Base* polymorphic_pointer = createPolymorphicObject();
69
+ * . if (polymorphic_pointer->getDynamicClassID() ==
70
+ * . erived::getStaticClassID()) ...
71
+ * </pre>
72
+ * @return The class ID for all objects of this class.
73
+ * @stable ICU 4.0
74
+ */
75
+ static UClassID U_EXPORT2 getStaticClassID(void);
76
+
77
+ /**
78
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
79
+ * method is to implement a simple version of RTTI, since not all C++
80
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
81
+ * methods call this method.
82
+ *
83
+ * @return The class ID for this object. All objects of a
84
+ * given class have the same class ID. Objects of
85
+ * other classes have different class IDs.
86
+ * @stable ICU 4.0
87
+ */
88
+ virtual UClassID getDynamicClassID(void) const;
89
+
90
+
91
+ /**
92
+ * Copy constructor.
93
+ * @stable ICU 4.0
94
+ */
95
+ DateInterval(const DateInterval& other);
96
+
97
+ /**
98
+ * Default assignment operator
99
+ * @stable ICU 4.0
100
+ */
101
+ DateInterval& operator=(const DateInterval&);
102
+
103
+ /**
104
+ * Equality operator.
105
+ * @return TRUE if the two DateIntervals are the same
106
+ * @stable ICU 4.0
107
+ */
108
+ virtual UBool operator==(const DateInterval& other) const;
109
+
110
+ /**
111
+ * Non-equality operator
112
+ * @return TRUE if the two DateIntervals are not the same
113
+ * @stable ICU 4.0
114
+ */
115
+ UBool operator!=(const DateInterval& other) const;
116
+
117
+
118
+ /**
119
+ * clone this object.
120
+ * The caller owns the result and should delete it when done.
121
+ * @return a cloned DateInterval
122
+ * @stable ICU 4.0
123
+ */
124
+ virtual DateInterval* clone() const;
125
+
126
+ private:
127
+ /**
128
+ * Default constructor, not implemented.
129
+ */
130
+ DateInterval();
131
+
132
+ UDate fromDate;
133
+ UDate toDate;
134
+
135
+ } ;// end class DateInterval
136
+
137
+
138
+ inline UDate
139
+ DateInterval::getFromDate() const {
140
+ return fromDate;
141
+ }
142
+
143
+
144
+ inline UDate
145
+ DateInterval::getToDate() const {
146
+ return toDate;
147
+ }
148
+
149
+
150
+ inline UBool
151
+ DateInterval::operator!=(const DateInterval& other) const {
152
+ return ( !operator==(other) );
153
+ }
154
+
155
+
156
+ U_NAMESPACE_END
157
+
158
+ #endif
@@ -0,0 +1,985 @@
1
+ /********************************************************************************
2
+ * Copyright (C) 2008-2013, International Business Machines Corporation and
3
+ * others. All Rights Reserved.
4
+ *******************************************************************************
5
+ *
6
+ * File DTITVFMT.H
7
+ *
8
+ *******************************************************************************
9
+ */
10
+
11
+ #ifndef __DTITVFMT_H__
12
+ #define __DTITVFMT_H__
13
+
14
+
15
+ #include "unicode/utypes.h"
16
+
17
+ /**
18
+ * \file
19
+ * \brief C++ API: Format and parse date interval in a language-independent manner.
20
+ */
21
+
22
+ #if !UCONFIG_NO_FORMATTING
23
+
24
+ #include "unicode/ucal.h"
25
+ #include "unicode/smpdtfmt.h"
26
+ #include "unicode/dtintrv.h"
27
+ #include "unicode/dtitvinf.h"
28
+ #include "unicode/dtptngen.h"
29
+
30
+ U_NAMESPACE_BEGIN
31
+
32
+
33
+
34
+ /**
35
+ * DateIntervalFormat is a class for formatting and parsing date
36
+ * intervals in a language-independent manner.
37
+ * Only formatting is supported, parsing is not supported.
38
+ *
39
+ * <P>
40
+ * Date interval means from one date to another date,
41
+ * for example, from "Jan 11, 2008" to "Jan 18, 2008".
42
+ * We introduced class DateInterval to represent it.
43
+ * DateInterval is a pair of UDate, which is
44
+ * the standard milliseconds since 24:00 GMT, Jan 1, 1970.
45
+ *
46
+ * <P>
47
+ * DateIntervalFormat formats a DateInterval into
48
+ * text as compactly as possible.
49
+ * For example, the date interval format from "Jan 11, 2008" to "Jan 18,. 2008"
50
+ * is "Jan 11-18, 2008" for English.
51
+ * And it parses text into DateInterval,
52
+ * although initially, parsing is not supported.
53
+ *
54
+ * <P>
55
+ * There is no structural information in date time patterns.
56
+ * For any punctuations and string literals inside a date time pattern,
57
+ * we do not know whether it is just a separator, or a prefix, or a suffix.
58
+ * Without such information, so, it is difficult to generate a sub-pattern
59
+ * (or super-pattern) by algorithm.
60
+ * So, formatting a DateInterval is pattern-driven. It is very
61
+ * similar to formatting in SimpleDateFormat.
62
+ * We introduce class DateIntervalInfo to save date interval
63
+ * patterns, similar to date time pattern in SimpleDateFormat.
64
+ *
65
+ * <P>
66
+ * Logically, the interval patterns are mappings
67
+ * from (skeleton, the_largest_different_calendar_field)
68
+ * to (date_interval_pattern).
69
+ *
70
+ * <P>
71
+ * A skeleton
72
+ * <ol>
73
+ * <li>
74
+ * only keeps the field pattern letter and ignores all other parts
75
+ * in a pattern, such as space, punctuations, and string literals.
76
+ * </li>
77
+ * <li>
78
+ * hides the order of fields.
79
+ * </li>
80
+ * <li>
81
+ * might hide a field's pattern letter length.
82
+ * </li>
83
+ * </ol>
84
+ *
85
+ * For those non-digit calendar fields, the pattern letter length is
86
+ * important, such as MMM, MMMM, and MMMMM; EEE and EEEE,
87
+ * and the field's pattern letter length is honored.
88
+ *
89
+ * For the digit calendar fields, such as M or MM, d or dd, yy or yyyy,
90
+ * the field pattern length is ignored and the best match, which is defined
91
+ * in date time patterns, will be returned without honor the field pattern
92
+ * letter length in skeleton.
93
+ *
94
+ * <P>
95
+ * The calendar fields we support for interval formatting are:
96
+ * year, month, date, day-of-week, am-pm, hour, hour-of-day, and minute.
97
+ * Those calendar fields can be defined in the following order:
98
+ * year > month > date > hour (in day) > minute
99
+ *
100
+ * The largest different calendar fields between 2 calendars is the
101
+ * first different calendar field in above order.
102
+ *
103
+ * For example: the largest different calendar fields between "Jan 10, 2007"
104
+ * and "Feb 20, 2008" is year.
105
+ *
106
+ * <P>
107
+ * For other calendar fields, the compact interval formatting is not
108
+ * supported. And the interval format will be fall back to fall-back
109
+ * patterns, which is mostly "{date0} - {date1}".
110
+ *
111
+ * <P>
112
+ * There is a set of pre-defined static skeleton strings.
113
+ * There are pre-defined interval patterns for those pre-defined skeletons
114
+ * in locales' resource files.
115
+ * For example, for a skeleton UDAT_YEAR_ABBR_MONTH_DAY, which is &quot;yMMMd&quot;,
116
+ * in en_US, if the largest different calendar field between date1 and date2
117
+ * is &quot;year&quot;, the date interval pattern is &quot;MMM d, yyyy - MMM d, yyyy&quot;,
118
+ * such as &quot;Jan 10, 2007 - Jan 10, 2008&quot;.
119
+ * If the largest different calendar field between date1 and date2 is &quot;month&quot;,
120
+ * the date interval pattern is &quot;MMM d - MMM d, yyyy&quot;,
121
+ * such as &quot;Jan 10 - Feb 10, 2007&quot;.
122
+ * If the largest different calendar field between date1 and date2 is &quot;day&quot;,
123
+ * the date interval pattern is &quot;MMM d-d, yyyy&quot;, such as &quot;Jan 10-20, 2007&quot;.
124
+ *
125
+ * For date skeleton, the interval patterns when year, or month, or date is
126
+ * different are defined in resource files.
127
+ * For time skeleton, the interval patterns when am/pm, or hour, or minute is
128
+ * different are defined in resource files.
129
+ *
130
+ * <P>
131
+ * If a skeleton is not found in a locale's DateIntervalInfo, which means
132
+ * the interval patterns for the skeleton is not defined in resource file,
133
+ * the interval pattern will falls back to the interval "fallback" pattern
134
+ * defined in resource file.
135
+ * If the interval "fallback" pattern is not defined, the default fall-back
136
+ * is "{date0} - {data1}".
137
+ *
138
+ * <P>
139
+ * For the combination of date and time,
140
+ * The rule to generate interval patterns are:
141
+ * <ol>
142
+ * <li>
143
+ * when the year, month, or day differs, falls back to fall-back
144
+ * interval pattern, which mostly is the concatenate the two original
145
+ * expressions with a separator between,
146
+ * For example, interval pattern from "Jan 10, 2007 10:10 am"
147
+ * to "Jan 11, 2007 10:10am" is
148
+ * "Jan 10, 2007 10:10 am - Jan 11, 2007 10:10am"
149
+ * </li>
150
+ * <li>
151
+ * otherwise, present the date followed by the range expression
152
+ * for the time.
153
+ * For example, interval pattern from "Jan 10, 2007 10:10 am"
154
+ * to "Jan 10, 2007 11:10am" is "Jan 10, 2007 10:10 am - 11:10am"
155
+ * </li>
156
+ * </ol>
157
+ *
158
+ *
159
+ * <P>
160
+ * If two dates are the same, the interval pattern is the single date pattern.
161
+ * For example, interval pattern from "Jan 10, 2007" to "Jan 10, 2007" is
162
+ * "Jan 10, 2007".
163
+ *
164
+ * Or if the presenting fields between 2 dates have the exact same values,
165
+ * the interval pattern is the single date pattern.
166
+ * For example, if user only requests year and month,
167
+ * the interval pattern from "Jan 10, 2007" to "Jan 20, 2007" is "Jan 2007".
168
+ *
169
+ * <P>
170
+ * DateIntervalFormat needs the following information for correct
171
+ * formatting: time zone, calendar type, pattern, date format symbols,
172
+ * and date interval patterns.
173
+ * It can be instantiated in 2 ways:
174
+ * <ol>
175
+ * <li>
176
+ * create an instance using default or given locale plus given skeleton.
177
+ * Users are encouraged to created date interval formatter this way and
178
+ * to use the pre-defined skeleton macros, such as
179
+ * UDAT_YEAR_NUM_MONTH, which consists the calendar fields and
180
+ * the format style.
181
+ * </li>
182
+ * <li>
183
+ * create an instance using default or given locale plus given skeleton
184
+ * plus a given DateIntervalInfo.
185
+ * This factory method is for powerful users who want to provide their own
186
+ * interval patterns.
187
+ * Locale provides the timezone, calendar, and format symbols information.
188
+ * Local plus skeleton provides full pattern information.
189
+ * DateIntervalInfo provides the date interval patterns.
190
+ * </li>
191
+ * </ol>
192
+ *
193
+ * <P>
194
+ * For the calendar field pattern letter, such as G, y, M, d, a, h, H, m, s etc.
195
+ * DateIntervalFormat uses the same syntax as that of
196
+ * DateTime format.
197
+ *
198
+ * <P>
199
+ * Code Sample: general usage
200
+ * <pre>
201
+ * \code
202
+ * // the date interval object which the DateIntervalFormat formats on
203
+ * // and parses into
204
+ * DateInterval* dtInterval = new DateInterval(1000*3600*24, 1000*3600*24*2);
205
+ * UErrorCode status = U_ZERO_ERROR;
206
+ * DateIntervalFormat* dtIntervalFmt = DateIntervalFormat::createInstance(
207
+ * UDAT_YEAR_MONTH_DAY,
208
+ * Locale("en", "GB", ""), status);
209
+ * UnicodeUnicodeString dateIntervalString;
210
+ * FieldPosition pos = 0;
211
+ * // formatting
212
+ * dtIntervalFmt->format(dtInterval, dateIntervalUnicodeString, pos, status);
213
+ * delete dtIntervalFmt;
214
+ * \endcode
215
+ * </pre>
216
+ */
217
+
218
+ class U_I18N_API DateIntervalFormat : public Format {
219
+ public:
220
+
221
+ /**
222
+ * Construct a DateIntervalFormat from skeleton and the default locale.
223
+ *
224
+ * This is a convenient override of
225
+ * createInstance(const UnicodeString& skeleton, const Locale& locale,
226
+ * UErrorCode&)
227
+ * with the value of locale as default locale.
228
+ *
229
+ * @param skeleton the skeleton on which interval format based.
230
+ * @param status output param set to success/failure code on exit
231
+ * @return a date time interval formatter which the caller owns.
232
+ * @stable ICU 4.0
233
+ */
234
+ static DateIntervalFormat* U_EXPORT2 createInstance(
235
+ const UnicodeString& skeleton,
236
+ UErrorCode& status);
237
+
238
+ /**
239
+ * Construct a DateIntervalFormat from skeleton and a given locale.
240
+ * <P>
241
+ * In this factory method,
242
+ * the date interval pattern information is load from resource files.
243
+ * Users are encouraged to created date interval formatter this way and
244
+ * to use the pre-defined skeleton macros.
245
+ *
246
+ * <P>
247
+ * There are pre-defined skeletons (defined in udate.h) having predefined
248
+ * interval patterns in resource files.
249
+ * Users are encouraged to use those macros.
250
+ * For example:
251
+ * DateIntervalFormat::createInstance(UDAT_MONTH_DAY, status)
252
+ *
253
+ * The given Locale provides the interval patterns.
254
+ * For example, for en_GB, if skeleton is UDAT_YEAR_ABBR_MONTH_WEEKDAY_DAY,
255
+ * which is "yMMMEEEd",
256
+ * the interval patterns defined in resource file to above skeleton are:
257
+ * "EEE, d MMM, yyyy - EEE, d MMM, yyyy" for year differs,
258
+ * "EEE, d MMM - EEE, d MMM, yyyy" for month differs,
259
+ * "EEE, d - EEE, d MMM, yyyy" for day differs,
260
+ * @param skeleton the skeleton on which the interval format is based.
261
+ * @param locale the given locale
262
+ * @param status output param set to success/failure code on exit
263
+ * @return a date time interval formatter which the caller owns.
264
+ * @stable ICU 4.0
265
+ * <p>
266
+ * <h4>Sample code</h4>
267
+ * \snippet samples/dtitvfmtsample/dtitvfmtsample.cpp dtitvfmtPreDefined1
268
+ * \snippet samples/dtitvfmtsample/dtitvfmtsample.cpp dtitvfmtPreDefined
269
+ * <p>
270
+ */
271
+
272
+ static DateIntervalFormat* U_EXPORT2 createInstance(
273
+ const UnicodeString& skeleton,
274
+ const Locale& locale,
275
+ UErrorCode& status);
276
+
277
+ /**
278
+ * Construct a DateIntervalFormat from skeleton
279
+ * DateIntervalInfo, and default locale.
280
+ *
281
+ * This is a convenient override of
282
+ * createInstance(const UnicodeString& skeleton, const Locale& locale,
283
+ * const DateIntervalInfo& dtitvinf, UErrorCode&)
284
+ * with the locale value as default locale.
285
+ *
286
+ * @param skeleton the skeleton on which interval format based.
287
+ * @param dtitvinf the DateIntervalInfo object.
288
+ * @param status output param set to success/failure code on exit
289
+ * @return a date time interval formatter which the caller owns.
290
+ * @stable ICU 4.0
291
+ */
292
+ static DateIntervalFormat* U_EXPORT2 createInstance(
293
+ const UnicodeString& skeleton,
294
+ const DateIntervalInfo& dtitvinf,
295
+ UErrorCode& status);
296
+
297
+ /**
298
+ * Construct a DateIntervalFormat from skeleton
299
+ * a DateIntervalInfo, and the given locale.
300
+ *
301
+ * <P>
302
+ * In this factory method, user provides its own date interval pattern
303
+ * information, instead of using those pre-defined data in resource file.
304
+ * This factory method is for powerful users who want to provide their own
305
+ * interval patterns.
306
+ * <P>
307
+ * There are pre-defined skeletons (defined in udate.h) having predefined
308
+ * interval patterns in resource files.
309
+ * Users are encouraged to use those macros.
310
+ * For example:
311
+ * DateIntervalFormat::createInstance(UDAT_MONTH_DAY, status)
312
+ *
313
+ * The DateIntervalInfo provides the interval patterns.
314
+ * and the DateIntervalInfo ownership remains to the caller.
315
+ *
316
+ * User are encouraged to set default interval pattern in DateIntervalInfo
317
+ * as well, if they want to set other interval patterns ( instead of
318
+ * reading the interval patterns from resource files).
319
+ * When the corresponding interval pattern for a largest calendar different
320
+ * field is not found ( if user not set it ), interval format fallback to
321
+ * the default interval pattern.
322
+ * If user does not provide default interval pattern, it fallback to
323
+ * "{date0} - {date1}"
324
+ *
325
+ * @param skeleton the skeleton on which interval format based.
326
+ * @param locale the given locale
327
+ * @param dtitvinf the DateIntervalInfo object.
328
+ * @param status output param set to success/failure code on exit
329
+ * @return a date time interval formatter which the caller owns.
330
+ * @stable ICU 4.0
331
+ * <p>
332
+ * <h4>Sample code</h4>
333
+ * \snippet samples/dtitvfmtsample/dtitvfmtsample.cpp dtitvfmtPreDefined1
334
+ * \snippet samples/dtitvfmtsample/dtitvfmtsample.cpp dtitvfmtCustomized
335
+ * <p>
336
+ */
337
+ static DateIntervalFormat* U_EXPORT2 createInstance(
338
+ const UnicodeString& skeleton,
339
+ const Locale& locale,
340
+ const DateIntervalInfo& dtitvinf,
341
+ UErrorCode& status);
342
+
343
+ /**
344
+ * Destructor.
345
+ * @stable ICU 4.0
346
+ */
347
+ virtual ~DateIntervalFormat();
348
+
349
+ /**
350
+ * Clone this Format object polymorphically. The caller owns the result and
351
+ * should delete it when done.
352
+ * @return A copy of the object.
353
+ * @stable ICU 4.0
354
+ */
355
+ virtual Format* clone(void) const;
356
+
357
+ /**
358
+ * Return true if the given Format objects are semantically equal. Objects
359
+ * of different subclasses are considered unequal.
360
+ * @param other the object to be compared with.
361
+ * @return true if the given Format objects are semantically equal.
362
+ * @stable ICU 4.0
363
+ */
364
+ virtual UBool operator==(const Format& other) const;
365
+
366
+ /**
367
+ * Return true if the given Format objects are not semantically equal.
368
+ * Objects of different subclasses are considered unequal.
369
+ * @param other the object to be compared with.
370
+ * @return true if the given Format objects are not semantically equal.
371
+ * @stable ICU 4.0
372
+ */
373
+ UBool operator!=(const Format& other) const;
374
+
375
+
376
+ using Format::format;
377
+
378
+ /**
379
+ * Format an object to produce a string. This method handles Formattable
380
+ * objects with a DateInterval type.
381
+ * If a the Formattable object type is not a DateInterval,
382
+ * then it returns a failing UErrorCode.
383
+ *
384
+ * @param obj The object to format.
385
+ * Must be a DateInterval.
386
+ * @param appendTo Output parameter to receive result.
387
+ * Result is appended to existing contents.
388
+ * @param fieldPosition On input: an alignment field, if desired.
389
+ * On output: the offsets of the alignment field.
390
+ * @param status Output param filled with success/failure status.
391
+ * @return Reference to 'appendTo' parameter.
392
+ * @stable ICU 4.0
393
+ */
394
+ virtual UnicodeString& format(const Formattable& obj,
395
+ UnicodeString& appendTo,
396
+ FieldPosition& fieldPosition,
397
+ UErrorCode& status) const ;
398
+
399
+
400
+
401
+ /**
402
+ * Format a DateInterval to produce a string.
403
+ *
404
+ * @param dtInterval DateInterval to be formatted.
405
+ * @param appendTo Output parameter to receive result.
406
+ * Result is appended to existing contents.
407
+ * @param fieldPosition On input: an alignment field, if desired.
408
+ * On output: the offsets of the alignment field.
409
+ * @param status Output param filled with success/failure status.
410
+ * @return Reference to 'appendTo' parameter.
411
+ * @stable ICU 4.0
412
+ */
413
+ UnicodeString& format(const DateInterval* dtInterval,
414
+ UnicodeString& appendTo,
415
+ FieldPosition& fieldPosition,
416
+ UErrorCode& status) const ;
417
+
418
+
419
+ /**
420
+ * Format 2 Calendars to produce a string.
421
+ *
422
+ * Note: "fromCalendar" and "toCalendar" are not const,
423
+ * since calendar is not const in SimpleDateFormat::format(Calendar&),
424
+ *
425
+ * @param fromCalendar calendar set to the from date in date interval
426
+ * to be formatted into date interval string
427
+ * @param toCalendar calendar set to the to date in date interval
428
+ * to be formatted into date interval string
429
+ * @param appendTo Output parameter to receive result.
430
+ * Result is appended to existing contents.
431
+ * @param fieldPosition On input: an alignment field, if desired.
432
+ * On output: the offsets of the alignment field.
433
+ * @param status Output param filled with success/failure status.
434
+ * Caller needs to make sure it is SUCCESS
435
+ * at the function entrance
436
+ * @return Reference to 'appendTo' parameter.
437
+ * @stable ICU 4.0
438
+ */
439
+ UnicodeString& format(Calendar& fromCalendar,
440
+ Calendar& toCalendar,
441
+ UnicodeString& appendTo,
442
+ FieldPosition& fieldPosition,
443
+ UErrorCode& status) const ;
444
+
445
+ /**
446
+ * Date interval parsing is not supported. Please do not use.
447
+ * <P>
448
+ * This method should handle parsing of
449
+ * date time interval strings into Formattable objects with
450
+ * DateInterval type, which is a pair of UDate.
451
+ * <P>
452
+ * Before calling, set parse_pos.index to the offset you want to start
453
+ * parsing at in the source. After calling, parse_pos.index is the end of
454
+ * the text you parsed. If error occurs, index is unchanged.
455
+ * <P>
456
+ * When parsing, leading whitespace is discarded (with a successful parse),
457
+ * while trailing whitespace is left as is.
458
+ * <P>
459
+ * See Format::parseObject() for more.
460
+ *
461
+ * @param source The string to be parsed into an object.
462
+ * @param result Formattable to be set to the parse result.
463
+ * If parse fails, return contents are undefined.
464
+ * @param parse_pos The position to start parsing at. Since no parsing
465
+ * is supported, upon return this param is unchanged.
466
+ * @return A newly created Formattable* object, or NULL
467
+ * on failure. The caller owns this and should
468
+ * delete it when done.
469
+ * @internal ICU 4.0
470
+ */
471
+ virtual void parseObject(const UnicodeString& source,
472
+ Formattable& result,
473
+ ParsePosition& parse_pos) const;
474
+
475
+
476
+ /**
477
+ * Gets the date time interval patterns.
478
+ * @return the date time interval patterns associated with
479
+ * this date interval formatter.
480
+ * @stable ICU 4.0
481
+ */
482
+ const DateIntervalInfo* getDateIntervalInfo(void) const;
483
+
484
+
485
+ /**
486
+ * Set the date time interval patterns.
487
+ * @param newIntervalPatterns the given interval patterns to copy.
488
+ * @param status output param set to success/failure code on exit
489
+ * @stable ICU 4.0
490
+ */
491
+ void setDateIntervalInfo(const DateIntervalInfo& newIntervalPatterns,
492
+ UErrorCode& status);
493
+
494
+
495
+ /**
496
+ * Gets the date formatter
497
+ * @return the date formatter associated with this date interval formatter.
498
+ * @stable ICU 4.0
499
+ */
500
+ const DateFormat* getDateFormat(void) const;
501
+
502
+ /**
503
+ * Returns a reference to the TimeZone used by this DateIntervalFormat's calendar.
504
+ * @return the time zone associated with the calendar of DateIntervalFormat.
505
+ * @stable ICU 4.8
506
+ */
507
+ virtual const TimeZone& getTimeZone(void) const;
508
+
509
+ /**
510
+ * Sets the time zone for the calendar used by this DateIntervalFormat object. The
511
+ * caller no longer owns the TimeZone object and should not delete it after this call.
512
+ * @param zoneToAdopt the TimeZone to be adopted.
513
+ * @stable ICU 4.8
514
+ */
515
+ virtual void adoptTimeZone(TimeZone* zoneToAdopt);
516
+
517
+ /**
518
+ * Sets the time zone for the calendar used by this DateIntervalFormat object.
519
+ * @param zone the new time zone.
520
+ * @stable ICU 4.8
521
+ */
522
+ virtual void setTimeZone(const TimeZone& zone);
523
+
524
+ /**
525
+ * Return the class ID for this class. This is useful only for comparing to
526
+ * a return value from getDynamicClassID(). For example:
527
+ * <pre>
528
+ * . Base* polymorphic_pointer = createPolymorphicObject();
529
+ * . if (polymorphic_pointer->getDynamicClassID() ==
530
+ * . erived::getStaticClassID()) ...
531
+ * </pre>
532
+ * @return The class ID for all objects of this class.
533
+ * @stable ICU 4.0
534
+ */
535
+ static UClassID U_EXPORT2 getStaticClassID(void);
536
+
537
+ /**
538
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
539
+ * method is to implement a simple version of RTTI, since not all C++
540
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
541
+ * methods call this method.
542
+ *
543
+ * @return The class ID for this object. All objects of a
544
+ * given class have the same class ID. Objects of
545
+ * other classes have different class IDs.
546
+ * @stable ICU 4.0
547
+ */
548
+ virtual UClassID getDynamicClassID(void) const;
549
+
550
+ protected:
551
+
552
+ /**
553
+ * Copy constructor.
554
+ * @stable ICU 4.0
555
+ */
556
+ DateIntervalFormat(const DateIntervalFormat&);
557
+
558
+ /**
559
+ * Assignment operator.
560
+ * @stable ICU 4.0
561
+ */
562
+ DateIntervalFormat& operator=(const DateIntervalFormat&);
563
+
564
+ private:
565
+
566
+ /*
567
+ * This is for ICU internal use only. Please do not use.
568
+ * Save the interval pattern information.
569
+ * Interval pattern consists of 2 single date patterns and the separator.
570
+ * For example, interval pattern "MMM d - MMM d, yyyy" consists
571
+ * a single date pattern "MMM d", another single date pattern "MMM d, yyyy",
572
+ * and a separator "-".
573
+ * The pattern is divided into 2 parts. For above example,
574
+ * the first part is "MMM d - ", and the second part is "MMM d, yyyy".
575
+ * Also, the first date appears in an interval pattern could be
576
+ * the earlier date or the later date.
577
+ * And such information is saved in the interval pattern as well.
578
+ */
579
+ struct PatternInfo {
580
+ UnicodeString firstPart;
581
+ UnicodeString secondPart;
582
+ /**
583
+ * Whether the first date in interval pattern is later date or not.
584
+ * Fallback format set the default ordering.
585
+ * And for a particular interval pattern, the order can be
586
+ * overriden by prefixing the interval pattern with "latestFirst:" or
587
+ * "earliestFirst:"
588
+ * For example, given 2 date, Jan 10, 2007 to Feb 10, 2007.
589
+ * if the fallback format is "{0} - {1}",
590
+ * and the pattern is "d MMM - d MMM yyyy", the interval format is
591
+ * "10 Jan - 10 Feb, 2007".
592
+ * If the pattern is "latestFirst:d MMM - d MMM yyyy",
593
+ * the interval format is "10 Feb - 10 Jan, 2007"
594
+ */
595
+ UBool laterDateFirst;
596
+ };
597
+
598
+
599
+ /**
600
+ * default constructor
601
+ * @internal ICU 4.0
602
+ */
603
+ DateIntervalFormat();
604
+
605
+ /**
606
+ * Construct a DateIntervalFormat from DateFormat,
607
+ * a DateIntervalInfo, and skeleton.
608
+ * DateFormat provides the timezone, calendar,
609
+ * full pattern, and date format symbols information.
610
+ * It should be a SimpleDateFormat object which
611
+ * has a pattern in it.
612
+ * the DateIntervalInfo provides the interval patterns.
613
+ *
614
+ * Note: the DateIntervalFormat takes ownership of both
615
+ * DateFormat and DateIntervalInfo objects.
616
+ * Caller should not delete them.
617
+ *
618
+ * @param locale the locale of this date interval formatter.
619
+ * @param dtItvInfo the DateIntervalInfo object to be adopted.
620
+ * @param skeleton the skeleton of the date formatter
621
+ * @param status output param set to success/failure code on exit
622
+ */
623
+ DateIntervalFormat(const Locale& locale, DateIntervalInfo* dtItvInfo,
624
+ const UnicodeString* skeleton, UErrorCode& status);
625
+
626
+
627
+ /**
628
+ * Construct a DateIntervalFormat from DateFormat
629
+ * and a DateIntervalInfo.
630
+ *
631
+ * It is a wrapper of the constructor.
632
+ *
633
+ * @param locale the locale of this date interval formatter.
634
+ * @param dtitvinf the DateIntervalInfo object to be adopted.
635
+ * @param skeleton the skeleton of this formatter.
636
+ * @param status Output param set to success/failure code.
637
+ * @return a date time interval formatter which the caller owns.
638
+ */
639
+ static DateIntervalFormat* U_EXPORT2 create(const Locale& locale,
640
+ DateIntervalInfo* dtitvinf,
641
+ const UnicodeString* skeleton,
642
+ UErrorCode& status);
643
+
644
+ /**
645
+ * Create a simple date/time formatter from skeleton, given locale,
646
+ * and date time pattern generator.
647
+ *
648
+ * @param skeleton the skeleton on which date format based.
649
+ * @param locale the given locale.
650
+ * @param dtpng the date time pattern generator.
651
+ * @param status Output param to be set to success/failure code.
652
+ * If it is failure, the returned date formatter will
653
+ * be NULL.
654
+ * @return a simple date formatter which the caller owns.
655
+ */
656
+ static SimpleDateFormat* U_EXPORT2 createSDFPatternInstance(
657
+ const UnicodeString& skeleton,
658
+ const Locale& locale,
659
+ DateTimePatternGenerator* dtpng,
660
+ UErrorCode& status);
661
+
662
+
663
+ /**
664
+ * Below are for generating interval patterns local to the formatter
665
+ */
666
+
667
+
668
+ /**
669
+ * Format 2 Calendars using fall-back interval pattern
670
+ *
671
+ * The full pattern used in this fall-back format is the
672
+ * full pattern of the date formatter.
673
+ *
674
+ * @param fromCalendar calendar set to the from date in date interval
675
+ * to be formatted into date interval string
676
+ * @param toCalendar calendar set to the to date in date interval
677
+ * to be formatted into date interval string
678
+ * @param appendTo Output parameter to receive result.
679
+ * Result is appended to existing contents.
680
+ * @param pos On input: an alignment field, if desired.
681
+ * On output: the offsets of the alignment field.
682
+ * @param status output param set to success/failure code on exit
683
+ * @return Reference to 'appendTo' parameter.
684
+ */
685
+ UnicodeString& fallbackFormat(Calendar& fromCalendar,
686
+ Calendar& toCalendar,
687
+ UnicodeString& appendTo,
688
+ FieldPosition& pos,
689
+ UErrorCode& status) const;
690
+
691
+
692
+
693
+ /**
694
+ * Initialize interval patterns locale to this formatter
695
+ *
696
+ * This code is a bit complicated since
697
+ * 1. the interval patterns saved in resource bundle files are interval
698
+ * patterns based on date or time only.
699
+ * It does not have interval patterns based on both date and time.
700
+ * Interval patterns on both date and time are algorithm generated.
701
+ *
702
+ * For example, it has interval patterns on skeleton "dMy" and "hm",
703
+ * but it does not have interval patterns on skeleton "dMyhm".
704
+ *
705
+ * The rule to generate interval patterns for both date and time skeleton are
706
+ * 1) when the year, month, or day differs, concatenate the two original
707
+ * expressions with a separator between,
708
+ * For example, interval pattern from "Jan 10, 2007 10:10 am"
709
+ * to "Jan 11, 2007 10:10am" is
710
+ * "Jan 10, 2007 10:10 am - Jan 11, 2007 10:10am"
711
+ *
712
+ * 2) otherwise, present the date followed by the range expression
713
+ * for the time.
714
+ * For example, interval pattern from "Jan 10, 2007 10:10 am"
715
+ * to "Jan 10, 2007 11:10am" is
716
+ * "Jan 10, 2007 10:10 am - 11:10am"
717
+ *
718
+ * 2. even a pattern does not request a certain calendar field,
719
+ * the interval pattern needs to include such field if such fields are
720
+ * different between 2 dates.
721
+ * For example, a pattern/skeleton is "hm", but the interval pattern
722
+ * includes year, month, and date when year, month, and date differs.
723
+ *
724
+ *
725
+ * @param status output param set to success/failure code on exit
726
+ */
727
+ void initializePattern(UErrorCode& status);
728
+
729
+
730
+
731
+ /**
732
+ * Set fall back interval pattern given a calendar field,
733
+ * a skeleton, and a date time pattern generator.
734
+ * @param field the largest different calendar field
735
+ * @param skeleton a skeleton
736
+ * @param status output param set to success/failure code on exit
737
+ */
738
+ void setFallbackPattern(UCalendarDateFields field,
739
+ const UnicodeString& skeleton,
740
+ UErrorCode& status);
741
+
742
+
743
+
744
+ /**
745
+ * get separated date and time skeleton from a combined skeleton.
746
+ *
747
+ * The difference between date skeleton and normalizedDateSkeleton are:
748
+ * 1. both 'y' and 'd' are appeared only once in normalizeDateSkeleton
749
+ * 2. 'E' and 'EE' are normalized into 'EEE'
750
+ * 3. 'MM' is normalized into 'M'
751
+ *
752
+ ** the difference between time skeleton and normalizedTimeSkeleton are:
753
+ * 1. both 'H' and 'h' are normalized as 'h' in normalized time skeleton,
754
+ * 2. 'a' is omitted in normalized time skeleton.
755
+ * 3. there is only one appearance for 'h', 'm','v', 'z' in normalized time
756
+ * skeleton
757
+ *
758
+ *
759
+ * @param skeleton given combined skeleton.
760
+ * @param date Output parameter for date only skeleton.
761
+ * @param normalizedDate Output parameter for normalized date only
762
+ *
763
+ * @param time Output parameter for time only skeleton.
764
+ * @param normalizedTime Output parameter for normalized time only
765
+ * skeleton.
766
+ *
767
+ */
768
+ static void U_EXPORT2 getDateTimeSkeleton(const UnicodeString& skeleton,
769
+ UnicodeString& date,
770
+ UnicodeString& normalizedDate,
771
+ UnicodeString& time,
772
+ UnicodeString& normalizedTime);
773
+
774
+
775
+
776
+ /**
777
+ * Generate date or time interval pattern from resource,
778
+ * and set them into the interval pattern locale to this formatter.
779
+ *
780
+ * It needs to handle the following:
781
+ * 1. need to adjust field width.
782
+ * For example, the interval patterns saved in DateIntervalInfo
783
+ * includes "dMMMy", but not "dMMMMy".
784
+ * Need to get interval patterns for dMMMMy from dMMMy.
785
+ * Another example, the interval patterns saved in DateIntervalInfo
786
+ * includes "hmv", but not "hmz".
787
+ * Need to get interval patterns for "hmz' from 'hmv'
788
+ *
789
+ * 2. there might be no pattern for 'y' differ for skeleton "Md",
790
+ * in order to get interval patterns for 'y' differ,
791
+ * need to look for it from skeleton 'yMd'
792
+ *
793
+ * @param dateSkeleton normalized date skeleton
794
+ * @param timeSkeleton normalized time skeleton
795
+ * @return whether the resource is found for the skeleton.
796
+ * TRUE if interval pattern found for the skeleton,
797
+ * FALSE otherwise.
798
+ */
799
+ UBool setSeparateDateTimePtn(const UnicodeString& dateSkeleton,
800
+ const UnicodeString& timeSkeleton);
801
+
802
+
803
+
804
+
805
+ /**
806
+ * Generate interval pattern from existing resource
807
+ *
808
+ * It not only save the interval patterns,
809
+ * but also return the extended skeleton and its best match skeleton.
810
+ *
811
+ * @param field largest different calendar field
812
+ * @param skeleton skeleton
813
+ * @param bestSkeleton the best match skeleton which has interval pattern
814
+ * defined in resource
815
+ * @param differenceInfo the difference between skeleton and best skeleton
816
+ * 0 means the best matched skeleton is the same as input skeleton
817
+ * 1 means the fields are the same, but field width are different
818
+ * 2 means the only difference between fields are v/z,
819
+ * -1 means there are other fields difference
820
+ *
821
+ * @param extendedSkeleton extended skeleton
822
+ * @param extendedBestSkeleton extended best match skeleton
823
+ * @return whether the interval pattern is found
824
+ * through extending skeleton or not.
825
+ * TRUE if interval pattern is found by
826
+ * extending skeleton, FALSE otherwise.
827
+ */
828
+ UBool setIntervalPattern(UCalendarDateFields field,
829
+ const UnicodeString* skeleton,
830
+ const UnicodeString* bestSkeleton,
831
+ int8_t differenceInfo,
832
+ UnicodeString* extendedSkeleton = NULL,
833
+ UnicodeString* extendedBestSkeleton = NULL);
834
+
835
+ /**
836
+ * Adjust field width in best match interval pattern to match
837
+ * the field width in input skeleton.
838
+ *
839
+ * TODO (xji) make a general solution
840
+ * The adjusting rule can be:
841
+ * 1. always adjust
842
+ * 2. never adjust
843
+ * 3. default adjust, which means adjust according to the following rules
844
+ * 3.1 always adjust string, such as MMM and MMMM
845
+ * 3.2 never adjust between string and numeric, such as MM and MMM
846
+ * 3.3 always adjust year
847
+ * 3.4 do not adjust 'd', 'h', or 'm' if h presents
848
+ * 3.5 do not adjust 'M' if it is numeric(?)
849
+ *
850
+ * Since date interval format is well-formed format,
851
+ * date and time skeletons are normalized previously,
852
+ * till this stage, the adjust here is only "adjust strings, such as MMM
853
+ * and MMMM, EEE and EEEE.
854
+ *
855
+ * @param inputSkeleton the input skeleton
856
+ * @param bestMatchSkeleton the best match skeleton
857
+ * @param bestMatchIntervalPattern the best match interval pattern
858
+ * @param differenceInfo the difference between 2 skeletons
859
+ * 1 means only field width differs
860
+ * 2 means v/z exchange
861
+ * @param adjustedIntervalPattern adjusted interval pattern
862
+ */
863
+ static void U_EXPORT2 adjustFieldWidth(
864
+ const UnicodeString& inputSkeleton,
865
+ const UnicodeString& bestMatchSkeleton,
866
+ const UnicodeString& bestMatchIntervalPattern,
867
+ int8_t differenceInfo,
868
+ UnicodeString& adjustedIntervalPattern);
869
+
870
+ /**
871
+ * Concat a single date pattern with a time interval pattern,
872
+ * set it into the intervalPatterns, while field is time field.
873
+ * This is used to handle time interval patterns on skeleton with
874
+ * both time and date. Present the date followed by
875
+ * the range expression for the time.
876
+ * @param format date and time format
877
+ * @param formatLen format string length
878
+ * @param datePattern date pattern
879
+ * @param field time calendar field: AM_PM, HOUR, MINUTE
880
+ * @param status output param set to success/failure code on exit
881
+ */
882
+ void concatSingleDate2TimeInterval(const UChar* format,
883
+ int32_t formatLen,
884
+ const UnicodeString& datePattern,
885
+ UCalendarDateFields field,
886
+ UErrorCode& status);
887
+
888
+ /**
889
+ * check whether a calendar field present in a skeleton.
890
+ * @param field calendar field need to check
891
+ * @param skeleton given skeleton on which to check the calendar field
892
+ * @return true if field present in a skeleton.
893
+ */
894
+ static UBool U_EXPORT2 fieldExistsInSkeleton(UCalendarDateFields field,
895
+ const UnicodeString& skeleton);
896
+
897
+
898
+ /**
899
+ * Split interval patterns into 2 part.
900
+ * @param intervalPattern interval pattern
901
+ * @return the index in interval pattern which split the pattern into 2 part
902
+ */
903
+ static int32_t U_EXPORT2 splitPatternInto2Part(const UnicodeString& intervalPattern);
904
+
905
+
906
+ /**
907
+ * Break interval patterns as 2 part and save them into pattern info.
908
+ * @param field calendar field
909
+ * @param intervalPattern interval pattern
910
+ */
911
+ void setIntervalPattern(UCalendarDateFields field,
912
+ const UnicodeString& intervalPattern);
913
+
914
+
915
+ /**
916
+ * Break interval patterns as 2 part and save them into pattern info.
917
+ * @param field calendar field
918
+ * @param intervalPattern interval pattern
919
+ * @param laterDateFirst whether later date appear first in interval pattern
920
+ */
921
+ void setIntervalPattern(UCalendarDateFields field,
922
+ const UnicodeString& intervalPattern,
923
+ UBool laterDateFirst);
924
+
925
+
926
+ /**
927
+ * Set pattern information.
928
+ *
929
+ * @param field calendar field
930
+ * @param firstPart the first part in interval pattern
931
+ * @param secondPart the second part in interval pattern
932
+ * @param laterDateFirst whether the first date in intervalPattern
933
+ * is earlier date or later date
934
+ */
935
+ void setPatternInfo(UCalendarDateFields field,
936
+ const UnicodeString* firstPart,
937
+ const UnicodeString* secondPart,
938
+ UBool laterDateFirst);
939
+
940
+
941
+ // from calendar field to pattern letter
942
+ static const UChar fgCalendarFieldToPatternLetter[];
943
+
944
+
945
+ /**
946
+ * The interval patterns for this locale.
947
+ */
948
+ DateIntervalInfo* fInfo;
949
+
950
+ /**
951
+ * The DateFormat object used to format single pattern
952
+ */
953
+ SimpleDateFormat* fDateFormat;
954
+
955
+ /**
956
+ * The 2 calendars with the from and to date.
957
+ * could re-use the calendar in fDateFormat,
958
+ * but keeping 2 calendars make it clear and clean.
959
+ */
960
+ Calendar* fFromCalendar;
961
+ Calendar* fToCalendar;
962
+
963
+ /**
964
+ * Date time pattern generator
965
+ */
966
+ DateTimePatternGenerator* fDtpng;
967
+
968
+ /**
969
+ * Following are interval information relavent (locale) to this formatter.
970
+ */
971
+ UnicodeString fSkeleton;
972
+ PatternInfo fIntervalPatterns[DateIntervalInfo::kIPI_MAX_INDEX];
973
+ };
974
+
975
+ inline UBool
976
+ DateIntervalFormat::operator!=(const Format& other) const {
977
+ return !operator==(other);
978
+ }
979
+
980
+ U_NAMESPACE_END
981
+
982
+ #endif /* #if !UCONFIG_NO_FORMATTING */
983
+
984
+ #endif // _DTITVFMT_H__
985
+ //eof