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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +21 -2
  3. data/lib/2.0/pango.so +0 -0
  4. data/vendor/local/bin/derb.exe +0 -0
  5. data/vendor/local/bin/genbrk.exe +0 -0
  6. data/vendor/local/bin/genccode.exe +0 -0
  7. data/vendor/local/bin/gencfu.exe +0 -0
  8. data/vendor/local/bin/gencmn.exe +0 -0
  9. data/vendor/local/bin/gencnval.exe +0 -0
  10. data/vendor/local/bin/gendict.exe +0 -0
  11. data/vendor/local/bin/gennorm2.exe +0 -0
  12. data/vendor/local/bin/genrb.exe +0 -0
  13. data/vendor/local/bin/gensprep.exe +0 -0
  14. data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
  15. data/vendor/local/bin/hb-shape.exe +0 -0
  16. data/vendor/local/bin/hb-view.exe +0 -0
  17. data/vendor/local/bin/icu-config +820 -0
  18. data/vendor/local/bin/icuinfo.exe +0 -0
  19. data/vendor/local/bin/icupkg.exe +0 -0
  20. data/vendor/local/bin/libharfbuzz-0.dll +0 -0
  21. data/vendor/local/bin/libpango-1.0-0.dll +0 -0
  22. data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
  23. data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
  24. data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
  25. data/vendor/local/bin/libstdc++-6.dll +0 -0
  26. data/vendor/local/bin/makeconv.exe +0 -0
  27. data/vendor/local/bin/pango-querymodules.exe +0 -0
  28. data/vendor/local/bin/pango-view.exe +0 -0
  29. data/vendor/local/bin/pkgdata.exe +0 -0
  30. data/vendor/local/bin/uconv.exe +0 -0
  31. data/vendor/local/etc/pango/pango.modules +3 -3
  32. data/vendor/local/include/harfbuzz/hb-blob.h +3 -4
  33. data/vendor/local/include/harfbuzz/hb-buffer.h +22 -1
  34. data/vendor/local/include/harfbuzz/hb-common.h +23 -18
  35. data/vendor/local/include/harfbuzz/hb-icu.h +52 -0
  36. data/vendor/local/include/harfbuzz/hb-ot-font.h +41 -0
  37. data/vendor/local/include/harfbuzz/hb-ot-layout.h +11 -3
  38. data/vendor/local/include/harfbuzz/hb-ot-shape.h +10 -11
  39. data/vendor/local/include/harfbuzz/hb-ot.h +1 -0
  40. data/vendor/local/include/harfbuzz/hb-version.h +7 -7
  41. data/vendor/local/include/layout/LEFontInstance.h +550 -0
  42. data/vendor/local/include/layout/LEGlyphFilter.h +45 -0
  43. data/vendor/local/include/layout/LEGlyphStorage.h +546 -0
  44. data/vendor/local/include/layout/LEInsertionList.h +177 -0
  45. data/vendor/local/include/layout/LELanguages.h +112 -0
  46. data/vendor/local/include/layout/LEScripts.h +263 -0
  47. data/vendor/local/include/layout/LESwaps.h +100 -0
  48. data/vendor/local/include/layout/LETableReference.h +418 -0
  49. data/vendor/local/include/layout/LETypes.h +728 -0
  50. data/vendor/local/include/layout/LayoutEngine.h +518 -0
  51. data/vendor/local/include/layout/ParagraphLayout.h +747 -0
  52. data/vendor/local/include/layout/RunArrays.h +676 -0
  53. data/vendor/local/include/layout/loengine.h +225 -0
  54. data/vendor/local/include/layout/playout.h +466 -0
  55. data/vendor/local/include/layout/plruns.h +441 -0
  56. data/vendor/local/include/pango-1.0/pango/pango-features.h +2 -2
  57. data/vendor/local/include/pango-1.0/pango/pango-font.h +3 -1
  58. data/vendor/local/include/pango-1.0/pango/pango-item.h +11 -2
  59. data/vendor/local/include/unicode/alphaindex.h +752 -0
  60. data/vendor/local/include/unicode/appendable.h +232 -0
  61. data/vendor/local/include/unicode/basictz.h +214 -0
  62. data/vendor/local/include/unicode/brkiter.h +655 -0
  63. data/vendor/local/include/unicode/bytestream.h +257 -0
  64. data/vendor/local/include/unicode/bytestrie.h +519 -0
  65. data/vendor/local/include/unicode/bytestriebuilder.h +181 -0
  66. data/vendor/local/include/unicode/calendar.h +2519 -0
  67. data/vendor/local/include/unicode/caniter.h +208 -0
  68. data/vendor/local/include/unicode/chariter.h +722 -0
  69. data/vendor/local/include/unicode/choicfmt.h +594 -0
  70. data/vendor/local/include/unicode/coleitr.h +404 -0
  71. data/vendor/local/include/unicode/coll.h +1267 -0
  72. data/vendor/local/include/unicode/compactdecimalformat.h +330 -0
  73. data/vendor/local/include/unicode/curramt.h +130 -0
  74. data/vendor/local/include/unicode/currpinf.h +258 -0
  75. data/vendor/local/include/unicode/currunit.h +110 -0
  76. data/vendor/local/include/unicode/datefmt.h +883 -0
  77. data/vendor/local/include/unicode/dbbi.h +40 -0
  78. data/vendor/local/include/unicode/dcfmtsym.h +482 -0
  79. data/vendor/local/include/unicode/decimfmt.h +2479 -0
  80. data/vendor/local/include/unicode/docmain.h +215 -0
  81. data/vendor/local/include/unicode/dtfmtsym.h +912 -0
  82. data/vendor/local/include/unicode/dtintrv.h +158 -0
  83. data/vendor/local/include/unicode/dtitvfmt.h +985 -0
  84. data/vendor/local/include/unicode/dtitvinf.h +514 -0
  85. data/vendor/local/include/unicode/dtptngen.h +498 -0
  86. data/vendor/local/include/unicode/dtrule.h +250 -0
  87. data/vendor/local/include/unicode/enumset.h +64 -0
  88. data/vendor/local/include/unicode/errorcode.h +137 -0
  89. data/vendor/local/include/unicode/fieldpos.h +291 -0
  90. data/vendor/local/include/unicode/filteredbrk.h +131 -0
  91. data/vendor/local/include/unicode/fmtable.h +760 -0
  92. data/vendor/local/include/unicode/format.h +305 -0
  93. data/vendor/local/include/unicode/fpositer.h +117 -0
  94. data/vendor/local/include/unicode/gender.h +111 -0
  95. data/vendor/local/include/unicode/gregocal.h +777 -0
  96. data/vendor/local/include/unicode/icudataver.h +41 -0
  97. data/vendor/local/include/unicode/icuplug.h +371 -0
  98. data/vendor/local/include/unicode/idna.h +323 -0
  99. data/vendor/local/include/unicode/listformatter.h +167 -0
  100. data/vendor/local/include/unicode/localpointer.h +304 -0
  101. data/vendor/local/include/unicode/locdspnm.h +204 -0
  102. data/vendor/local/include/unicode/locid.h +815 -0
  103. data/vendor/local/include/unicode/measfmt.h +389 -0
  104. data/vendor/local/include/unicode/measunit.h +1443 -0
  105. data/vendor/local/include/unicode/measure.h +159 -0
  106. data/vendor/local/include/unicode/messagepattern.h +943 -0
  107. data/vendor/local/include/unicode/msgfmt.h +1093 -0
  108. data/vendor/local/include/unicode/normalizer2.h +658 -0
  109. data/vendor/local/include/unicode/normlzr.h +797 -0
  110. data/vendor/local/include/unicode/numfmt.h +1187 -0
  111. data/vendor/local/include/unicode/numsys.h +208 -0
  112. data/vendor/local/include/unicode/parseerr.h +92 -0
  113. data/vendor/local/include/unicode/parsepos.h +230 -0
  114. data/vendor/local/include/unicode/platform.h +751 -0
  115. data/vendor/local/include/unicode/plurfmt.h +615 -0
  116. data/vendor/local/include/unicode/plurrule.h +501 -0
  117. data/vendor/local/include/unicode/ptypes.h +126 -0
  118. data/vendor/local/include/unicode/putil.h +181 -0
  119. data/vendor/local/include/unicode/rbbi.h +782 -0
  120. data/vendor/local/include/unicode/rbnf.h +1032 -0
  121. data/vendor/local/include/unicode/rbtz.h +362 -0
  122. data/vendor/local/include/unicode/regex.h +1857 -0
  123. data/vendor/local/include/unicode/region.h +228 -0
  124. data/vendor/local/include/unicode/reldatefmt.h +498 -0
  125. data/vendor/local/include/unicode/rep.h +261 -0
  126. data/vendor/local/include/unicode/resbund.h +490 -0
  127. data/vendor/local/include/unicode/schriter.h +187 -0
  128. data/vendor/local/include/unicode/scientificformathelper.h +139 -0
  129. data/vendor/local/include/unicode/search.h +575 -0
  130. data/vendor/local/include/unicode/selfmt.h +367 -0
  131. data/vendor/local/include/unicode/simpletz.h +928 -0
  132. data/vendor/local/include/unicode/smpdtfmt.h +1592 -0
  133. data/vendor/local/include/unicode/sortkey.h +338 -0
  134. data/vendor/local/include/unicode/std_string.h +37 -0
  135. data/vendor/local/include/unicode/strenum.h +276 -0
  136. data/vendor/local/include/unicode/stringpiece.h +224 -0
  137. data/vendor/local/include/unicode/stringtriebuilder.h +402 -0
  138. data/vendor/local/include/unicode/stsearch.h +504 -0
  139. data/vendor/local/include/unicode/symtable.h +112 -0
  140. data/vendor/local/include/unicode/tblcoll.h +873 -0
  141. data/vendor/local/include/unicode/timezone.h +948 -0
  142. data/vendor/local/include/unicode/tmunit.h +129 -0
  143. data/vendor/local/include/unicode/tmutamt.h +168 -0
  144. data/vendor/local/include/unicode/tmutfmt.h +243 -0
  145. data/vendor/local/include/unicode/translit.h +1342 -0
  146. data/vendor/local/include/unicode/tzfmt.h +1098 -0
  147. data/vendor/local/include/unicode/tznames.h +404 -0
  148. data/vendor/local/include/unicode/tzrule.h +828 -0
  149. data/vendor/local/include/unicode/tztrans.h +195 -0
  150. data/vendor/local/include/unicode/ubidi.h +2186 -0
  151. data/vendor/local/include/unicode/ubrk.h +540 -0
  152. data/vendor/local/include/unicode/ucal.h +1560 -0
  153. data/vendor/local/include/unicode/ucasemap.h +423 -0
  154. data/vendor/local/include/unicode/ucat.h +158 -0
  155. data/vendor/local/include/unicode/uchar.h +3426 -0
  156. data/vendor/local/include/unicode/ucharstrie.h +576 -0
  157. data/vendor/local/include/unicode/ucharstriebuilder.h +185 -0
  158. data/vendor/local/include/unicode/uchriter.h +381 -0
  159. data/vendor/local/include/unicode/uclean.h +258 -0
  160. data/vendor/local/include/unicode/ucnv.h +2036 -0
  161. data/vendor/local/include/unicode/ucnv_cb.h +162 -0
  162. data/vendor/local/include/unicode/ucnv_err.h +463 -0
  163. data/vendor/local/include/unicode/ucnvsel.h +187 -0
  164. data/vendor/local/include/unicode/ucol.h +1474 -0
  165. data/vendor/local/include/unicode/ucoleitr.h +266 -0
  166. data/vendor/local/include/unicode/uconfig.h +430 -0
  167. data/vendor/local/include/unicode/ucsdet.h +413 -0
  168. data/vendor/local/include/unicode/ucurr.h +424 -0
  169. data/vendor/local/include/unicode/udat.h +1536 -0
  170. data/vendor/local/include/unicode/udata.h +430 -0
  171. data/vendor/local/include/unicode/udateintervalformat.h +181 -0
  172. data/vendor/local/include/unicode/udatpg.h +588 -0
  173. data/vendor/local/include/unicode/udisplaycontext.h +150 -0
  174. data/vendor/local/include/unicode/uenum.h +206 -0
  175. data/vendor/local/include/unicode/uformattable.h +280 -0
  176. data/vendor/local/include/unicode/ugender.h +82 -0
  177. data/vendor/local/include/unicode/uidna.h +762 -0
  178. data/vendor/local/include/unicode/uiter.h +707 -0
  179. data/vendor/local/include/unicode/uldnames.h +302 -0
  180. data/vendor/local/include/unicode/uloc.h +1256 -0
  181. data/vendor/local/include/unicode/ulocdata.h +277 -0
  182. data/vendor/local/include/unicode/umachine.h +356 -0
  183. data/vendor/local/include/unicode/umisc.h +60 -0
  184. data/vendor/local/include/unicode/umsg.h +623 -0
  185. data/vendor/local/include/unicode/unifilt.h +120 -0
  186. data/vendor/local/include/unicode/unifunct.h +125 -0
  187. data/vendor/local/include/unicode/unimatch.h +163 -0
  188. data/vendor/local/include/unicode/unirepl.h +97 -0
  189. data/vendor/local/include/unicode/uniset.h +1691 -0
  190. data/vendor/local/include/unicode/unistr.h +4470 -0
  191. data/vendor/local/include/unicode/unorm.h +561 -0
  192. data/vendor/local/include/unicode/unorm2.h +528 -0
  193. data/vendor/local/include/unicode/unum.h +1328 -0
  194. data/vendor/local/include/unicode/unumsys.h +170 -0
  195. data/vendor/local/include/unicode/uobject.h +320 -0
  196. data/vendor/local/include/unicode/upluralrules.h +145 -0
  197. data/vendor/local/include/unicode/uregex.h +1591 -0
  198. data/vendor/local/include/unicode/uregion.h +248 -0
  199. data/vendor/local/include/unicode/urename.h +1784 -0
  200. data/vendor/local/include/unicode/urep.h +155 -0
  201. data/vendor/local/include/unicode/ures.h +887 -0
  202. data/vendor/local/include/unicode/uscript.h +642 -0
  203. data/vendor/local/include/unicode/usearch.h +885 -0
  204. data/vendor/local/include/unicode/uset.h +1126 -0
  205. data/vendor/local/include/unicode/usetiter.h +318 -0
  206. data/vendor/local/include/unicode/ushape.h +474 -0
  207. data/vendor/local/include/unicode/uspoof.h +1064 -0
  208. data/vendor/local/include/unicode/usprep.h +269 -0
  209. data/vendor/local/include/unicode/ustdio.h +1018 -0
  210. data/vendor/local/include/unicode/ustream.h +68 -0
  211. data/vendor/local/include/unicode/ustring.h +1700 -0
  212. data/vendor/local/include/unicode/ustringtrie.h +95 -0
  213. data/vendor/local/include/unicode/utext.h +1600 -0
  214. data/vendor/local/include/unicode/utf.h +223 -0
  215. data/vendor/local/include/unicode/utf16.h +623 -0
  216. data/vendor/local/include/unicode/utf32.h +23 -0
  217. data/vendor/local/include/unicode/utf8.h +824 -0
  218. data/vendor/local/include/unicode/utf_old.h +1169 -0
  219. data/vendor/local/include/unicode/utmscale.h +481 -0
  220. data/vendor/local/include/unicode/utrace.h +359 -0
  221. data/vendor/local/include/unicode/utrans.h +658 -0
  222. data/vendor/local/include/unicode/utypes.h +723 -0
  223. data/vendor/local/include/unicode/uvernum.h +170 -0
  224. data/vendor/local/include/unicode/uversion.h +193 -0
  225. data/vendor/local/include/unicode/vtzone.h +455 -0
  226. data/vendor/local/lib/girepository-1.0/Pango-1.0.typelib +0 -0
  227. data/vendor/local/lib/girepository-1.0/PangoCairo-1.0.typelib +0 -0
  228. data/vendor/local/lib/girepository-1.0/PangoFT2-1.0.typelib +0 -0
  229. data/vendor/local/lib/icu/54.1/Makefile.inc +293 -0
  230. data/vendor/local/lib/icu/54.1/pkgdata.inc +17 -0
  231. data/vendor/local/lib/icu/Makefile.inc +293 -0
  232. data/vendor/local/lib/icu/pkgdata.inc +17 -0
  233. data/vendor/local/lib/icudt.dll +0 -0
  234. data/vendor/local/lib/icudt54.dll +0 -0
  235. data/vendor/local/lib/icuin.dll +0 -0
  236. data/vendor/local/lib/icuin54.dll +0 -0
  237. data/vendor/local/lib/icuio.dll +0 -0
  238. data/vendor/local/lib/icuio54.dll +0 -0
  239. data/vendor/local/lib/icule.dll +0 -0
  240. data/vendor/local/lib/icule54.dll +0 -0
  241. data/vendor/local/lib/iculx.dll +0 -0
  242. data/vendor/local/lib/iculx54.dll +0 -0
  243. data/vendor/local/lib/icutest.dll +0 -0
  244. data/vendor/local/lib/icutest54.dll +0 -0
  245. data/vendor/local/lib/icutu.dll +0 -0
  246. data/vendor/local/lib/icutu54.dll +0 -0
  247. data/vendor/local/lib/icuuc.dll +0 -0
  248. data/vendor/local/lib/icuuc54.dll +0 -0
  249. data/vendor/local/lib/libharfbuzz-icu.a +0 -0
  250. data/vendor/local/lib/libharfbuzz-icu.la +41 -0
  251. data/vendor/local/lib/libharfbuzz.dll.a +0 -0
  252. data/vendor/local/lib/libharfbuzz.la +3 -3
  253. data/vendor/local/lib/libicudt.dll.a +0 -0
  254. data/vendor/local/lib/libicuin.dll.a +0 -0
  255. data/vendor/local/lib/libicuio.dll.a +0 -0
  256. data/vendor/local/lib/libicule.dll.a +0 -0
  257. data/vendor/local/lib/libiculx.dll.a +0 -0
  258. data/vendor/local/lib/libicutest.dll.a +0 -0
  259. data/vendor/local/lib/libicutu.dll.a +0 -0
  260. data/vendor/local/lib/libicuuc.dll.a +0 -0
  261. data/vendor/local/lib/libpango-1.0.dll.a +0 -0
  262. data/vendor/local/lib/libpango-1.0.la +2 -2
  263. data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
  264. data/vendor/local/lib/libpangocairo-1.0.la +2 -2
  265. data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
  266. data/vendor/local/lib/libpangoft2-1.0.la +2 -2
  267. data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
  268. data/vendor/local/lib/libpangowin32-1.0.la +2 -2
  269. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll +0 -0
  270. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.dll.a +0 -0
  271. data/vendor/local/lib/pango/1.8.0/modules/pango-arabic-lang.la +1 -1
  272. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll +0 -0
  273. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.dll.a +0 -0
  274. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-fc.la +1 -1
  275. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll +0 -0
  276. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.dll.a +0 -0
  277. data/vendor/local/lib/pango/1.8.0/modules/pango-basic-win32.la +1 -1
  278. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll +0 -0
  279. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.dll.a +0 -0
  280. data/vendor/local/lib/pango/1.8.0/modules/pango-indic-lang.la +1 -1
  281. data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +13 -0
  282. data/vendor/local/lib/pkgconfig/harfbuzz.pc +1 -1
  283. data/vendor/local/lib/pkgconfig/icu-i18n.pc +38 -0
  284. data/vendor/local/lib/pkgconfig/icu-io.pc +38 -0
  285. data/vendor/local/lib/pkgconfig/icu-le.pc +38 -0
  286. data/vendor/local/lib/pkgconfig/icu-lx.pc +38 -0
  287. data/vendor/local/lib/pkgconfig/icu-uc.pc +38 -0
  288. data/vendor/local/lib/pkgconfig/pango.pc +1 -1
  289. data/vendor/local/lib/pkgconfig/pangocairo.pc +1 -1
  290. data/vendor/local/lib/pkgconfig/pangoft2.pc +1 -1
  291. data/vendor/local/lib/pkgconfig/pangowin32.pc +1 -1
  292. data/vendor/local/share/gir-1.0/Pango-1.0.gir +3009 -462
  293. data/vendor/local/share/gir-1.0/PangoCairo-1.0.gir +64 -22
  294. data/vendor/local/share/gir-1.0/PangoFT2-1.0.gir +4 -2
  295. data/vendor/local/share/gtk-doc/html/harfbuzz/annotation-glossary.html +30 -26
  296. data/vendor/local/share/gtk-doc/html/harfbuzz/api-index-full.html +343 -313
  297. data/vendor/local/share/gtk-doc/html/harfbuzz/ch01.html +5 -5
  298. data/vendor/local/share/gtk-doc/html/harfbuzz/deprecated-api-index.html +6 -8
  299. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-blob.html +442 -247
  300. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-buffer.html +1389 -654
  301. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-common.html +954 -698
  302. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-coretext.html +95 -18
  303. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-deprecated.html +36 -27
  304. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-face.html +477 -191
  305. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-font.html +1951 -1039
  306. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ft.html +123 -65
  307. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-glib.html +66 -21
  308. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-gobject.html +11 -13
  309. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-graphite2.html +67 -23
  310. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-icu.html +66 -21
  311. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-layout.html +574 -347
  312. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot-tag.html +104 -37
  313. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-ot.html +10 -27
  314. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-set.html +744 -318
  315. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape-plan.html +294 -153
  316. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-shape.html +196 -104
  317. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-unicode.html +1100 -757
  318. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-uniscribe.html +51 -18
  319. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +110 -84
  320. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb.html +11 -13
  321. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz.devhelp2 +289 -503
  322. data/vendor/local/share/gtk-doc/html/harfbuzz/index.html +3 -3
  323. data/vendor/local/share/gtk-doc/html/harfbuzz/index.sgml +161 -316
  324. data/vendor/local/share/gtk-doc/html/harfbuzz/object-tree.html +31 -4
  325. data/vendor/local/share/gtk-doc/html/harfbuzz/style.css +260 -105
  326. data/vendor/local/share/gtk-doc/html/pango/PangoEngineLang.html +143 -105
  327. data/vendor/local/share/gtk-doc/html/pango/PangoEngineShape.html +150 -108
  328. data/vendor/local/share/gtk-doc/html/pango/PangoFcDecoder.html +163 -112
  329. data/vendor/local/share/gtk-doc/html/pango/PangoFcFont.html +348 -229
  330. data/vendor/local/share/gtk-doc/html/pango/PangoFcFontMap.html +746 -514
  331. data/vendor/local/share/gtk-doc/html/pango/PangoMarkupFormat.html +9 -9
  332. data/vendor/local/share/gtk-doc/html/pango/PangoRenderer.html +853 -623
  333. data/vendor/local/share/gtk-doc/html/pango/annotation-glossary.html +29 -13
  334. data/vendor/local/share/gtk-doc/html/pango/api-index-1-10.html +31 -33
  335. data/vendor/local/share/gtk-doc/html/pango/api-index-1-12.html +10 -12
  336. data/vendor/local/share/gtk-doc/html/pango/api-index-1-14.html +12 -14
  337. data/vendor/local/share/gtk-doc/html/pango/api-index-1-16.html +53 -55
  338. data/vendor/local/share/gtk-doc/html/pango/api-index-1-18.html +28 -30
  339. data/vendor/local/share/gtk-doc/html/pango/api-index-1-2.html +29 -31
  340. data/vendor/local/share/gtk-doc/html/pango/api-index-1-20.html +17 -19
  341. data/vendor/local/share/gtk-doc/html/pango/api-index-1-22.html +28 -30
  342. data/vendor/local/share/gtk-doc/html/pango/api-index-1-24.html +17 -19
  343. data/vendor/local/share/gtk-doc/html/pango/api-index-1-26.html +9 -11
  344. data/vendor/local/share/gtk-doc/html/pango/api-index-1-30.html +6 -6
  345. data/vendor/local/share/gtk-doc/html/pango/api-index-1-31-0.html +6 -6
  346. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32-4.html +11 -13
  347. data/vendor/local/share/gtk-doc/html/pango/api-index-1-32.html +7 -9
  348. data/vendor/local/share/gtk-doc/html/pango/api-index-1-34.html +5 -5
  349. data/vendor/local/share/gtk-doc/html/pango/api-index-1-4.html +49 -51
  350. data/vendor/local/share/gtk-doc/html/pango/api-index-1-6.html +36 -38
  351. data/vendor/local/share/gtk-doc/html/pango/api-index-1-8.html +37 -39
  352. data/vendor/local/share/gtk-doc/html/pango/api-index-deprecated.html +68 -70
  353. data/vendor/local/share/gtk-doc/html/pango/api-index-full.html +568 -570
  354. data/vendor/local/share/gtk-doc/html/pango/index.html +3 -3
  355. data/vendor/local/share/gtk-doc/html/pango/index.sgml +229 -399
  356. data/vendor/local/share/gtk-doc/html/pango/lowlevel.html +4 -4
  357. data/vendor/local/share/gtk-doc/html/pango/pango-Bidirectional-Text.html +345 -259
  358. data/vendor/local/share/gtk-doc/html/pango/pango-Cairo-Rendering.html +979 -664
  359. data/vendor/local/share/gtk-doc/html/pango/pango-CoreText-Fonts.html +70 -43
  360. data/vendor/local/share/gtk-doc/html/pango/pango-Coverage-Maps.html +349 -229
  361. data/vendor/local/share/gtk-doc/html/pango/pango-Engines.html +236 -153
  362. data/vendor/local/share/gtk-doc/html/pango/pango-Fonts.html +3100 -2159
  363. data/vendor/local/share/gtk-doc/html/pango/pango-FreeType-Fonts-and-Rendering.html +659 -472
  364. data/vendor/local/share/gtk-doc/html/pango/pango-Glyph-Storage.html +1952 -1384
  365. data/vendor/local/share/gtk-doc/html/pango/pango-Layout-Objects.html +3050 -2135
  366. data/vendor/local/share/gtk-doc/html/pango/pango-Miscellaneous-Utilities.html +676 -463
  367. data/vendor/local/share/gtk-doc/html/pango/pango-Modules.html +223 -146
  368. data/vendor/local/share/gtk-doc/html/pango/pango-OpenType-Font-Handling.html +1589 -1199
  369. data/vendor/local/share/gtk-doc/html/pango/pango-Scripts-and-Languages.html +1072 -842
  370. data/vendor/local/share/gtk-doc/html/pango/pango-Tab-Stops.html +406 -276
  371. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Attributes.html +2541 -1792
  372. data/vendor/local/share/gtk-doc/html/pango/pango-Text-Processing.html +1479 -1033
  373. data/vendor/local/share/gtk-doc/html/pango/pango-Version-Checking.html +214 -154
  374. data/vendor/local/share/gtk-doc/html/pango/pango-Vertical-Text.html +374 -291
  375. data/vendor/local/share/gtk-doc/html/pango/pango-Win32-Fonts-and-Rendering.html +733 -498
  376. data/vendor/local/share/gtk-doc/html/pango/pango-Xft-Fonts-and-Rendering.html +893 -617
  377. data/vendor/local/share/gtk-doc/html/pango/pango-hierarchy.html +59 -59
  378. data/vendor/local/share/gtk-doc/html/pango/pango-querymodules.html +5 -5
  379. data/vendor/local/share/gtk-doc/html/pango/pango.devhelp2 +578 -782
  380. data/vendor/local/share/gtk-doc/html/pango/pango.html +4 -4
  381. data/vendor/local/share/gtk-doc/html/pango/rendering.html +4 -4
  382. data/vendor/local/share/gtk-doc/html/pango/style.css +260 -105
  383. data/vendor/local/share/gtk-doc/html/pango/tools.html +4 -4
  384. data/vendor/local/share/icu/54.1/config/mh-mingw +158 -0
  385. data/vendor/local/share/icu/54.1/install-sh +251 -0
  386. data/vendor/local/share/icu/54.1/license.html +385 -0
  387. data/vendor/local/share/icu/54.1/mkinstalldirs +43 -0
  388. data/vendor/local/share/license/harfbuzz/AUTHORS +1 -0
  389. data/vendor/local/share/man/man1/derb.1 +196 -0
  390. data/vendor/local/share/man/man1/genbrk.1 +112 -0
  391. data/vendor/local/share/man/man1/gencfu.1 +91 -0
  392. data/vendor/local/share/man/man1/gencnval.1 +91 -0
  393. data/vendor/local/share/man/man1/gendict.1 +131 -0
  394. data/vendor/local/share/man/man1/genrb.1 +146 -0
  395. data/vendor/local/share/man/man1/icu-config.1 +288 -0
  396. data/vendor/local/share/man/man1/makeconv.1 +112 -0
  397. data/vendor/local/share/man/man1/pango-querymodules.1 +2 -2
  398. data/vendor/local/share/man/man1/pango-view.1 +1 -118
  399. data/vendor/local/share/man/man1/pkgdata.1 +258 -0
  400. data/vendor/local/share/man/man1/uconv.1 +443 -0
  401. data/vendor/local/share/man/man8/genccode.8 +106 -0
  402. data/vendor/local/share/man/man8/gencmn.8 +129 -0
  403. data/vendor/local/share/man/man8/gensprep.8 +102 -0
  404. data/vendor/local/share/man/man8/icupkg.8 +204 -0
  405. metadata +266 -14
  406. data/lib/1.9/pango.so +0 -0
  407. data/lib/2.1/pango.so +0 -0
