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,404 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2011-2014, International Business Machines Corporation and
4
+ * others. All Rights Reserved.
5
+ *******************************************************************************
6
+ */
7
+ #ifndef __TZNAMES_H
8
+ #define __TZNAMES_H
9
+
10
+ /**
11
+ * \file
12
+ * \brief C++ API: TimeZoneNames
13
+ */
14
+ #include "unicode/utypes.h"
15
+
16
+ #if !UCONFIG_NO_FORMATTING
17
+
18
+ #include "unicode/uloc.h"
19
+ #include "unicode/unistr.h"
20
+
21
+ U_CDECL_BEGIN
22
+
23
+ /**
24
+ * Constants for time zone display name types.
25
+ * @stable ICU 50
26
+ */
27
+ typedef enum UTimeZoneNameType {
28
+ /**
29
+ * Unknown display name type.
30
+ * @stable ICU 50
31
+ */
32
+ UTZNM_UNKNOWN = 0x00,
33
+ /**
34
+ * Long display name, such as "Eastern Time".
35
+ * @stable ICU 50
36
+ */
37
+ UTZNM_LONG_GENERIC = 0x01,
38
+ /**
39
+ * Long display name for standard time, such as "Eastern Standard Time".
40
+ * @stable ICU 50
41
+ */
42
+ UTZNM_LONG_STANDARD = 0x02,
43
+ /**
44
+ * Long display name for daylight saving time, such as "Eastern Daylight Time".
45
+ * @stable ICU 50
46
+ */
47
+ UTZNM_LONG_DAYLIGHT = 0x04,
48
+ /**
49
+ * Short display name, such as "ET".
50
+ * @stable ICU 50
51
+ */
52
+ UTZNM_SHORT_GENERIC = 0x08,
53
+ /**
54
+ * Short display name for standard time, such as "EST".
55
+ * @stable ICU 50
56
+ */
57
+ UTZNM_SHORT_STANDARD = 0x10,
58
+ /**
59
+ * Short display name for daylight saving time, such as "EDT".
60
+ * @stable ICU 50
61
+ */
62
+ UTZNM_SHORT_DAYLIGHT = 0x20,
63
+ /**
64
+ * Exemplar location name, such as "Los Angeles".
65
+ * @stable ICU 51
66
+ */
67
+ UTZNM_EXEMPLAR_LOCATION = 0x40
68
+ } UTimeZoneNameType;
69
+
70
+ U_CDECL_END
71
+
72
+ U_NAMESPACE_BEGIN
73
+
74
+ class UVector;
75
+ struct MatchInfo;
76
+
77
+ /**
78
+ * <code>TimeZoneNames</code> is an abstract class representing the time zone display name data model defined
79
+ * by <a href="http://www.unicode.org/reports/tr35/">UTS#35 Unicode Locale Data Markup Language (LDML)</a>.
80
+ * The model defines meta zone, which is used for storing a set of display names. A meta zone can be shared
81
+ * by multiple time zones. Also a time zone may have multiple meta zone historic mappings.
82
+ * <p>
83
+ * For example, people in the United States refer the zone used by the east part of North America as "Eastern Time".
84
+ * The tz database contains multiple time zones "America/New_York", "America/Detroit", "America/Montreal" and some
85
+ * others that belong to "Eastern Time". However, assigning different display names to these time zones does not make
86
+ * much sense for most of people.
87
+ * <p>
88
+ * In <a href="http://cldr.unicode.org/">CLDR</a> (which uses LDML for representing locale data), the display name
89
+ * "Eastern Time" is stored as long generic display name of a meta zone identified by the ID "America_Eastern".
90
+ * Then, there is another table maintaining the historic mapping to meta zones for each time zone. The time zones in
91
+ * the above example ("America/New_York", "America/Detroit"...) are mapped to the meta zone "America_Eastern".
92
+ * <p>
93
+ * Sometimes, a time zone is mapped to a different time zone in the past. For example, "America/Indiana/Knox"
94
+ * had been moving "Eastern Time" and "Central Time" back and forth. Therefore, it is necessary that time zone
95
+ * to meta zones mapping data are stored by date range.
96
+ *
97
+ * <p><b>Note:</b>
98
+ * The methods in this class assume that time zone IDs are already canonicalized. For example, you may not get proper
99
+ * result returned by a method with time zone ID "America/Indiana/Indianapolis", because it's not a canonical time zone
100
+ * ID (the canonical time zone ID for the time zone is "America/Indianapolis". See
101
+ * {@link TimeZone#getCanonicalID(const UnicodeString& id, UnicodeString& canonicalID, UErrorCode& status)} about ICU
102
+ * canonical time zone IDs.
103
+ *
104
+ * <p>
105
+ * In CLDR, most of time zone display names except location names are provided through meta zones. But a time zone may
106
+ * have a specific name that is not shared with other time zones.
107
+ *
108
+ * For example, time zone "Europe/London" has English long name for standard time "Greenwich Mean Time", which is also
109
+ * shared with other time zones. However, the long name for daylight saving time is "British Summer Time", which is only
110
+ * used for "Europe/London".
111
+ *
112
+ * <p>
113
+ * {@link #getTimeZoneDisplayName} is designed for accessing a name only used by a single time zone.
114
+ * But is not necessarily mean that a subclass implementation use the same model with CLDR. A subclass implementation
115
+ * may provide time zone names only through {@link #getTimeZoneDisplayName}, or only through {@link #getMetaZoneDisplayName},
116
+ * or both.
117
+ *
118
+ * <p>
119
+ * The default <code>TimeZoneNames</code> implementation returned by {@link #createInstance}
120
+ * uses the locale data imported from CLDR. In CLDR, set of meta zone IDs and mappings between zone IDs and meta zone
121
+ * IDs are shared by all locales. Therefore, the behavior of {@link #getAvailableMetaZoneIDs},
122
+ * {@link #getMetaZoneID}, and {@link #getReferenceZoneID} won't be changed no matter
123
+ * what locale is used for getting an instance of <code>TimeZoneNames</code>.
124
+ *
125
+ * @stable ICU 50
126
+ */
127
+ class U_I18N_API TimeZoneNames : public UObject {
128
+ public:
129
+ /**
130
+ * Destructor.
131
+ * @stable ICU 50
132
+ */
133
+ virtual ~TimeZoneNames();
134
+
135
+ /**
136
+ * Return true if the given TimeZoneNames objects are emantically equal.
137
+ * @param other the object to be compared with.
138
+ * @return Return TRUE if the given Format objects are semantically equal.
139
+ * @stable ICU 50
140
+ */
141
+ virtual UBool operator==(const TimeZoneNames& other) const = 0;
142
+
143
+ /**
144
+ * Return true if the given TimeZoneNames objects are not semantically
145
+ * equal.
146
+ * @param other the object to be compared with.
147
+ * @return Return TRUE if the given Format objects are not semantically equal.
148
+ * @stable ICU 50
149
+ */
150
+ UBool operator!=(const TimeZoneNames& other) const { return !operator==(other); }
151
+
152
+ /**
153
+ * Clone this object polymorphically. The caller is responsible
154
+ * for deleting the result when done.
155
+ * @return A copy of the object
156
+ * @stable ICU 50
157
+ */
158
+ virtual TimeZoneNames* clone() const = 0;
159
+
160
+ /**
161
+ * Returns an instance of <code>TimeZoneNames</code> for the specified locale.
162
+ *
163
+ * @param locale The locale.
164
+ * @param status Receives the status.
165
+ * @return An instance of <code>TimeZoneNames</code>
166
+ * @stable ICU 50
167
+ */
168
+ static TimeZoneNames* U_EXPORT2 createInstance(const Locale& locale, UErrorCode& status);
169
+
170
+ #ifndef U_HIDE_DRAFT_API
171
+ /**
172
+ * Returns an instance of <code>TimeZoneNames</code> containing only short specific
173
+ * zone names (SHORT_STANDARD and SHORT_DAYLIGHT),
174
+ * compatible with the IANA tz database's zone abbreviations (not localized).
175
+ * <br>
176
+ * Note: The input locale is used for resolving ambiguous names (e.g. "IST" is parsed
177
+ * as Israel Standard Time for Israel, while it is parsed as India Standard Time for
178
+ * all other regions). The zone names returned by this instance are not localized.
179
+ * @draft ICU 54
180
+ */
181
+ static TimeZoneNames* U_EXPORT2 createTZDBInstance(const Locale& locale, UErrorCode& status);
182
+ #endif /* U_HIDE_DRAFT_API */
183
+
184
+ /**
185
+ * Returns an enumeration of all available meta zone IDs.
186
+ * @param status Receives the status.
187
+ * @return an enumeration object, owned by the caller.
188
+ * @stable ICU 50
189
+ */
190
+ virtual StringEnumeration* getAvailableMetaZoneIDs(UErrorCode& status) const = 0;
191
+
192
+ /**
193
+ * Returns an enumeration of all available meta zone IDs used by the given time zone.
194
+ * @param tzID The canoical tiem zone ID.
195
+ * @param status Receives the status.
196
+ * @return an enumeration object, owned by the caller.
197
+ * @stable ICU 50
198
+ */
199
+ virtual StringEnumeration* getAvailableMetaZoneIDs(const UnicodeString& tzID, UErrorCode& status) const = 0;
200
+
201
+ /**
202
+ * Returns the meta zone ID for the given canonical time zone ID at the given date.
203
+ * @param tzID The canonical time zone ID.
204
+ * @param date The date.
205
+ * @param mzID Receives the meta zone ID for the given time zone ID at the given date. If the time zone does not have a
206
+ * corresponding meta zone at the given date or the implementation does not support meta zones, "bogus" state
207
+ * is set.
208
+ * @return A reference to the result.
209
+ * @stable ICU 50
210
+ */
211
+ virtual UnicodeString& getMetaZoneID(const UnicodeString& tzID, UDate date, UnicodeString& mzID) const = 0;
212
+
213
+ /**
214
+ * Returns the reference zone ID for the given meta zone ID for the region.
215
+ *
216
+ * Note: Each meta zone must have a reference zone associated with a special region "001" (world).
217
+ * Some meta zones may have region specific reference zone IDs other than the special region
218
+ * "001". When a meta zone does not have any region specific reference zone IDs, this method
219
+ * return the reference zone ID for the special region "001" (world).
220
+ *
221
+ * @param mzID The meta zone ID.
222
+ * @param region The region.
223
+ * @param tzID Receives the reference zone ID ("golden zone" in the LDML specification) for the given time zone ID for the
224
+ * region. If the meta zone is unknown or the implementation does not support meta zones, "bogus" state
225
+ * is set.
226
+ * @return A reference to the result.
227
+ * @stable ICU 50
228
+ */
229
+ virtual UnicodeString& getReferenceZoneID(const UnicodeString& mzID, const char* region, UnicodeString& tzID) const = 0;
230
+
231
+ /**
232
+ * Returns the display name of the meta zone.
233
+ * @param mzID The meta zone ID.
234
+ * @param type The display name type. See {@link #UTimeZoneNameType}.
235
+ * @param name Receives the display name of the meta zone. When this object does not have a localized display name for the given
236
+ * meta zone with the specified type or the implementation does not provide any display names associated
237
+ * with meta zones, "bogus" state is set.
238
+ * @return A reference to the result.
239
+ * @stable ICU 50
240
+ */
241
+ virtual UnicodeString& getMetaZoneDisplayName(const UnicodeString& mzID, UTimeZoneNameType type, UnicodeString& name) const = 0;
242
+
243
+ /**
244
+ * Returns the display name of the time zone. Unlike {@link #getDisplayName},
245
+ * this method does not get a name from a meta zone used by the time zone.
246
+ * @param tzID The canonical time zone ID.
247
+ * @param type The display name type. See {@link #UTimeZoneNameType}.
248
+ * @param name Receives the display name for the time zone. When this object does not have a localized display name for the given
249
+ * time zone with the specified type, "bogus" state is set.
250
+ * @return A reference to the result.
251
+ * @stable ICU 50
252
+ */
253
+ virtual UnicodeString& getTimeZoneDisplayName(const UnicodeString& tzID, UTimeZoneNameType type, UnicodeString& name) const = 0;
254
+
255
+ /**
256
+ * Returns the exemplar location name for the given time zone. When this object does not have a localized location
257
+ * name, the default implementation may still returns a programmatically generated name with the logic described
258
+ * below.
259
+ * <ol>
260
+ * <li>Check if the ID contains "/". If not, return null.
261
+ * <li>Check if the ID does not start with "Etc/" or "SystemV/". If it does, return null.
262
+ * <li>Extract a substring after the last occurrence of "/".
263
+ * <li>Replace "_" with " ".
264
+ * </ol>
265
+ * For example, "New York" is returned for the time zone ID "America/New_York" when this object does not have the
266
+ * localized location name.
267
+ *
268
+ * @param tzID The canonical time zone ID
269
+ * @param name Receives the exemplar location name for the given time zone, or "bogus" state is set when a localized
270
+ * location name is not available and the fallback logic described above cannot extract location from the ID.
271
+ * @return A reference to the result.
272
+ * @stable ICU 50
273
+ */
274
+ virtual UnicodeString& getExemplarLocationName(const UnicodeString& tzID, UnicodeString& name) const;
275
+
276
+ /**
277
+ * Returns the display name of the time zone at the given date.
278
+ * <p>
279
+ * <b>Note:</b> This method calls the subclass's {@link #getTimeZoneDisplayName} first. When the
280
+ * result is bogus, this method calls {@link #getMetaZoneID} to get the meta zone ID mapped from the
281
+ * time zone, then calls {@link #getMetaZoneDisplayName}.
282
+ *
283
+ * @param tzID The canonical time zone ID.
284
+ * @param type The display name type. See {@link #UTimeZoneNameType}.
285
+ * @param date The date.
286
+ * @param name Receives the display name for the time zone at the given date. When this object does not have a localized display
287
+ * name for the time zone with the specified type and date, "bogus" state is set.
288
+ * @return A reference to the result.
289
+ * @stable ICU 50
290
+ */
291
+ virtual UnicodeString& getDisplayName(const UnicodeString& tzID, UTimeZoneNameType type, UDate date, UnicodeString& name) const;
292
+
293
+ /**
294
+ * <code>MatchInfoCollection</code> represents a collection of time zone name matches used by
295
+ * {@link TimeZoneNames#find}.
296
+ * @internal
297
+ */
298
+ class U_I18N_API MatchInfoCollection : public UMemory {
299
+ public:
300
+ /**
301
+ * Constructor.
302
+ * @internal
303
+ */
304
+ MatchInfoCollection();
305
+ /**
306
+ * Destructor.
307
+ * @internal
308
+ */
309
+ virtual ~MatchInfoCollection();
310
+
311
+ #ifndef U_HIDE_INTERNAL_API
312
+ /**
313
+ * Adds a zone match.
314
+ * @param nameType The name type.
315
+ * @param matchLength The match length.
316
+ * @param tzID The time zone ID.
317
+ * @param status Receives the status
318
+ * @internal
319
+ */
320
+ void addZone(UTimeZoneNameType nameType, int32_t matchLength,
321
+ const UnicodeString& tzID, UErrorCode& status);
322
+
323
+ /**
324
+ * Adds a meata zone match.
325
+ * @param nameType The name type.
326
+ * @param matchLength The match length.
327
+ * @param mzID The metazone ID.
328
+ * @param status Receives the status
329
+ * @internal
330
+ */
331
+ void addMetaZone(UTimeZoneNameType nameType, int32_t matchLength,
332
+ const UnicodeString& mzID, UErrorCode& status);
333
+
334
+ /**
335
+ * Returns the number of entries available in this object.
336
+ * @return The number of entries.
337
+ * @internal
338
+ */
339
+ int32_t size() const;
340
+
341
+ /**
342
+ * Returns the time zone name type of a match at the specified index.
343
+ * @param idx The index
344
+ * @return The time zone name type. If the specified idx is out of range,
345
+ * it returns UTZNM_UNKNOWN.
346
+ * @see UTimeZoneNameType
347
+ * @internal
348
+ */
349
+ UTimeZoneNameType getNameTypeAt(int32_t idx) const;
350
+
351
+ /**
352
+ * Returns the match length of a match at the specified index.
353
+ * @param idx The index
354
+ * @return The match length. If the specified idx is out of range,
355
+ * it returns 0.
356
+ * @internal
357
+ */
358
+ int32_t getMatchLengthAt(int32_t idx) const;
359
+
360
+ /**
361
+ * Gets the zone ID of a match at the specified index.
362
+ * @param idx The index
363
+ * @param tzID Receives the zone ID.
364
+ * @return TRUE if the zone ID was set to tzID.
365
+ * @internal
366
+ */
367
+ UBool getTimeZoneIDAt(int32_t idx, UnicodeString& tzID) const;
368
+
369
+ /**
370
+ * Gets the metazone ID of a match at the specified index.
371
+ * @param idx The index
372
+ * @param mzID Receives the metazone ID
373
+ * @return TRUE if the meta zone ID was set to mzID.
374
+ * @internal
375
+ */
376
+ UBool getMetaZoneIDAt(int32_t idx, UnicodeString& mzID) const;
377
+ #endif /* U_HIDE_INTERNAL_API */
378
+
379
+ private:
380
+ UVector* fMatches; // vector of MatchEntry
381
+
382
+ UVector* matches(UErrorCode& status);
383
+ };
384
+
385
+ /**
386
+ * Finds time zone name prefix matches for the input text at the
387
+ * given offset and returns a collection of the matches.
388
+ * @param text The text.
389
+ * @param start The starting offset within the text.
390
+ * @param types The set of name types represented by bitwise flags of UTimeZoneNameType enums,
391
+ * or UTZNM_UNKNOWN for all name types.
392
+ * @param status Receives the status.
393
+ * @return A collection of matches (owned by the caller), or NULL if no matches are found.
394
+ * @see UTimeZoneNameType
395
+ * @see MatchInfoCollection
396
+ * @internal
397
+ */
398
+ virtual MatchInfoCollection* find(const UnicodeString& text, int32_t start, uint32_t types, UErrorCode& status) const = 0;
399
+ };
400
+
401
+ U_NAMESPACE_END
402
+
403
+ #endif
404
+ #endif
@@ -0,0 +1,828 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2007-2008, International Business Machines Corporation and *
4
+ * others. All Rights Reserved. *
5
+ *******************************************************************************
6
+ */
7
+ #ifndef TZRULE_H
8
+ #define TZRULE_H
9
+
10
+ /**
11
+ * \file
12
+ * \brief C++ API: Time zone rule classes
13
+ */
14
+
15
+ #include "unicode/utypes.h"
16
+
17
+ #if !UCONFIG_NO_FORMATTING
18
+
19
+ #include "unicode/uobject.h"
20
+ #include "unicode/unistr.h"
21
+ #include "unicode/dtrule.h"
22
+
23
+ U_NAMESPACE_BEGIN
24
+
25
+ /**
26
+ * <code>TimeZoneRule</code> is a class representing a rule for time zone.
27
+ * <code>TimeZoneRule</code> has a set of time zone attributes, such as zone name,
28
+ * raw offset (UTC offset for standard time) and daylight saving time offset.
29
+ *
30
+ * @stable ICU 3.8
31
+ */
32
+ class U_I18N_API TimeZoneRule : public UObject {
33
+ public:
34
+ /**
35
+ * Destructor.
36
+ * @stable ICU 3.8
37
+ */
38
+ virtual ~TimeZoneRule();
39
+
40
+ /**
41
+ * Clone this TimeZoneRule object polymorphically. The caller owns the result and
42
+ * should delete it when done.
43
+ * @return A copy of the object.
44
+ * @stable ICU 3.8
45
+ */
46
+ virtual TimeZoneRule* clone(void) const = 0;
47
+
48
+ /**
49
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
50
+ * of different subclasses are considered unequal.
51
+ * @param that The object to be compared with.
52
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically equal.
53
+ * @stable ICU 3.8
54
+ */
55
+ virtual UBool operator==(const TimeZoneRule& that) const;
56
+
57
+ /**
58
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
59
+ * of different subclasses are considered unequal.
60
+ * @param that The object to be compared with.
61
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically unequal.
62
+ * @stable ICU 3.8
63
+ */
64
+ virtual UBool operator!=(const TimeZoneRule& that) const;
65
+
66
+ /**
67
+ * Fills in "name" with the name of this time zone.
68
+ * @param name Receives the name of this time zone.
69
+ * @return A reference to "name"
70
+ * @stable ICU 3.8
71
+ */
72
+ UnicodeString& getName(UnicodeString& name) const;
73
+
74
+ /**
75
+ * Gets the standard time offset.
76
+ * @return The standard time offset from UTC in milliseconds.
77
+ * @stable ICU 3.8
78
+ */
79
+ int32_t getRawOffset(void) const;
80
+
81
+ /**
82
+ * Gets the amount of daylight saving delta time from the standard time.
83
+ * @return The amount of daylight saving offset used by this rule
84
+ * in milliseconds.
85
+ * @stable ICU 3.8
86
+ */
87
+ int32_t getDSTSavings(void) const;
88
+
89
+ /**
90
+ * Returns if this rule represents the same rule and offsets as another.
91
+ * When two <code>TimeZoneRule</code> objects differ only its names, this method
92
+ * returns true.
93
+ * @param other The <code>TimeZoneRule</code> object to be compared with.
94
+ * @return true if the other <code>TimeZoneRule</code> is the same as this one.
95
+ * @stable ICU 3.8
96
+ */
97
+ virtual UBool isEquivalentTo(const TimeZoneRule& other) const;
98
+
99
+ /**
100
+ * Gets the very first time when this rule takes effect.
101
+ * @param prevRawOffset The standard time offset from UTC before this rule
102
+ * takes effect in milliseconds.
103
+ * @param prevDSTSavings The amount of daylight saving offset from the
104
+ * standard time.
105
+ * @param result Receives the very first time when this rule takes effect.
106
+ * @return true if the start time is available. When false is returned, output parameter
107
+ * "result" is unchanged.
108
+ * @stable ICU 3.8
109
+ */
110
+ virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;
111
+
112
+ /**
113
+ * Gets the final time when this rule takes effect.
114
+ * @param prevRawOffset The standard time offset from UTC before this rule
115
+ * takes effect in milliseconds.
116
+ * @param prevDSTSavings The amount of daylight saving offset from the
117
+ * standard time.
118
+ * @param result Receives the final time when this rule takes effect.
119
+ * @return true if the start time is available. When false is returned, output parameter
120
+ * "result" is unchanged.
121
+ * @stable ICU 3.8
122
+ */
123
+ virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;
124
+
125
+ /**
126
+ * Gets the first time when this rule takes effect after the specified time.
127
+ * @param base The first start time after this base time will be returned.
128
+ * @param prevRawOffset The standard time offset from UTC before this rule
129
+ * takes effect in milliseconds.
130
+ * @param prevDSTSavings The amount of daylight saving offset from the
131
+ * standard time.
132
+ * @param inclusive Whether the base time is inclusive or not.
133
+ * @param result Receives The first time when this rule takes effect after
134
+ * the specified base time.
135
+ * @return true if the start time is available. When false is returned, output parameter
136
+ * "result" is unchanged.
137
+ * @stable ICU 3.8
138
+ */
139
+ virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
140
+ UBool inclusive, UDate& result) const = 0;
141
+
142
+ /**
143
+ * Gets the most recent time when this rule takes effect before the specified time.
144
+ * @param base The most recent time before this base time will be returned.
145
+ * @param prevRawOffset The standard time offset from UTC before this rule
146
+ * takes effect in milliseconds.
147
+ * @param prevDSTSavings The amount of daylight saving offset from the
148
+ * standard time.
149
+ * @param inclusive Whether the base time is inclusive or not.
150
+ * @param result Receives The most recent time when this rule takes effect before
151
+ * the specified base time.
152
+ * @return true if the start time is available. When false is returned, output parameter
153
+ * "result" is unchanged.
154
+ * @stable ICU 3.8
155
+ */
156
+ virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
157
+ UBool inclusive, UDate& result) const = 0;
158
+
159
+ protected:
160
+
161
+ /**
162
+ * Constructs a <code>TimeZoneRule</code> with the name, the GMT offset of its
163
+ * standard time and the amount of daylight saving offset adjustment.
164
+ * @param name The time zone name.
165
+ * @param rawOffset The UTC offset of its standard time in milliseconds.
166
+ * @param dstSavings The amount of daylight saving offset adjustment in milliseconds.
167
+ * If this ia a rule for standard time, the value of this argument is 0.
168
+ * @stable ICU 3.8
169
+ */
170
+ TimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);
171
+
172
+ /**
173
+ * Copy constructor.
174
+ * @param source The TimeZoneRule object to be copied.
175
+ * @stable ICU 3.8
176
+ */
177
+ TimeZoneRule(const TimeZoneRule& source);
178
+
179
+ /**
180
+ * Assignment operator.
181
+ * @param right The object to be copied.
182
+ * @stable ICU 3.8
183
+ */
184
+ TimeZoneRule& operator=(const TimeZoneRule& right);
185
+
186
+ private:
187
+ UnicodeString fName; // time name
188
+ int32_t fRawOffset; // UTC offset of the standard time in milliseconds
189
+ int32_t fDSTSavings; // DST saving amount in milliseconds
190
+ };
191
+
192
+ /**
193
+ * <code>InitialTimeZoneRule</code> represents a time zone rule
194
+ * representing a time zone effective from the beginning and
195
+ * has no actual start times.
196
+ * @stable ICU 3.8
197
+ */
198
+ class U_I18N_API InitialTimeZoneRule : public TimeZoneRule {
199
+ public:
200
+ /**
201
+ * Constructs an <code>InitialTimeZoneRule</code> with the name, the GMT offset of its
202
+ * standard time and the amount of daylight saving offset adjustment.
203
+ * @param name The time zone name.
204
+ * @param rawOffset The UTC offset of its standard time in milliseconds.
205
+ * @param dstSavings The amount of daylight saving offset adjustment in milliseconds.
206
+ * If this ia a rule for standard time, the value of this argument is 0.
207
+ * @stable ICU 3.8
208
+ */
209
+ InitialTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);
210
+
211
+ /**
212
+ * Copy constructor.
213
+ * @param source The InitialTimeZoneRule object to be copied.
214
+ * @stable ICU 3.8
215
+ */
216
+ InitialTimeZoneRule(const InitialTimeZoneRule& source);
217
+
218
+ /**
219
+ * Destructor.
220
+ * @stable ICU 3.8
221
+ */
222
+ virtual ~InitialTimeZoneRule();
223
+
224
+ /**
225
+ * Clone this InitialTimeZoneRule object polymorphically. The caller owns the result and
226
+ * should delete it when done.
227
+ * @return A copy of the object.
228
+ * @stable ICU 3.8
229
+ */
230
+ virtual InitialTimeZoneRule* clone(void) const;
231
+
232
+ /**
233
+ * Assignment operator.
234
+ * @param right The object to be copied.
235
+ * @stable ICU 3.8
236
+ */
237
+ InitialTimeZoneRule& operator=(const InitialTimeZoneRule& right);
238
+
239
+ /**
240
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
241
+ * of different subclasses are considered unequal.
242
+ * @param that The object to be compared with.
243
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically equal.
244
+ * @stable ICU 3.8
245
+ */
246
+ virtual UBool operator==(const TimeZoneRule& that) const;
247
+
248
+ /**
249
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
250
+ * of different subclasses are considered unequal.
251
+ * @param that The object to be compared with.
252
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically unequal.
253
+ * @stable ICU 3.8
254
+ */
255
+ virtual UBool operator!=(const TimeZoneRule& that) const;
256
+
257
+ /**
258
+ * Gets the time when this rule takes effect in the given year.
259
+ * @param year The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
260
+ * @param prevRawOffset The standard time offset from UTC before this rule
261
+ * takes effect in milliseconds.
262
+ * @param prevDSTSavings The amount of daylight saving offset from the
263
+ * standard time.
264
+ * @param result Receives the start time in the year.
265
+ * @return true if this rule takes effect in the year and the result is set to
266
+ * "result".
267
+ * @stable ICU 3.8
268
+ */
269
+ UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
270
+
271
+ /**
272
+ * Returns if this rule represents the same rule and offsets as another.
273
+ * When two <code>TimeZoneRule</code> objects differ only its names, this method
274
+ * returns true.
275
+ * @param that The <code>TimeZoneRule</code> object to be compared with.
276
+ * @return true if the other <code>TimeZoneRule</code> is equivalent to this one.
277
+ * @stable ICU 3.8
278
+ */
279
+ virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
280
+
281
+ /**
282
+ * Gets the very first time when this rule takes effect.
283
+ * @param prevRawOffset The standard time offset from UTC before this rule
284
+ * takes effect in milliseconds.
285
+ * @param prevDSTSavings The amount of daylight saving offset from the
286
+ * standard time.
287
+ * @param result Receives the very first time when this rule takes effect.
288
+ * @return true if the start time is available. When false is returned, output parameter
289
+ * "result" is unchanged.
290
+ * @stable ICU 3.8
291
+ */
292
+ virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
293
+
294
+ /**
295
+ * Gets the final time when this rule takes effect.
296
+ * @param prevRawOffset The standard time offset from UTC before this rule
297
+ * takes effect in milliseconds.
298
+ * @param prevDSTSavings The amount of daylight saving offset from the
299
+ * standard time.
300
+ * @param result Receives the final time when this rule takes effect.
301
+ * @return true if the start time is available. When false is returned, output parameter
302
+ * "result" is unchanged.
303
+ * @stable ICU 3.8
304
+ */
305
+ virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
306
+
307
+ /**
308
+ * Gets the first time when this rule takes effect after the specified time.
309
+ * @param base The first start time after this base time will be returned.
310
+ * @param prevRawOffset The standard time offset from UTC before this rule
311
+ * takes effect in milliseconds.
312
+ * @param prevDSTSavings The amount of daylight saving offset from the
313
+ * standard time.
314
+ * @param inclusive Whether the base time is inclusive or not.
315
+ * @param result Receives The first time when this rule takes effect after
316
+ * the specified base time.
317
+ * @return true if the start time is available. When false is returned, output parameter
318
+ * "result" is unchanged.
319
+ * @stable ICU 3.8
320
+ */
321
+ virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
322
+ UBool inclusive, UDate& result) const;
323
+
324
+ /**
325
+ * Gets the most recent time when this rule takes effect before the specified time.
326
+ * @param base The most recent time before this base time will be returned.
327
+ * @param prevRawOffset The standard time offset from UTC before this rule
328
+ * takes effect in milliseconds.
329
+ * @param prevDSTSavings The amount of daylight saving offset from the
330
+ * standard time.
331
+ * @param inclusive Whether the base time is inclusive or not.
332
+ * @param result Receives The most recent time when this rule takes effect before
333
+ * the specified base time.
334
+ * @return true if the start time is available. When false is returned, output parameter
335
+ * "result" is unchanged.
336
+ * @stable ICU 3.8
337
+ */
338
+ virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
339
+ UBool inclusive, UDate& result) const;
340
+
341
+ public:
342
+ /**
343
+ * Return the class ID for this class. This is useful only for comparing to
344
+ * a return value from getDynamicClassID(). For example:
345
+ * <pre>
346
+ * . Base* polymorphic_pointer = createPolymorphicObject();
347
+ * . if (polymorphic_pointer->getDynamicClassID() ==
348
+ * . erived::getStaticClassID()) ...
349
+ * </pre>
350
+ * @return The class ID for all objects of this class.
351
+ * @stable ICU 3.8
352
+ */
353
+ static UClassID U_EXPORT2 getStaticClassID(void);
354
+
355
+ /**
356
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
357
+ * method is to implement a simple version of RTTI, since not all C++
358
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
359
+ * methods call this method.
360
+ *
361
+ * @return The class ID for this object. All objects of a
362
+ * given class have the same class ID. Objects of
363
+ * other classes have different class IDs.
364
+ * @stable ICU 3.8
365
+ */
366
+ virtual UClassID getDynamicClassID(void) const;
367
+ };
368
+
369
+ /**
370
+ * <code>AnnualTimeZoneRule</code> is a class used for representing a time zone
371
+ * rule which takes effect annually. The calenday system used for the rule is
372
+ * is based on Gregorian calendar
373
+ *
374
+ * @stable ICU 3.8
375
+ */
376
+ class U_I18N_API AnnualTimeZoneRule : public TimeZoneRule {
377
+ public:
378
+ /**
379
+ * The constant representing the maximum year used for designating
380
+ * a rule is permanent.
381
+ */
382
+ static const int32_t MAX_YEAR;
383
+
384
+ /**
385
+ * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
386
+ * standard time, the amount of daylight saving offset adjustment, the annual start
387
+ * time rule and the start/until years. The input DateTimeRule is copied by this
388
+ * constructor, so the caller remains responsible for deleting the object.
389
+ * @param name The time zone name.
390
+ * @param rawOffset The GMT offset of its standard time in milliseconds.
391
+ * @param dstSavings The amount of daylight saving offset adjustment in
392
+ * milliseconds. If this ia a rule for standard time,
393
+ * the value of this argument is 0.
394
+ * @param dateTimeRule The start date/time rule repeated annually.
395
+ * @param startYear The first year when this rule takes effect.
396
+ * @param endYear The last year when this rule takes effect. If this
397
+ * rule is effective forever in future, specify MAX_YEAR.
398
+ * @stable ICU 3.8
399
+ */
400
+ AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
401
+ const DateTimeRule& dateTimeRule, int32_t startYear, int32_t endYear);
402
+
403
+ /**
404
+ * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
405
+ * standard time, the amount of daylight saving offset adjustment, the annual start
406
+ * time rule and the start/until years. The input DateTimeRule object is adopted
407
+ * by this object, therefore, the caller must not delete the object.
408
+ * @param name The time zone name.
409
+ * @param rawOffset The GMT offset of its standard time in milliseconds.
410
+ * @param dstSavings The amount of daylight saving offset adjustment in
411
+ * milliseconds. If this ia a rule for standard time,
412
+ * the value of this argument is 0.
413
+ * @param dateTimeRule The start date/time rule repeated annually.
414
+ * @param startYear The first year when this rule takes effect.
415
+ * @param endYear The last year when this rule takes effect. If this
416
+ * rule is effective forever in future, specify MAX_YEAR.
417
+ * @stable ICU 3.8
418
+ */
419
+ AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
420
+ DateTimeRule* dateTimeRule, int32_t startYear, int32_t endYear);
421
+
422
+ /**
423
+ * Copy constructor.
424
+ * @param source The AnnualTimeZoneRule object to be copied.
425
+ * @stable ICU 3.8
426
+ */
427
+ AnnualTimeZoneRule(const AnnualTimeZoneRule& source);
428
+
429
+ /**
430
+ * Destructor.
431
+ * @stable ICU 3.8
432
+ */
433
+ virtual ~AnnualTimeZoneRule();
434
+
435
+ /**
436
+ * Clone this AnnualTimeZoneRule object polymorphically. The caller owns the result and
437
+ * should delete it when done.
438
+ * @return A copy of the object.
439
+ * @stable ICU 3.8
440
+ */
441
+ virtual AnnualTimeZoneRule* clone(void) const;
442
+
443
+ /**
444
+ * Assignment operator.
445
+ * @param right The object to be copied.
446
+ * @stable ICU 3.8
447
+ */
448
+ AnnualTimeZoneRule& operator=(const AnnualTimeZoneRule& right);
449
+
450
+ /**
451
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
452
+ * of different subclasses are considered unequal.
453
+ * @param that The object to be compared with.
454
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically equal.
455
+ * @stable ICU 3.8
456
+ */
457
+ virtual UBool operator==(const TimeZoneRule& that) const;
458
+
459
+ /**
460
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
461
+ * of different subclasses are considered unequal.
462
+ * @param that The object to be compared with.
463
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically unequal.
464
+ * @stable ICU 3.8
465
+ */
466
+ virtual UBool operator!=(const TimeZoneRule& that) const;
467
+
468
+ /**
469
+ * Gets the start date/time rule used by this rule.
470
+ * @return The <code>AnnualDateTimeRule</code> which represents the start date/time
471
+ * rule used by this time zone rule.
472
+ * @stable ICU 3.8
473
+ */
474
+ const DateTimeRule* getRule(void) const;
475
+
476
+ /**
477
+ * Gets the first year when this rule takes effect.
478
+ * @return The start year of this rule. The year is in Gregorian calendar
479
+ * with 0 == 1 BCE, -1 == 2 BCE, etc.
480
+ * @stable ICU 3.8
481
+ */
482
+ int32_t getStartYear(void) const;
483
+
484
+ /**
485
+ * Gets the end year when this rule takes effect.
486
+ * @return The end year of this rule (inclusive). The year is in Gregorian calendar
487
+ * with 0 == 1 BCE, -1 == 2 BCE, etc.
488
+ * @stable ICU 3.8
489
+ */
490
+ int32_t getEndYear(void) const;
491
+
492
+ /**
493
+ * Gets the time when this rule takes effect in the given year.
494
+ * @param year The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
495
+ * @param prevRawOffset The standard time offset from UTC before this rule
496
+ * takes effect in milliseconds.
497
+ * @param prevDSTSavings The amount of daylight saving offset from the
498
+ * standard time.
499
+ * @param result Receives the start time in the year.
500
+ * @return true if this rule takes effect in the year and the result is set to
501
+ * "result".
502
+ * @stable ICU 3.8
503
+ */
504
+ UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
505
+
506
+ /**
507
+ * Returns if this rule represents the same rule and offsets as another.
508
+ * When two <code>TimeZoneRule</code> objects differ only its names, this method
509
+ * returns true.
510
+ * @param that The <code>TimeZoneRule</code> object to be compared with.
511
+ * @return true if the other <code>TimeZoneRule</code> is equivalent to this one.
512
+ * @stable ICU 3.8
513
+ */
514
+ virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
515
+
516
+ /**
517
+ * Gets the very first time when this rule takes effect.
518
+ * @param prevRawOffset The standard time offset from UTC before this rule
519
+ * takes effect in milliseconds.
520
+ * @param prevDSTSavings The amount of daylight saving offset from the
521
+ * standard time.
522
+ * @param result Receives the very first time when this rule takes effect.
523
+ * @return true if the start time is available. When false is returned, output parameter
524
+ * "result" is unchanged.
525
+ * @stable ICU 3.8
526
+ */
527
+ virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
528
+
529
+ /**
530
+ * Gets the final time when this rule takes effect.
531
+ * @param prevRawOffset The standard time offset from UTC before this rule
532
+ * takes effect in milliseconds.
533
+ * @param prevDSTSavings The amount of daylight saving offset from the
534
+ * standard time.
535
+ * @param result Receives the final time when this rule takes effect.
536
+ * @return true if the start time is available. When false is returned, output parameter
537
+ * "result" is unchanged.
538
+ * @stable ICU 3.8
539
+ */
540
+ virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
541
+
542
+ /**
543
+ * Gets the first time when this rule takes effect after the specified time.
544
+ * @param base The first start time after this base time will be returned.
545
+ * @param prevRawOffset The standard time offset from UTC before this rule
546
+ * takes effect in milliseconds.
547
+ * @param prevDSTSavings The amount of daylight saving offset from the
548
+ * standard time.
549
+ * @param inclusive Whether the base time is inclusive or not.
550
+ * @param result Receives The first time when this rule takes effect after
551
+ * the specified base time.
552
+ * @return true if the start time is available. When false is returned, output parameter
553
+ * "result" is unchanged.
554
+ * @stable ICU 3.8
555
+ */
556
+ virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
557
+ UBool inclusive, UDate& result) const;
558
+
559
+ /**
560
+ * Gets the most recent time when this rule takes effect before the specified time.
561
+ * @param base The most recent time before this base time will be returned.
562
+ * @param prevRawOffset The standard time offset from UTC before this rule
563
+ * takes effect in milliseconds.
564
+ * @param prevDSTSavings The amount of daylight saving offset from the
565
+ * standard time.
566
+ * @param inclusive Whether the base time is inclusive or not.
567
+ * @param result Receives The most recent time when this rule takes effect before
568
+ * the specified base time.
569
+ * @return true if the start time is available. When false is returned, output parameter
570
+ * "result" is unchanged.
571
+ * @stable ICU 3.8
572
+ */
573
+ virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
574
+ UBool inclusive, UDate& result) const;
575
+
576
+
577
+ private:
578
+ DateTimeRule* fDateTimeRule;
579
+ int32_t fStartYear;
580
+ int32_t fEndYear;
581
+
582
+ public:
583
+ /**
584
+ * Return the class ID for this class. This is useful only for comparing to
585
+ * a return value from getDynamicClassID(). For example:
586
+ * <pre>
587
+ * . Base* polymorphic_pointer = createPolymorphicObject();
588
+ * . if (polymorphic_pointer->getDynamicClassID() ==
589
+ * . erived::getStaticClassID()) ...
590
+ * </pre>
591
+ * @return The class ID for all objects of this class.
592
+ * @stable ICU 3.8
593
+ */
594
+ static UClassID U_EXPORT2 getStaticClassID(void);
595
+
596
+ /**
597
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
598
+ * method is to implement a simple version of RTTI, since not all C++
599
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
600
+ * methods call this method.
601
+ *
602
+ * @return The class ID for this object. All objects of a
603
+ * given class have the same class ID. Objects of
604
+ * other classes have different class IDs.
605
+ * @stable ICU 3.8
606
+ */
607
+ virtual UClassID getDynamicClassID(void) const;
608
+ };
609
+
610
+ /**
611
+ * <code>TimeArrayTimeZoneRule</code> represents a time zone rule whose start times are
612
+ * defined by an array of milliseconds since the standard base time.
613
+ *
614
+ * @stable ICU 3.8
615
+ */
616
+ class U_I18N_API TimeArrayTimeZoneRule : public TimeZoneRule {
617
+ public:
618
+ /**
619
+ * Constructs a <code>TimeArrayTimeZoneRule</code> with the name, the GMT offset of its
620
+ * standard time, the amount of daylight saving offset adjustment and
621
+ * the array of times when this rule takes effect.
622
+ * @param name The time zone name.
623
+ * @param rawOffset The UTC offset of its standard time in milliseconds.
624
+ * @param dstSavings The amount of daylight saving offset adjustment in
625
+ * milliseconds. If this ia a rule for standard time,
626
+ * the value of this argument is 0.
627
+ * @param startTimes The array start times in milliseconds since the base time
628
+ * (January 1, 1970, 00:00:00).
629
+ * @param numStartTimes The number of elements in the parameter "startTimes"
630
+ * @param timeRuleType The time type of the start times, which is one of
631
+ * <code>DataTimeRule::WALL_TIME</code>, <code>STANDARD_TIME</code>
632
+ * and <code>UTC_TIME</code>.
633
+ * @stable ICU 3.8
634
+ */
635
+ TimeArrayTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
636
+ const UDate* startTimes, int32_t numStartTimes, DateTimeRule::TimeRuleType timeRuleType);
637
+
638
+ /**
639
+ * Copy constructor.
640
+ * @param source The TimeArrayTimeZoneRule object to be copied.
641
+ * @stable ICU 3.8
642
+ */
643
+ TimeArrayTimeZoneRule(const TimeArrayTimeZoneRule& source);
644
+
645
+ /**
646
+ * Destructor.
647
+ * @stable ICU 3.8
648
+ */
649
+ virtual ~TimeArrayTimeZoneRule();
650
+
651
+ /**
652
+ * Clone this TimeArrayTimeZoneRule object polymorphically. The caller owns the result and
653
+ * should delete it when done.
654
+ * @return A copy of the object.
655
+ * @stable ICU 3.8
656
+ */
657
+ virtual TimeArrayTimeZoneRule* clone(void) const;
658
+
659
+ /**
660
+ * Assignment operator.
661
+ * @param right The object to be copied.
662
+ * @stable ICU 3.8
663
+ */
664
+ TimeArrayTimeZoneRule& operator=(const TimeArrayTimeZoneRule& right);
665
+
666
+ /**
667
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
668
+ * of different subclasses are considered unequal.
669
+ * @param that The object to be compared with.
670
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically equal.
671
+ * @stable ICU 3.8
672
+ */
673
+ virtual UBool operator==(const TimeZoneRule& that) const;
674
+
675
+ /**
676
+ * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
677
+ * of different subclasses are considered unequal.
678
+ * @param that The object to be compared with.
679
+ * @return true if the given <code>TimeZoneRule</code> objects are semantically unequal.
680
+ * @stable ICU 3.8
681
+ */
682
+ virtual UBool operator!=(const TimeZoneRule& that) const;
683
+
684
+ /**
685
+ * Gets the time type of the start times used by this rule. The return value
686
+ * is either <code>DateTimeRule::WALL_TIME</code> or <code>STANDARD_TIME</code>
687
+ * or <code>UTC_TIME</code>.
688
+ *
689
+ * @return The time type used of the start times used by this rule.
690
+ * @stable ICU 3.8
691
+ */
692
+ DateTimeRule::TimeRuleType getTimeType(void) const;
693
+
694
+ /**
695
+ * Gets a start time at the index stored in this rule.
696
+ * @param index The index of start times
697
+ * @param result Receives the start time at the index
698
+ * @return true if the index is within the valid range and
699
+ * and the result is set. When false, the output
700
+ * parameger "result" is unchanged.
701
+ * @stable ICU 3.8
702
+ */
703
+ UBool getStartTimeAt(int32_t index, UDate& result) const;
704
+
705
+ /**
706
+ * Returns the number of start times stored in this rule
707
+ * @return The number of start times.
708
+ * @stable ICU 3.8
709
+ */
710
+ int32_t countStartTimes(void) const;
711
+
712
+ /**
713
+ * Returns if this rule represents the same rule and offsets as another.
714
+ * When two <code>TimeZoneRule</code> objects differ only its names, this method
715
+ * returns true.
716
+ * @param that The <code>TimeZoneRule</code> object to be compared with.
717
+ * @return true if the other <code>TimeZoneRule</code> is equivalent to this one.
718
+ * @stable ICU 3.8
719
+ */
720
+ virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
721
+
722
+ /**
723
+ * Gets the very first time when this rule takes effect.
724
+ * @param prevRawOffset The standard time offset from UTC before this rule
725
+ * takes effect in milliseconds.
726
+ * @param prevDSTSavings The amount of daylight saving offset from the
727
+ * standard time.
728
+ * @param result Receives the very first time when this rule takes effect.
729
+ * @return true if the start time is available. When false is returned, output parameter
730
+ * "result" is unchanged.
731
+ * @stable ICU 3.8
732
+ */
733
+ virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
734
+
735
+ /**
736
+ * Gets the final time when this rule takes effect.
737
+ * @param prevRawOffset The standard time offset from UTC before this rule
738
+ * takes effect in milliseconds.
739
+ * @param prevDSTSavings The amount of daylight saving offset from the
740
+ * standard time.
741
+ * @param result Receives the final time when this rule takes effect.
742
+ * @return true if the start time is available. When false is returned, output parameter
743
+ * "result" is unchanged.
744
+ * @stable ICU 3.8
745
+ */
746
+ virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
747
+
748
+ /**
749
+ * Gets the first time when this rule takes effect after the specified time.
750
+ * @param base The first start time after this base time will be returned.
751
+ * @param prevRawOffset The standard time offset from UTC before this rule
752
+ * takes effect in milliseconds.
753
+ * @param prevDSTSavings The amount of daylight saving offset from the
754
+ * standard time.
755
+ * @param inclusive Whether the base time is inclusive or not.
756
+ * @param result Receives The first time when this rule takes effect after
757
+ * the specified base time.
758
+ * @return true if the start time is available. When false is returned, output parameter
759
+ * "result" is unchanged.
760
+ * @stable ICU 3.8
761
+ */
762
+ virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
763
+ UBool inclusive, UDate& result) const;
764
+
765
+ /**
766
+ * Gets the most recent time when this rule takes effect before the specified time.
767
+ * @param base The most recent time before this base time will be returned.
768
+ * @param prevRawOffset The standard time offset from UTC before this rule
769
+ * takes effect in milliseconds.
770
+ * @param prevDSTSavings The amount of daylight saving offset from the
771
+ * standard time.
772
+ * @param inclusive Whether the base time is inclusive or not.
773
+ * @param result Receives The most recent time when this rule takes effect before
774
+ * the specified base time.
775
+ * @return true if the start time is available. When false is returned, output parameter
776
+ * "result" is unchanged.
777
+ * @stable ICU 3.8
778
+ */
779
+ virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
780
+ UBool inclusive, UDate& result) const;
781
+
782
+
783
+ private:
784
+ enum { TIMEARRAY_STACK_BUFFER_SIZE = 32 };
785
+ UBool initStartTimes(const UDate source[], int32_t size, UErrorCode& ec);
786
+ UDate getUTC(UDate time, int32_t raw, int32_t dst) const;
787
+
788
+ DateTimeRule::TimeRuleType fTimeRuleType;
789
+ int32_t fNumStartTimes;
790
+ UDate* fStartTimes;
791
+ UDate fLocalStartTimes[TIMEARRAY_STACK_BUFFER_SIZE];
792
+
793
+ public:
794
+ /**
795
+ * Return the class ID for this class. This is useful only for comparing to
796
+ * a return value from getDynamicClassID(). For example:
797
+ * <pre>
798
+ * . Base* polymorphic_pointer = createPolymorphicObject();
799
+ * . if (polymorphic_pointer->getDynamicClassID() ==
800
+ * . erived::getStaticClassID()) ...
801
+ * </pre>
802
+ * @return The class ID for all objects of this class.
803
+ * @stable ICU 3.8
804
+ */
805
+ static UClassID U_EXPORT2 getStaticClassID(void);
806
+
807
+ /**
808
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
809
+ * method is to implement a simple version of RTTI, since not all C++
810
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
811
+ * methods call this method.
812
+ *
813
+ * @return The class ID for this object. All objects of a
814
+ * given class have the same class ID. Objects of
815
+ * other classes have different class IDs.
816
+ * @stable ICU 3.8
817
+ */
818
+ virtual UClassID getDynamicClassID(void) const;
819
+ };
820
+
821
+
822
+ U_NAMESPACE_END
823
+
824
+ #endif /* #if !UCONFIG_NO_FORMATTING */
825
+
826
+ #endif // TZRULE_H
827
+
828
+ //eof