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,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