@@ -0,0 +1,170 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2000-2014, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ *******************************************************************************
6
+ *
7
+ * file name: uvernum.h
8
+ * encoding: US-ASCII
9
+ * tab size: 8 (not used)
10
+ * indentation:4
11
+ *
12
+ * Created by: Vladimir Weinstein
13
+ * Updated by: Steven R. Loomis
14
+ *
15
+ */
16
+
17
+ /**
18
+ * \file
19
+ * \brief C API: definitions of ICU version numbers
20
+ *
21
+ * This file is included by uversion.h and other files. This file contains only
22
+ * macros and definitions. The actual version numbers are defined here.
23
+ */
24
+
25
+ /*
26
+ * IMPORTANT: When updating version, the following things need to be done:
27
+ * source/common/unicode/uvernum.h - this file: update major, minor,
28
+ * patchlevel, suffix, version, short version constants, namespace,
29
+ * renaming macro, and copyright
30
+ *
31
+ * The following files need to be updated as well, which can be done
32
+ * by running the UNIX makefile target 'update-windows-makefiles' in icu/source.
33
+ *
34
+ *
35
+ * source/common/common.vcproj - update 'Output file name' on the link tab so
36
+ * that it contains the new major/minor combination
37
+ * source/i18n/i18n.vcproj - same as for the common.vcproj
38
+ * source/layout/layout.vcproj - same as for the common.vcproj
39
+ * source/layoutex/layoutex.vcproj - same
40
+ * source/stubdata/stubdata.vcproj - same as for the common.vcproj
41
+ * source/io/io.vcproj - same as for the common.vcproj
42
+ * source/data/makedata.mak - change U_ICUDATA_NAME so that it contains
43
+ * the new major/minor combination and the Unicode version.
44
+ */
45
+
46
+ #ifndef UVERNUM_H
47
+ #define UVERNUM_H
48
+
49
+ /** The standard copyright notice that gets compiled into each library.
50
+ * This value will change in the subsequent releases of ICU
51
+ * @stable ICU 2.4
52
+ */
53
+ #define U_COPYRIGHT_STRING \
54
+ " Copyright (C) 2014, International Business Machines Corporation and others. All Rights Reserved. "
55
+
56
+ /** The current ICU major version as an integer.
57
+ * This value will change in the subsequent releases of ICU
58
+ * @stable ICU 2.4
59
+ */
60
+ #define U_ICU_VERSION_MAJOR_NUM 54
61
+
62
+ /** The current ICU minor version as an integer.
63
+ * This value will change in the subsequent releases of ICU
64
+ * @stable ICU 2.6
65
+ */
66
+ #define U_ICU_VERSION_MINOR_NUM 1
67
+
68
+ /** The current ICU patchlevel version as an integer.
69
+ * This value will change in the subsequent releases of ICU
70
+ * @stable ICU 2.4
71
+ */
72
+ #define U_ICU_VERSION_PATCHLEVEL_NUM 0
73
+
74
+ /** The current ICU build level version as an integer.
75
+ * This value is for use by ICU clients. It defaults to 0.
76
+ * @stable ICU 4.0
77
+ */
78
+ #ifndef U_ICU_VERSION_BUILDLEVEL_NUM
79
+ #define U_ICU_VERSION_BUILDLEVEL_NUM 0
80
+ #endif
81
+
82
+ /** Glued version suffix for renamers
83
+ * This value will change in the subsequent releases of ICU
84
+ * @stable ICU 2.6
85
+ */
86
+ #define U_ICU_VERSION_SUFFIX _54
87
+
88
+ /**
89
+ * \def U_DEF2_ICU_ENTRY_POINT_RENAME
90
+ * @internal
91
+ */
92
+ /**
93
+ * \def U_DEF_ICU_ENTRY_POINT_RENAME
94
+ * @internal
95
+ */
96
+ /** Glued version suffix function for renamers
97
+ * This value will change in the subsequent releases of ICU.
98
+ * If a custom suffix (such as matching library suffixes) is desired, this can be modified.
99
+ * Note that if present, platform.h may contain an earlier definition of this macro.
100
+ * \def U_ICU_ENTRY_POINT_RENAME
101
+ * @stable ICU 4.2
102
+ */
103
+
104
+ #ifndef U_ICU_ENTRY_POINT_RENAME
105
+ #ifdef U_HAVE_LIB_SUFFIX
106
+ #define U_DEF_ICU_ENTRY_POINT_RENAME(x,y,z) x ## y ## z
107
+ #define U_DEF2_ICU_ENTRY_POINT_RENAME(x,y,z) U_DEF_ICU_ENTRY_POINT_RENAME(x,y,z)
108
+ #define U_ICU_ENTRY_POINT_RENAME(x) U_DEF2_ICU_ENTRY_POINT_RENAME(x,U_ICU_VERSION_SUFFIX,U_LIB_SUFFIX_C_NAME)
109
+ #else
110
+ #define U_DEF_ICU_ENTRY_POINT_RENAME(x,y) x ## y
111
+ #define U_DEF2_ICU_ENTRY_POINT_RENAME(x,y) U_DEF_ICU_ENTRY_POINT_RENAME(x,y)
112
+ #define U_ICU_ENTRY_POINT_RENAME(x) U_DEF2_ICU_ENTRY_POINT_RENAME(x,U_ICU_VERSION_SUFFIX)
113
+ #endif
114
+ #endif
115
+
116
+ /** The current ICU library version as a dotted-decimal string. The patchlevel
117
+ * only appears in this string if it non-zero.
118
+ * This value will change in the subsequent releases of ICU
119
+ * @stable ICU 2.4
120
+ */
121
+ #define U_ICU_VERSION "54.1"
122
+
123
+ /** The current ICU library major/minor version as a string without dots, for library name suffixes.
124
+ * This value will change in the subsequent releases of ICU
125
+ * @stable ICU 2.6
126
+ */
127
+ #define U_ICU_VERSION_SHORT "54"
128
+
129
+ #ifndef U_HIDE_INTERNAL_API
130
+ /** Data version in ICU4C.
131
+ * @internal ICU 4.4 Internal Use Only
132
+ **/
133
+ #define U_ICU_DATA_VERSION "54.1"
134
+ #endif /* U_HIDE_INTERNAL_API */
135
+
136
+ /*===========================================================================
137
+ * ICU collation framework version information
138
+ * Version info that can be obtained from a collator is affected by these
139
+ * numbers in a secret and magic way. Please use collator version as whole
140
+ *===========================================================================
141
+ */
142
+
143
+ /**
144
+ * Collation runtime version (sort key generator, strcoll).
145
+ * If the version is different, sort keys for the same string could be different.
146
+ * This value may change in subsequent releases of ICU.
147
+ * @stable ICU 2.4
148
+ */
149
+ #define UCOL_RUNTIME_VERSION 8
150
+
151
+ /**
152
+ * Collation builder code version.
153
+ * When this is different, the same tailoring might result
154
+ * in assigning different collation elements to code points.
155
+ * This value may change in subsequent releases of ICU.
156
+ * @stable ICU 2.4
157
+ */
158
+ #define UCOL_BUILDER_VERSION 9
159
+
160
+ #ifndef U_HIDE_DEPRECATED_API
161
+ /**
162
+ * Constant 1.
163
+ * This was intended to be the version of collation tailorings,
164
+ * but instead the tailoring data carries a version number.
165
+ * @deprecated ICU 54
166
+ */
167
+ #define UCOL_TAILORINGS_VERSION 1
168
+ #endif /* U_HIDE_DEPRECATED_API */
169
+
170
+ #endif
@@ -0,0 +1,193 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2000-2011, International Business Machines
4
+ * Corporation and others. All Rights Reserved.
5
+ *******************************************************************************
6
+ *
7
+ * file name: uversion.h
8
+ * encoding: US-ASCII
9
+ * tab size: 8 (not used)
10
+ * indentation:4
11
+ *
12
+ * Created by: Vladimir Weinstein
13
+ *
14
+ * Gets included by utypes.h and Windows .rc files
15
+ */
16
+
17
+ /**
18
+ * \file
19
+ * \brief C API: API for accessing ICU version numbers.
20
+ */
21
+ /*===========================================================================*/
22
+ /* Main ICU version information */
23
+ /*===========================================================================*/
24
+
25
+ #ifndef UVERSION_H
26
+ #define UVERSION_H
27
+
28
+ #include "unicode/umachine.h"
29
+
30
+ /* Actual version info lives in uvernum.h */
31
+ #include "unicode/uvernum.h"
32
+
33
+ /** Maximum length of the copyright string.
34
+ * @stable ICU 2.4
35
+ */
36
+ #define U_COPYRIGHT_STRING_LENGTH 128
37
+
38
+ /** An ICU version consists of up to 4 numbers from 0..255.
39
+ * @stable ICU 2.4
40
+ */
41
+ #define U_MAX_VERSION_LENGTH 4
42
+
43
+ /** In a string, ICU version fields are delimited by dots.
44
+ * @stable ICU 2.4
45
+ */
46
+ #define U_VERSION_DELIMITER '.'
47
+
48
+ /** The maximum length of an ICU version string.
49
+ * @stable ICU 2.4
50
+ */
51
+ #define U_MAX_VERSION_STRING_LENGTH 20
52
+
53
+ /** The binary form of a version on ICU APIs is an array of 4 uint8_t.
54
+ * To compare two versions, use memcmp(v1,v2,sizeof(UVersionInfo)).
55
+ * @stable ICU 2.4
56
+ */
57
+ typedef uint8_t UVersionInfo[U_MAX_VERSION_LENGTH];
58
+
59
+ /*===========================================================================*/
60
+ /* C++ namespace if supported. Versioned unless versioning is disabled. */
61
+ /*===========================================================================*/
62
+
63
+ /**
64
+ * \def U_NAMESPACE_BEGIN
65
+ * This is used to begin a declaration of a public ICU C++ API.
66
+ * When not compiling for C++, it does nothing.
67
+ * When compiling for C++, it begins an extern "C++" linkage block (to protect
68
+ * against cases in which an external client includes ICU header files inside
69
+ * an extern "C" linkage block).
70
+ *
71
+ * It also begins a versioned-ICU-namespace block.
72
+ * @stable ICU 2.4
73
+ */
74
+
75
+ /**
76
+ * \def U_NAMESPACE_END
77
+ * This is used to end a declaration of a public ICU C++ API.
78
+ * When not compiling for C++, it does nothing.
79
+ * When compiling for C++, it ends the extern "C++" block begun by
80
+ * U_NAMESPACE_BEGIN.
81
+ *
82
+ * It also ends the versioned-ICU-namespace block begun by U_NAMESPACE_BEGIN.
83
+ * @stable ICU 2.4
84
+ */
85
+
86
+ /**
87
+ * \def U_NAMESPACE_USE
88
+ * This is used to specify that the rest of the code uses the
89
+ * public ICU C++ API namespace.
90
+ * This is invoked by default; we recommend that you turn it off:
91
+ * See the "Recommended Build Options" section of the ICU4C readme
92
+ * (http://source.icu-project.org/repos/icu/icu/trunk/readme.html#RecBuild)
93
+ * @stable ICU 2.4
94
+ */
95
+
96
+ /**
97
+ * \def U_NAMESPACE_QUALIFIER
98
+ * This is used to qualify that a function or class is part of
99
+ * the public ICU C++ API namespace.
100
+ *
101
+ * This macro is unnecessary since ICU 49 requires namespace support.
102
+ * You can just use "icu::" instead.
103
+ * @stable ICU 2.4
104
+ */
105
+
106
+ /* Define namespace symbols if the compiler supports it. */
107
+ #ifdef __cplusplus
108
+ # if U_DISABLE_RENAMING
109
+ # define U_ICU_NAMESPACE icu
110
+ namespace U_ICU_NAMESPACE { }
111
+ # else
112
+ # define U_ICU_NAMESPACE U_ICU_ENTRY_POINT_RENAME(icu)
113
+ namespace U_ICU_NAMESPACE { }
114
+ namespace icu = U_ICU_NAMESPACE;
115
+ # endif
116
+
117
+ # define U_NAMESPACE_BEGIN extern "C++" { namespace U_ICU_NAMESPACE {
118
+ # define U_NAMESPACE_END } }
119
+ # define U_NAMESPACE_USE using namespace U_ICU_NAMESPACE;
120
+ # define U_NAMESPACE_QUALIFIER U_ICU_NAMESPACE::
121
+
122
+ # ifndef U_USING_ICU_NAMESPACE
123
+ # define U_USING_ICU_NAMESPACE 1
124
+ # endif
125
+ # if U_USING_ICU_NAMESPACE
126
+ U_NAMESPACE_USE
127
+ # endif
128
+ #else
129
+ # define U_NAMESPACE_BEGIN
130
+ # define U_NAMESPACE_END
131
+ # define U_NAMESPACE_USE
132
+ # define U_NAMESPACE_QUALIFIER
133
+ #endif
134
+
135
+ /*===========================================================================*/
136
+ /* General version helper functions. Definitions in putil.c */
137
+ /*===========================================================================*/
138
+
139
+ /**
140
+ * Parse a string with dotted-decimal version information and
141
+ * fill in a UVersionInfo structure with the result.
142
+ * Definition of this function lives in putil.c
143
+ *
144
+ * @param versionArray The destination structure for the version information.
145
+ * @param versionString A string with dotted-decimal version information,
146
+ * with up to four non-negative number fields with
147
+ * values of up to 255 each.
148
+ * @stable ICU 2.4
149
+ */
150
+ U_STABLE void U_EXPORT2
151
+ u_versionFromString(UVersionInfo versionArray, const char *versionString);
152
+
153
+ /**
154
+ * Parse a Unicode string with dotted-decimal version information and
155
+ * fill in a UVersionInfo structure with the result.
156
+ * Definition of this function lives in putil.c
157
+ *
158
+ * @param versionArray The destination structure for the version information.
159
+ * @param versionString A Unicode string with dotted-decimal version
160
+ * information, with up to four non-negative number
161
+ * fields with values of up to 255 each.
162
+ * @stable ICU 4.2
163
+ */
164
+ U_STABLE void U_EXPORT2
165
+ u_versionFromUString(UVersionInfo versionArray, const UChar *versionString);
166
+
167
+
168
+ /**
169
+ * Write a string with dotted-decimal version information according
170
+ * to the input UVersionInfo.
171
+ * Definition of this function lives in putil.c
172
+ *
173
+ * @param versionArray The version information to be written as a string.
174
+ * @param versionString A string buffer that will be filled in with
175
+ * a string corresponding to the numeric version
176
+ * information in versionArray.
177
+ * The buffer size must be at least U_MAX_VERSION_STRING_LENGTH.
178
+ * @stable ICU 2.4
179
+ */
180
+ U_STABLE void U_EXPORT2
181
+ u_versionToString(const UVersionInfo versionArray, char *versionString);
182
+
183
+ /**
184
+ * Gets the ICU release version. The version array stores the version information
185
+ * for ICU. For example, release "1.3.31.2" is then represented as 0x01031F02.
186
+ * Definition of this function lives in putil.c
187
+ *
188
+ * @param versionArray the version # information, the result will be filled in
189
+ * @stable ICU 2.0
190
+ */
191
+ U_STABLE void U_EXPORT2
192
+ u_getVersion(UVersionInfo versionArray);
193
+ #endif
@@ -0,0 +1,455 @@
1
+ /*
2
+ *******************************************************************************
3
+ * Copyright (C) 2007-2013, International Business Machines Corporation and
4
+ * others. All Rights Reserved.
5
+ *******************************************************************************
6
+ */
7
+ #ifndef VTZONE_H
8
+ #define VTZONE_H
9
+
10
+ #include "unicode/utypes.h"
11
+
12
+ /**
13
+ * \file
14
+ * \brief C++ API: RFC2445 VTIMEZONE support
15
+ */
16
+
17
+ #if !UCONFIG_NO_FORMATTING
18
+
19
+ #include "unicode/basictz.h"
20
+
21
+ U_NAMESPACE_BEGIN
22
+
23
+ class VTZWriter;
24
+ class VTZReader;
25
+ class UVector;
26
+
27
+ /**
28
+ * <code>VTimeZone</code> is a class implementing RFC2445 VTIMEZONE. You can create a
29
+ * <code>VTimeZone</code> instance from a time zone ID supported by <code>TimeZone</code>.
30
+ * With the <code>VTimeZone</code> instance created from the ID, you can write out the rule
31
+ * in RFC2445 VTIMEZONE format. Also, you can create a <code>VTimeZone</code> instance
32
+ * from RFC2445 VTIMEZONE data stream, which allows you to calculate time
33
+ * zone offset by the rules defined by the data. Or, you can create a
34
+ * <code>VTimeZone</code> from any other ICU <code>BasicTimeZone</code>.
35
+ * <br><br>
36
+ * Note: The consumer of this class reading or writing VTIMEZONE data is responsible to
37
+ * decode or encode Non-ASCII text. Methods reading/writing VTIMEZONE data in this class
38
+ * do nothing with MIME encoding.
39
+ * @stable ICU 3.8
40
+ */
41
+ class U_I18N_API VTimeZone : public BasicTimeZone {
42
+ public:
43
+ /**
44
+ * Copy constructor.
45
+ * @param source The <code>VTimeZone</code> object to be copied.
46
+ * @stable ICU 3.8
47
+ */
48
+ VTimeZone(const VTimeZone& source);
49
+
50
+ /**
51
+ * Destructor.
52
+ * @stable ICU 3.8
53
+ */
54
+ virtual ~VTimeZone();
55
+
56
+ /**
57
+ * Assignment operator.
58
+ * @param right The object to be copied.
59
+ * @stable ICU 3.8
60
+ */
61
+ VTimeZone& operator=(const VTimeZone& right);
62
+
63
+ /**
64
+ * Return true if the given <code>TimeZone</code> objects are
65
+ * semantically equal. Objects of different subclasses are considered unequal.
66
+ * @param that The object to be compared with.
67
+ * @return true if the given <code>TimeZone</code> objects are
68
+ *semantically equal.
69
+ * @stable ICU 3.8
70
+ */
71
+ virtual UBool operator==(const TimeZone& that) const;
72
+
73
+ /**
74
+ * Return true if the given <code>TimeZone</code> objects are
75
+ * semantically unequal. Objects of different subclasses are considered unequal.
76
+ * @param that The object to be compared with.
77
+ * @return true if the given <code>TimeZone</code> objects are
78
+ * semantically unequal.
79
+ * @stable ICU 3.8
80
+ */
81
+ virtual UBool operator!=(const TimeZone& that) const;
82
+
83
+ /**
84
+ * Create a <code>VTimeZone</code> instance by the time zone ID.
85
+ * @param ID The time zone ID, such as America/New_York
86
+ * @return A <code>VTimeZone</code> object initialized by the time zone ID,
87
+ * or NULL when the ID is unknown.
88
+ * @stable ICU 3.8
89
+ */
90
+ static VTimeZone* createVTimeZoneByID(const UnicodeString& ID);
91
+
92
+ /**
93
+ * Create a <code>VTimeZone</code> instance using a basic time zone.
94
+ * @param basicTZ The basic time zone instance
95
+ * @param status Output param to filled in with a success or an error.
96
+ * @return A <code>VTimeZone</code> object initialized by the basic time zone.
97
+ * @stable ICU 4.6
98
+ */
99
+ static VTimeZone* createVTimeZoneFromBasicTimeZone(const BasicTimeZone& basicTZ,
100
+ UErrorCode &status);
101
+
102
+ /**
103
+ * Create a <code>VTimeZone</code> instance by RFC2445 VTIMEZONE data
104
+ *
105
+ * @param vtzdata The string including VTIMEZONE data block
106
+ * @param status Output param to filled in with a success or an error.
107
+ * @return A <code>VTimeZone</code> initialized by the VTIMEZONE data or
108
+ * NULL if failed to load the rule from the VTIMEZONE data.
109
+ * @stable ICU 3.8
110
+ */
111
+ static VTimeZone* createVTimeZone(const UnicodeString& vtzdata, UErrorCode& status);
112
+
113
+ /**
114
+ * Gets the RFC2445 TZURL property value. When a <code>VTimeZone</code> instance was
115
+ * created from VTIMEZONE data, the initial value is set by the TZURL property value
116
+ * in the data. Otherwise, the initial value is not set.
117
+ * @param url Receives the RFC2445 TZURL property value.
118
+ * @return TRUE if TZURL attribute is available and value is set.
119
+ * @stable ICU 3.8
120
+ */
121
+ UBool getTZURL(UnicodeString& url) const;
122
+
123
+ /**
124
+ * Sets the RFC2445 TZURL property value.
125
+ * @param url The TZURL property value.
126
+ * @stable ICU 3.8
127
+ */
128
+ void setTZURL(const UnicodeString& url);
129
+
130
+ /**
131
+ * Gets the RFC2445 LAST-MODIFIED property value. When a <code>VTimeZone</code> instance
132
+ * was created from VTIMEZONE data, the initial value is set by the LAST-MODIFIED property
133
+ * value in the data. Otherwise, the initial value is not set.
134
+ * @param lastModified Receives the last modified date.
135
+ * @return TRUE if lastModified attribute is available and value is set.
136
+ * @stable ICU 3.8
137
+ */
138
+ UBool getLastModified(UDate& lastModified) const;
139
+
140
+ /**
141
+ * Sets the RFC2445 LAST-MODIFIED property value.
142
+ * @param lastModified The LAST-MODIFIED date.
143
+ * @stable ICU 3.8
144
+ */
145
+ void setLastModified(UDate lastModified);
146
+
147
+ /**
148
+ * Writes RFC2445 VTIMEZONE data for this time zone
149
+ * @param result Output param to filled in with the VTIMEZONE data.
150
+ * @param status Output param to filled in with a success or an error.
151
+ * @stable ICU 3.8
152
+ */
153
+ void write(UnicodeString& result, UErrorCode& status) const;
154
+
155
+ /**
156
+ * Writes RFC2445 VTIMEZONE data for this time zone applicalbe
157
+ * for dates after the specified start time.
158
+ * @param start The start date.
159
+ * @param result Output param to filled in with the VTIMEZONE data.
160
+ * @param status Output param to filled in with a success or an error.
161
+ * @stable ICU 3.8
162
+ */
163
+ void write(UDate start, UnicodeString& result, UErrorCode& status) const;
164
+
165
+ /**
166
+ * Writes RFC2445 VTIMEZONE data applicalbe for the specified date.
167
+ * Some common iCalendar implementations can only handle a single time
168
+ * zone property or a pair of standard and daylight time properties using
169
+ * BYDAY rule with day of week (such as BYDAY=1SUN). This method produce
170
+ * the VTIMEZONE data which can be handled these implementations. The rules
171
+ * produced by this method can be used only for calculating time zone offset
172
+ * around the specified date.
173
+ * @param time The date used for rule extraction.
174
+ * @param result Output param to filled in with the VTIMEZONE data.
175
+ * @param status Output param to filled in with a success or an error.
176
+ * @stable ICU 3.8
177
+ */
178
+ void writeSimple(UDate time, UnicodeString& result, UErrorCode& status) const;
179
+
180
+ /**
181
+ * Clones TimeZone objects polymorphically. Clients are responsible for deleting
182
+ * the TimeZone object cloned.
183
+ * @return A new copy of this TimeZone object.
184
+ * @stable ICU 3.8
185
+ */
186
+ virtual TimeZone* clone(void) const;
187
+
188
+ /**
189
+ * Returns the TimeZone's adjusted GMT offset (i.e., the number of milliseconds to add
190
+ * to GMT to get local time in this time zone, taking daylight savings time into
191
+ * account) as of a particular reference date. The reference date is used to determine
192
+ * whether daylight savings time is in effect and needs to be figured into the offset
193
+ * that is returned (in other words, what is the adjusted GMT offset in this time zone
194
+ * at this particular date and time?). For the time zones produced by createTimeZone(),
195
+ * the reference data is specified according to the Gregorian calendar, and the date
196
+ * and time fields are local standard time.
197
+ *
198
+ * <p>Note: Don't call this method. Instead, call the getOffset(UDate...) overload,
199
+ * which returns both the raw and the DST offset for a given time. This method
200
+ * is retained only for backward compatibility.
201
+ *
202
+ * @param era The reference date's era
203
+ * @param year The reference date's year
204
+ * @param month The reference date's month (0-based; 0 is January)
205
+ * @param day The reference date's day-in-month (1-based)
206
+ * @param dayOfWeek The reference date's day-of-week (1-based; 1 is Sunday)
207
+ * @param millis The reference date's milliseconds in day, local standard time
208
+ * @param status Output param to filled in with a success or an error.
209
+ * @return The offset in milliseconds to add to GMT to get local time.
210
+ * @stable ICU 3.8
211
+ */
212
+ virtual int32_t getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
213
+ uint8_t dayOfWeek, int32_t millis, UErrorCode& status) const;
214
+
215
+ /**
216
+ * Gets the time zone offset, for current date, modified in case of
217
+ * daylight savings. This is the offset to add *to* UTC to get local time.
218
+ *
219
+ * <p>Note: Don't call this method. Instead, call the getOffset(UDate...) overload,
220
+ * which returns both the raw and the DST offset for a given time. This method
221
+ * is retained only for backward compatibility.
222
+ *
223
+ * @param era The reference date's era
224
+ * @param year The reference date's year
225
+ * @param month The reference date's month (0-based; 0 is January)
226
+ * @param day The reference date's day-in-month (1-based)
227
+ * @param dayOfWeek The reference date's day-of-week (1-based; 1 is Sunday)
228
+ * @param millis The reference date's milliseconds in day, local standard time
229
+ * @param monthLength The length of the given month in days.
230
+ * @param status Output param to filled in with a success or an error.
231
+ * @return The offset in milliseconds to add to GMT to get local time.
232
+ * @stable ICU 3.8
233
+ */
234
+ virtual int32_t getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
235
+ uint8_t dayOfWeek, int32_t millis,
236
+ int32_t monthLength, UErrorCode& status) const;
237
+
238
+ /**
239
+ * Returns the time zone raw and GMT offset for the given moment
240
+ * in time. Upon return, local-millis = GMT-millis + rawOffset +
241
+ * dstOffset. All computations are performed in the proleptic
242
+ * Gregorian calendar. The default implementation in the TimeZone
243
+ * class delegates to the 8-argument getOffset().
244
+ *
245
+ * @param date moment in time for which to return offsets, in
246
+ * units of milliseconds from January 1, 1970 0:00 GMT, either GMT
247
+ * time or local wall time, depending on `local'.
248
+ * @param local if true, `date' is local wall time; otherwise it
249
+ * is in GMT time.
250
+ * @param rawOffset output parameter to receive the raw offset, that
251
+ * is, the offset not including DST adjustments
252
+ * @param dstOffset output parameter to receive the DST offset,
253
+ * that is, the offset to be added to `rawOffset' to obtain the
254
+ * total offset between local and GMT time. If DST is not in
255
+ * effect, this value is zero; otherwise it is a positive value,
256
+ * typically one hour.
257
+ * @param ec input-output error code
258
+ * @stable ICU 3.8
259
+ */
260
+ virtual void getOffset(UDate date, UBool local, int32_t& rawOffset,
261
+ int32_t& dstOffset, UErrorCode& ec) const;
262
+
263
+ /**
264
+ * Sets the TimeZone's raw GMT offset (i.e., the number of milliseconds to add
265
+ * to GMT to get local time, before taking daylight savings time into account).
266
+ *
267
+ * @param offsetMillis The new raw GMT offset for this time zone.
268
+ * @stable ICU 3.8
269
+ */
270
+ virtual void setRawOffset(int32_t offsetMillis);
271
+
272
+ /**
273
+ * Returns the TimeZone's raw GMT offset (i.e., the number of milliseconds to add
274
+ * to GMT to get local time, before taking daylight savings time into account).
275
+ *
276
+ * @return The TimeZone's raw GMT offset.
277
+ * @stable ICU 3.8
278
+ */
279
+ virtual int32_t getRawOffset(void) const;
280
+
281
+ /**
282
+ * Queries if this time zone uses daylight savings time.
283
+ * @return true if this time zone uses daylight savings time,
284
+ * false, otherwise.
285
+ * @stable ICU 3.8
286
+ */
287
+ virtual UBool useDaylightTime(void) const;
288
+
289
+ /**
290
+ * Queries if the given date is in daylight savings time in
291
+ * this time zone.
292
+ * This method is wasteful since it creates a new GregorianCalendar and
293
+ * deletes it each time it is called. This is a deprecated method
294
+ * and provided only for Java compatibility.
295
+ *
296
+ * @param date the given UDate.
297
+ * @param status Output param filled in with success/error code.
298
+ * @return true if the given date is in daylight savings time,
299
+ * false, otherwise.
300
+ * @deprecated ICU 2.4. Use Calendar::inDaylightTime() instead.
301
+ */
302
+ virtual UBool inDaylightTime(UDate date, UErrorCode& status) const;
303
+
304
+ /**
305
+ * Returns true if this zone has the same rule and offset as another zone.
306
+ * That is, if this zone differs only in ID, if at all.
307
+ * @param other the <code>TimeZone</code> object to be compared with
308
+ * @return true if the given zone is the same as this one,
309
+ * with the possible exception of the ID
310
+ * @stable ICU 3.8
311
+ */
312
+ virtual UBool hasSameRules(const TimeZone& other) const;
313
+
314
+ /**
315
+ * Gets the first time zone transition after the base time.
316
+ * @param base The base time.
317
+ * @param inclusive Whether the base time is inclusive or not.
318
+ * @param result Receives the first transition after the base time.
319
+ * @return TRUE if the transition is found.
320
+ * @stable ICU 3.8
321
+ */
322
+ virtual UBool getNextTransition(UDate base, UBool inclusive, TimeZoneTransition& result) const;
323
+
324
+ /**
325
+ * Gets the most recent time zone transition before the base time.
326
+ * @param base The base time.
327
+ * @param inclusive Whether the base time is inclusive or not.
328
+ * @param result Receives the most recent transition before the base time.
329
+ * @return TRUE if the transition is found.
330
+ * @stable ICU 3.8
331
+ */
332
+ virtual UBool getPreviousTransition(UDate base, UBool inclusive, TimeZoneTransition& result) const;
333
+
334
+ /**
335
+ * Returns the number of <code>TimeZoneRule</code>s which represents time transitions,
336
+ * for this time zone, that is, all <code>TimeZoneRule</code>s for this time zone except
337
+ * <code>InitialTimeZoneRule</code>. The return value range is 0 or any positive value.
338
+ * @param status Receives error status code.
339
+ * @return The number of <code>TimeZoneRule</code>s representing time transitions.
340
+ * @stable ICU 3.8
341
+ */
342
+ virtual int32_t countTransitionRules(UErrorCode& status) const;
343
+
344
+ /**
345
+ * Gets the <code>InitialTimeZoneRule</code> and the set of <code>TimeZoneRule</code>
346
+ * which represent time transitions for this time zone. On successful return,
347
+ * the argument initial points to non-NULL <code>InitialTimeZoneRule</code> and
348
+ * the array trsrules is filled with 0 or multiple <code>TimeZoneRule</code>
349
+ * instances up to the size specified by trscount. The results are referencing the
350
+ * rule instance held by this time zone instance. Therefore, after this time zone
351
+ * is destructed, they are no longer available.
352
+ * @param initial Receives the initial timezone rule
353
+ * @param trsrules Receives the timezone transition rules
354
+ * @param trscount On input, specify the size of the array 'transitions' receiving
355
+ * the timezone transition rules. On output, actual number of
356
+ * rules filled in the array will be set.
357
+ * @param status Receives error status code.
358
+ * @stable ICU 3.8
359
+ */
360
+ virtual void getTimeZoneRules(const InitialTimeZoneRule*& initial,
361
+ const TimeZoneRule* trsrules[], int32_t& trscount, UErrorCode& status) const;
362
+
363
+ private:
364
+ enum { DEFAULT_VTIMEZONE_LINES = 100 };
365
+
366
+ /**
367
+ * Default constructor.
368
+ */
369
+ VTimeZone();
370
+ static VTimeZone* createVTimeZone(VTZReader* reader);
371
+ void write(VTZWriter& writer, UErrorCode& status) const;
372
+ void write(UDate start, VTZWriter& writer, UErrorCode& status) const;
373
+ void writeSimple(UDate time, VTZWriter& writer, UErrorCode& status) const;
374
+ void load(VTZReader& reader, UErrorCode& status);
375
+ void parse(UErrorCode& status);
376
+
377
+ void writeZone(VTZWriter& w, BasicTimeZone& basictz, UVector* customProps,
378
+ UErrorCode& status) const;
379
+
380
+ void writeHeaders(VTZWriter& w, UErrorCode& status) const;
381
+ void writeFooter(VTZWriter& writer, UErrorCode& status) const;
382
+
383
+ void writeZonePropsByTime(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
384
+ int32_t fromOffset, int32_t toOffset, UDate time, UBool withRDATE,
385
+ UErrorCode& status) const;
386
+ void writeZonePropsByDOM(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
387
+ int32_t fromOffset, int32_t toOffset,
388
+ int32_t month, int32_t dayOfMonth, UDate startTime, UDate untilTime,
389
+ UErrorCode& status) const;
390
+ void writeZonePropsByDOW(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
391
+ int32_t fromOffset, int32_t toOffset,
392
+ int32_t month, int32_t weekInMonth, int32_t dayOfWeek,
393
+ UDate startTime, UDate untilTime, UErrorCode& status) const;
394
+ void writeZonePropsByDOW_GEQ_DOM(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
395
+ int32_t fromOffset, int32_t toOffset,
396
+ int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
397
+ UDate startTime, UDate untilTime, UErrorCode& status) const;
398
+ void writeZonePropsByDOW_GEQ_DOM_sub(VTZWriter& writer, int32_t month, int32_t dayOfMonth,
399
+ int32_t dayOfWeek, int32_t numDays,
400
+ UDate untilTime, int32_t fromOffset, UErrorCode& status) const;
401
+ void writeZonePropsByDOW_LEQ_DOM(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
402
+ int32_t fromOffset, int32_t toOffset,
403
+ int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
404
+ UDate startTime, UDate untilTime, UErrorCode& status) const;
405
+ void writeFinalRule(VTZWriter& writer, UBool isDst, const AnnualTimeZoneRule* rule,
406
+ int32_t fromRawOffset, int32_t fromDSTSavings,
407
+ UDate startTime, UErrorCode& status) const;
408
+
409
+ void beginZoneProps(VTZWriter& writer, UBool isDst, const UnicodeString& zonename,
410
+ int32_t fromOffset, int32_t toOffset, UDate startTime, UErrorCode& status) const;
411
+ void endZoneProps(VTZWriter& writer, UBool isDst, UErrorCode& status) const;
412
+ void beginRRULE(VTZWriter& writer, int32_t month, UErrorCode& status) const;
413
+ void appendUNTIL(VTZWriter& writer, const UnicodeString& until, UErrorCode& status) const;
414
+
415
+ BasicTimeZone *tz;
416
+ UVector *vtzlines;
417
+ UnicodeString tzurl;
418
+ UDate lastmod;
419
+ UnicodeString olsonzid;
420
+ UnicodeString icutzver;
421
+
422
+ public:
423
+ /**
424
+ * Return the class ID for this class. This is useful only for comparing to
425
+ * a return value from getDynamicClassID(). For example:
426
+ * <pre>
427
+ * . Base* polymorphic_pointer = createPolymorphicObject();
428
+ * . if (polymorphic_pointer->getDynamicClassID() ==
429
+ * . erived::getStaticClassID()) ...
430
+ * </pre>
431
+ * @return The class ID for all objects of this class.
432
+ * @stable ICU 3.8
433
+ */
434
+ static UClassID U_EXPORT2 getStaticClassID(void);
435
+
436
+ /**
437
+ * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
438
+ * method is to implement a simple version of RTTI, since not all C++
439
+ * compilers support genuine RTTI. Polymorphic operator==() and clone()
440
+ * methods call this method.
441
+ *
442
+ * @return The class ID for this object. All objects of a
443
+ * given class have the same class ID. Objects of
444
+ * other classes have different class IDs.
445
+ * @stable ICU 3.8
446
+ */
447
+ virtual UClassID getDynamicClassID(void) const;
448
+ };
449
+
450
+ U_NAMESPACE_END
451
+
452
+ #endif /* #if !UCONFIG_NO_FORMATTING */
453
+
454
+ #endif // VTZONE_H
455
+ //eof