pango 3.1.0-x86-mingw32 → 3.1.1-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (293) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +9 -4
  3. data/ext/pango/rbpangolayoutline.c +6 -2
  4. data/lib/2.2/pango.so +0 -0
  5. data/lib/2.3/pango.so +0 -0
  6. data/lib/2.4/pango.so +0 -0
  7. data/sample/layout.rb +1 -1
  8. data/vendor/local/bin/derb.exe +0 -0
  9. data/vendor/local/bin/genbrk.exe +0 -0
  10. data/vendor/local/bin/genccode.exe +0 -0
  11. data/vendor/local/bin/gencfu.exe +0 -0
  12. data/vendor/local/bin/gencmn.exe +0 -0
  13. data/vendor/local/bin/gencnval.exe +0 -0
  14. data/vendor/local/bin/gendict.exe +0 -0
  15. data/vendor/local/bin/gennorm2.exe +0 -0
  16. data/vendor/local/bin/genrb.exe +0 -0
  17. data/vendor/local/bin/gensprep.exe +0 -0
  18. data/vendor/local/bin/hb-ot-shape-closure.exe +0 -0
  19. data/vendor/local/bin/hb-shape.exe +0 -0
  20. data/vendor/local/bin/hb-view.exe +0 -0
  21. data/vendor/local/bin/icu-config +18 -13
  22. data/vendor/local/bin/icuinfo.exe +0 -0
  23. data/vendor/local/bin/icupkg.exe +0 -0
  24. data/vendor/local/bin/libharfbuzz-0.dll +0 -0
  25. data/vendor/local/bin/libpango-1.0-0.dll +0 -0
  26. data/vendor/local/bin/libpangocairo-1.0-0.dll +0 -0
  27. data/vendor/local/bin/libpangoft2-1.0-0.dll +0 -0
  28. data/vendor/local/bin/libpangowin32-1.0-0.dll +0 -0
  29. data/vendor/local/bin/makeconv.exe +0 -0
  30. data/vendor/local/bin/pango-view.exe +0 -0
  31. data/vendor/local/bin/pkgdata.exe +0 -0
  32. data/vendor/local/bin/uconv.exe +0 -0
  33. data/vendor/local/include/harfbuzz/hb-font.h +5 -0
  34. data/vendor/local/include/harfbuzz/hb-glib.h +2 -1
  35. data/vendor/local/include/harfbuzz/hb-ot-layout.h +19 -0
  36. data/vendor/local/include/harfbuzz/hb-shape-plan.h +19 -0
  37. data/vendor/local/include/harfbuzz/hb-version.h +3 -3
  38. data/vendor/local/include/unicode/alphaindex.h +2 -0
  39. data/vendor/local/include/unicode/appendable.h +2 -0
  40. data/vendor/local/include/unicode/basictz.h +2 -0
  41. data/vendor/local/include/unicode/brkiter.h +7 -0
  42. data/vendor/local/include/unicode/bytestream.h +2 -0
  43. data/vendor/local/include/unicode/bytestrie.h +3 -2
  44. data/vendor/local/include/unicode/bytestriebuilder.h +4 -4
  45. data/vendor/local/include/unicode/calendar.h +2 -0
  46. data/vendor/local/include/unicode/caniter.h +2 -0
  47. data/vendor/local/include/unicode/chariter.h +2 -0
  48. data/vendor/local/include/unicode/choicfmt.h +2 -0
  49. data/vendor/local/include/unicode/coleitr.h +2 -0
  50. data/vendor/local/include/unicode/coll.h +2 -0
  51. data/vendor/local/include/unicode/compactdecimalformat.h +4 -3
  52. data/vendor/local/include/unicode/curramt.h +2 -0
  53. data/vendor/local/include/unicode/currpinf.h +2 -0
  54. data/vendor/local/include/unicode/currunit.h +2 -0
  55. data/vendor/local/include/unicode/datefmt.h +2 -0
  56. data/vendor/local/include/unicode/dbbi.h +2 -0
  57. data/vendor/local/include/unicode/dcfmtsym.h +2 -0
  58. data/vendor/local/include/unicode/decimfmt.h +9 -5
  59. data/vendor/local/include/unicode/docmain.h +3 -1
  60. data/vendor/local/include/unicode/dtfmtsym.h +26 -14
  61. data/vendor/local/include/unicode/dtintrv.h +2 -0
  62. data/vendor/local/include/unicode/dtitvfmt.h +2 -0
  63. data/vendor/local/include/unicode/dtitvinf.h +8 -3
  64. data/vendor/local/include/unicode/dtptngen.h +13 -9
  65. data/vendor/local/include/unicode/dtrule.h +2 -0
  66. data/vendor/local/include/unicode/enumset.h +2 -0
  67. data/vendor/local/include/unicode/errorcode.h +2 -0
  68. data/vendor/local/include/unicode/fieldpos.h +5 -2
  69. data/vendor/local/include/unicode/filteredbrk.h +10 -12
  70. data/vendor/local/include/unicode/fmtable.h +4 -2
  71. data/vendor/local/include/unicode/format.h +2 -0
  72. data/vendor/local/include/unicode/fpositer.h +2 -0
  73. data/vendor/local/include/unicode/gender.h +2 -0
  74. data/vendor/local/include/unicode/gregocal.h +2 -0
  75. data/vendor/local/include/unicode/icudataver.h +2 -0
  76. data/vendor/local/include/unicode/icuplug.h +12 -2
  77. data/vendor/local/include/unicode/idna.h +6 -4
  78. data/vendor/local/include/unicode/listformatter.h +2 -0
  79. data/vendor/local/include/unicode/localpointer.h +19 -28
  80. data/vendor/local/include/unicode/locdspnm.h +2 -0
  81. data/vendor/local/include/unicode/locid.h +2 -0
  82. data/vendor/local/include/unicode/measfmt.h +21 -2
  83. data/vendor/local/include/unicode/measunit.h +50 -24
  84. data/vendor/local/include/unicode/measure.h +2 -0
  85. data/vendor/local/include/unicode/messagepattern.h +2 -0
  86. data/vendor/local/include/unicode/msgfmt.h +2 -0
  87. data/vendor/local/include/unicode/normalizer2.h +2 -0
  88. data/vendor/local/include/unicode/normlzr.h +4 -4
  89. data/vendor/local/include/unicode/numfmt.h +8 -6
  90. data/vendor/local/include/unicode/numsys.h +2 -0
  91. data/vendor/local/include/unicode/parseerr.h +2 -0
  92. data/vendor/local/include/unicode/parsepos.h +2 -0
  93. data/vendor/local/include/unicode/platform.h +8 -0
  94. data/vendor/local/include/unicode/plurfmt.h +2 -0
  95. data/vendor/local/include/unicode/plurrule.h +2 -0
  96. data/vendor/local/include/unicode/ptypes.h +2 -0
  97. data/vendor/local/include/unicode/putil.h +2 -0
  98. data/vendor/local/include/unicode/rbbi.h +18 -66
  99. data/vendor/local/include/unicode/rbnf.h +8 -0
  100. data/vendor/local/include/unicode/rbtz.h +2 -0
  101. data/vendor/local/include/unicode/regex.h +2 -0
  102. data/vendor/local/include/unicode/region.h +3 -1
  103. data/vendor/local/include/unicode/reldatefmt.h +19 -9
  104. data/vendor/local/include/unicode/rep.h +2 -0
  105. data/vendor/local/include/unicode/resbund.h +2 -0
  106. data/vendor/local/include/unicode/schriter.h +2 -0
  107. data/vendor/local/include/unicode/scientificnumberformatter.h +2 -0
  108. data/vendor/local/include/unicode/search.h +2 -0
  109. data/vendor/local/include/unicode/selfmt.h +2 -0
  110. data/vendor/local/include/unicode/simpleformatter.h +2 -0
  111. data/vendor/local/include/unicode/simpletz.h +2 -0
  112. data/vendor/local/include/unicode/smpdtfmt.h +9 -1
  113. data/vendor/local/include/unicode/sortkey.h +2 -0
  114. data/vendor/local/include/unicode/std_string.h +2 -0
  115. data/vendor/local/include/unicode/strenum.h +2 -0
  116. data/vendor/local/include/unicode/stringpiece.h +5 -3
  117. data/vendor/local/include/unicode/stringtriebuilder.h +13 -1
  118. data/vendor/local/include/unicode/stsearch.h +2 -0
  119. data/vendor/local/include/unicode/symtable.h +2 -0
  120. data/vendor/local/include/unicode/tblcoll.h +3 -1
  121. data/vendor/local/include/unicode/timezone.h +2 -0
  122. data/vendor/local/include/unicode/tmunit.h +8 -0
  123. data/vendor/local/include/unicode/tmutamt.h +2 -0
  124. data/vendor/local/include/unicode/tmutfmt.h +5 -0
  125. data/vendor/local/include/unicode/translit.h +2 -0
  126. data/vendor/local/include/unicode/tzfmt.h +2 -0
  127. data/vendor/local/include/unicode/tznames.h +16 -2
  128. data/vendor/local/include/unicode/tzrule.h +2 -0
  129. data/vendor/local/include/unicode/tztrans.h +2 -0
  130. data/vendor/local/include/unicode/ubidi.h +20 -8
  131. data/vendor/local/include/unicode/ubiditransform.h +321 -0
  132. data/vendor/local/include/unicode/ubrk.h +26 -7
  133. data/vendor/local/include/unicode/ucal.h +8 -4
  134. data/vendor/local/include/unicode/ucasemap.h +2 -0
  135. data/vendor/local/include/unicode/ucat.h +2 -0
  136. data/vendor/local/include/unicode/uchar.h +244 -17
  137. data/vendor/local/include/unicode/ucharstrie.h +2 -0
  138. data/vendor/local/include/unicode/ucharstriebuilder.h +2 -0
  139. data/vendor/local/include/unicode/uchriter.h +2 -0
  140. data/vendor/local/include/unicode/uclean.h +2 -0
  141. data/vendor/local/include/unicode/ucnv.h +8 -1
  142. data/vendor/local/include/unicode/ucnv_cb.h +2 -0
  143. data/vendor/local/include/unicode/ucnv_err.h +2 -0
  144. data/vendor/local/include/unicode/ucnvsel.h +2 -0
  145. data/vendor/local/include/unicode/ucol.h +28 -11
  146. data/vendor/local/include/unicode/ucoleitr.h +2 -0
  147. data/vendor/local/include/unicode/uconfig.h +2 -0
  148. data/vendor/local/include/unicode/ucsdet.h +2 -0
  149. data/vendor/local/include/unicode/ucurr.h +5 -1
  150. data/vendor/local/include/unicode/udat.h +13 -11
  151. data/vendor/local/include/unicode/udata.h +8 -1
  152. data/vendor/local/include/unicode/udateintervalformat.h +2 -0
  153. data/vendor/local/include/unicode/udatpg.h +15 -2
  154. data/vendor/local/include/unicode/udisplaycontext.h +34 -2
  155. data/vendor/local/include/unicode/uenum.h +2 -0
  156. data/vendor/local/include/unicode/ufieldpositer.h +4 -2
  157. data/vendor/local/include/unicode/uformattable.h +9 -1
  158. data/vendor/local/include/unicode/ugender.h +2 -0
  159. data/vendor/local/include/unicode/uidna.h +2 -0
  160. data/vendor/local/include/unicode/uiter.h +2 -0
  161. data/vendor/local/include/unicode/uldnames.h +2 -0
  162. data/vendor/local/include/unicode/ulistformatter.h +2 -0
  163. data/vendor/local/include/unicode/uloc.h +9 -3
  164. data/vendor/local/include/unicode/ulocdata.h +20 -2
  165. data/vendor/local/include/unicode/umachine.h +25 -0
  166. data/vendor/local/include/unicode/umisc.h +2 -0
  167. data/vendor/local/include/unicode/umsg.h +2 -0
  168. data/vendor/local/include/unicode/unifilt.h +2 -0
  169. data/vendor/local/include/unicode/unifunct.h +2 -0
  170. data/vendor/local/include/unicode/unimatch.h +2 -0
  171. data/vendor/local/include/unicode/unirepl.h +2 -0
  172. data/vendor/local/include/unicode/uniset.h +3 -1
  173. data/vendor/local/include/unicode/unistr.h +12 -14
  174. data/vendor/local/include/unicode/unorm.h +6 -2
  175. data/vendor/local/include/unicode/unorm2.h +2 -0
  176. data/vendor/local/include/unicode/unum.h +28 -10
  177. data/vendor/local/include/unicode/unumsys.h +2 -0
  178. data/vendor/local/include/unicode/uobject.h +2 -0
  179. data/vendor/local/include/unicode/upluralrules.h +6 -2
  180. data/vendor/local/include/unicode/uregex.h +2 -0
  181. data/vendor/local/include/unicode/uregion.h +6 -2
  182. data/vendor/local/include/unicode/ureldatefmt.h +13 -7
  183. data/vendor/local/include/unicode/urename.h +16 -4
  184. data/vendor/local/include/unicode/urep.h +2 -0
  185. data/vendor/local/include/unicode/ures.h +7 -1
  186. data/vendor/local/include/unicode/uscript.h +41 -29
  187. data/vendor/local/include/unicode/usearch.h +10 -4
  188. data/vendor/local/include/unicode/uset.h +5 -1
  189. data/vendor/local/include/unicode/usetiter.h +2 -0
  190. data/vendor/local/include/unicode/ushape.h +2 -0
  191. data/vendor/local/include/unicode/uspoof.h +876 -363
  192. data/vendor/local/include/unicode/usprep.h +2 -0
  193. data/vendor/local/include/unicode/ustdio.h +2 -0
  194. data/vendor/local/include/unicode/ustream.h +2 -0
  195. data/vendor/local/include/unicode/ustring.h +2 -0
  196. data/vendor/local/include/unicode/ustringtrie.h +2 -0
  197. data/vendor/local/include/unicode/utext.h +2 -0
  198. data/vendor/local/include/unicode/utf.h +2 -0
  199. data/vendor/local/include/unicode/utf16.h +2 -0
  200. data/vendor/local/include/unicode/utf32.h +2 -0
  201. data/vendor/local/include/unicode/utf8.h +2 -0
  202. data/vendor/local/include/unicode/utf_old.h +2 -0
  203. data/vendor/local/include/unicode/utmscale.h +2 -0
  204. data/vendor/local/include/unicode/utrace.h +20 -0
  205. data/vendor/local/include/unicode/utrans.h +2 -0
  206. data/vendor/local/include/unicode/utypes.h +71 -97
  207. data/vendor/local/include/unicode/uvernum.h +13 -12
  208. data/vendor/local/include/unicode/uversion.h +2 -0
  209. data/vendor/local/include/unicode/vtzone.h +2 -0
  210. data/vendor/local/lib/icu/{57.1 → 58.2}/Makefile.inc +8 -9
  211. data/vendor/local/lib/icu/{57.1 → 58.2}/pkgdata.inc +3 -3
  212. data/vendor/local/lib/icu/Makefile.inc +8 -9
  213. data/vendor/local/lib/icu/pkgdata.inc +3 -3
  214. data/vendor/local/lib/icudt.dll +0 -0
  215. data/vendor/local/lib/icudt58.dll +0 -0
  216. data/vendor/local/lib/icuin.dll +0 -0
  217. data/vendor/local/lib/icuin58.dll +0 -0
  218. data/vendor/local/lib/icuio.dll +0 -0
  219. data/vendor/local/lib/icuio58.dll +0 -0
  220. data/vendor/local/lib/icutest.dll +0 -0
  221. data/vendor/local/lib/{icutest57.dll → icutest58.dll} +0 -0
  222. data/vendor/local/lib/icutu.dll +0 -0
  223. data/vendor/local/lib/icutu58.dll +0 -0
  224. data/vendor/local/lib/icuuc.dll +0 -0
  225. data/vendor/local/lib/icuuc58.dll +0 -0
  226. data/vendor/local/lib/libharfbuzz-icu.a +0 -0
  227. data/vendor/local/lib/libharfbuzz-icu.la +4 -4
  228. data/vendor/local/lib/libharfbuzz.dll.a +0 -0
  229. data/vendor/local/lib/libharfbuzz.la +3 -3
  230. data/vendor/local/lib/libicudt.dll.a +0 -0
  231. data/vendor/local/lib/{icudt57.dll → libicudt58.dll} +0 -0
  232. data/vendor/local/lib/libicuin.dll.a +0 -0
  233. data/vendor/local/lib/libicuio.dll.a +0 -0
  234. data/vendor/local/lib/libicutest.dll.a +0 -0
  235. data/vendor/local/lib/libicutu.dll.a +0 -0
  236. data/vendor/local/lib/libicuuc.dll.a +0 -0
  237. data/vendor/local/lib/libpango-1.0.dll.a +0 -0
  238. data/vendor/local/lib/libpangocairo-1.0.dll.a +0 -0
  239. data/vendor/local/lib/libpangoft2-1.0.dll.a +0 -0
  240. data/vendor/local/lib/libpangowin32-1.0.dll.a +0 -0
  241. data/vendor/local/lib/pkgconfig/harfbuzz-icu.pc +1 -1
  242. data/vendor/local/lib/pkgconfig/harfbuzz.pc +2 -2
  243. data/vendor/local/lib/pkgconfig/icu-i18n.pc +8 -6
  244. data/vendor/local/lib/pkgconfig/icu-io.pc +8 -6
  245. data/vendor/local/lib/pkgconfig/icu-uc.pc +8 -6
  246. data/vendor/local/share/gtk-doc/html/harfbuzz/harfbuzz-hb-version.html +3 -3
  247. data/vendor/local/share/gtk-doc/html/harfbuzz/pt02.html +1 -1
  248. data/vendor/local/share/icu/{57.1 → 58.2}/LICENSE +52 -60
  249. data/vendor/local/share/icu/{57.1 → 58.2}/config/mh-mingw +4 -2
  250. data/vendor/local/share/icu/{57.1 → 58.2}/install-sh +0 -0
  251. data/vendor/local/share/icu/{57.1 → 58.2}/mkinstalldirs +2 -0
  252. data/vendor/local/share/man/man1/derb.1 +4 -2
  253. data/vendor/local/share/man/man1/genbrk.1 +4 -2
  254. data/vendor/local/share/man/man1/gencfu.1 +3 -1
  255. data/vendor/local/share/man/man1/gencnval.1 +5 -3
  256. data/vendor/local/share/man/man1/gendict.1 +4 -2
  257. data/vendor/local/share/man/man1/genrb.1 +5 -3
  258. data/vendor/local/share/man/man1/icu-config.1 +4 -5
  259. data/vendor/local/share/man/man1/makeconv.1 +5 -3
  260. data/vendor/local/share/man/man1/pkgdata.1 +4 -2
  261. data/vendor/local/share/man/man1/uconv.1 +4 -2
  262. data/vendor/local/share/man/man8/genccode.8 +4 -2
  263. data/vendor/local/share/man/man8/gencmn.8 +5 -3
  264. data/vendor/local/share/man/man8/gensprep.8 +5 -3
  265. data/vendor/local/share/man/man8/icupkg.8 +3 -1
  266. metadata +23 -40
  267. data/vendor/local/include/layout/LEFontInstance.h +0 -524
  268. data/vendor/local/include/layout/LEGlyphFilter.h +0 -45
  269. data/vendor/local/include/layout/LEGlyphStorage.h +0 -546
  270. data/vendor/local/include/layout/LEInsertionList.h +0 -177
  271. data/vendor/local/include/layout/LELanguages.h +0 -109
  272. data/vendor/local/include/layout/LEScripts.h +0 -204
  273. data/vendor/local/include/layout/LESwaps.h +0 -100
  274. data/vendor/local/include/layout/LETableReference.h +0 -435
  275. data/vendor/local/include/layout/LETypes.h +0 -728
  276. data/vendor/local/include/layout/LayoutEngine.h +0 -518
  277. data/vendor/local/include/layout/ParagraphLayout.h +0 -747
  278. data/vendor/local/include/layout/RunArrays.h +0 -676
  279. data/vendor/local/include/layout/loengine.h +0 -225
  280. data/vendor/local/include/layout/playout.h +0 -466
  281. data/vendor/local/include/layout/plruns.h +0 -441
  282. data/vendor/local/lib/icuin57.dll +0 -0
  283. data/vendor/local/lib/icuio57.dll +0 -0
  284. data/vendor/local/lib/icule.dll +0 -0
  285. data/vendor/local/lib/icule57.dll +0 -0
  286. data/vendor/local/lib/iculx.dll +0 -0
  287. data/vendor/local/lib/iculx57.dll +0 -0
  288. data/vendor/local/lib/icutu57.dll +0 -0
  289. data/vendor/local/lib/icuuc57.dll +0 -0
  290. data/vendor/local/lib/libicule.dll.a +0 -0
  291. data/vendor/local/lib/libiculx.dll.a +0 -0
  292. data/vendor/local/lib/pkgconfig/icu-le.pc +0 -38
  293. data/vendor/local/lib/pkgconfig/icu-lx.pc +0 -38
@@ -1,225 +0,0 @@
1
- /*
2
- *
3
- * (C) Copyright IBM Corp. 1998-2011 - All Rights Reserved
4
- *
5
- */
6
-
7
- #ifndef __LOENGINE_H
8
- #define __LOENGINE_H
9
-
10
- #include "LETypes.h"
11
-
12
- #ifndef U_HIDE_INTERNAL_API
13
- /**
14
- * \file
15
- * \brief C API for complex text layout.
16
- * \internal
17
- *
18
- * This is a technology preview. The API may
19
- * change significantly.
20
- *
21
- */
22
-
23
- /**
24
- * The opaque type for a LayoutEngine.
25
- *
26
- * @internal
27
- */
28
- typedef void le_engine;
29
-
30
- /**
31
- * The opaque type for a font instance.
32
- *
33
- * @internal
34
- */
35
- typedef void le_font;
36
-
37
- /**
38
- * This function returns an le_engine capable of laying out text
39
- * in the given font, script and langauge. Note that the LayoutEngine
40
- * returned may be a subclass of LayoutEngine.
41
- *
42
- * @param font - the font of the text
43
- * @param scriptCode - the script of the text
44
- * @param languageCode - the language of the text
45
- * @param typo_flags - flags that control layout features like kerning and ligatures.
46
- * @param success - output parameter set to an error code if the operation fails
47
- *
48
- * @return an le_engine which can layout text in the given font.
49
- *
50
- * @internal
51
- */
52
- U_INTERNAL le_engine * U_EXPORT2
53
- le_create(const le_font *font,
54
- le_int32 scriptCode,
55
- le_int32 languageCode,
56
- le_int32 typo_flags,
57
- LEErrorCode *success);
58
-
59
- /**
60
- * This function closes the given LayoutEngine. After
61
- * it returns, the le_engine is no longer valid.
62
- *
63
- * @param engine - the LayoutEngine to close.
64
- *
65
- * @internal
66
- */
67
- U_INTERNAL void U_EXPORT2
68
- le_close(le_engine *engine);
69
-
70
- /**
71
- * This routine will compute the glyph, character index and position arrays.
72
- *
73
- * @param engine - the LayoutEngine
74
- * @param chars - the input character context
75
- * @param offset - the offset of the first character to process
76
- * @param count - the number of characters to process
77
- * @param max - the number of characters in the input context
78
- * @param rightToLeft - TRUE if the characers are in a right to left directional run
79
- * @param x - the initial X position
80
- * @param y - the initial Y position
81
- * @param success - output parameter set to an error code if the operation fails
82
- *
83
- * @return the number of glyphs in the glyph array
84
- *
85
- * Note: The glyph, character index and position array can be accessed
86
- * using the getter routines below.
87
- *
88
- * Note: If you call this function more than once, you must call the reset()
89
- * function first to free the glyph, character index and position arrays
90
- * allocated by the previous call.
91
- *
92
- * @internal
93
- */
94
- U_INTERNAL le_int32 U_EXPORT2
95
- le_layoutChars(le_engine *engine,
96
- const LEUnicode chars[],
97
- le_int32 offset,
98
- le_int32 count,
99
- le_int32 max,
100
- le_bool rightToLeft,
101
- float x,
102
- float y,
103
- LEErrorCode *success);
104
-
105
- /**
106
- * This function returns the number of glyphs in the glyph array. Note
107
- * that the number of glyphs will be greater than or equal to the number
108
- * of characters used to create the LayoutEngine.
109
- *
110
- * @param engine - the LayoutEngine
111
- * @param success - output parameter set to an error code if the operation fails.
112
- *
113
- * @return the number of glyphs in the glyph array
114
- *
115
- * @internal
116
- */
117
- U_INTERNAL le_int32 U_EXPORT2
118
- le_getGlyphCount(le_engine *engine,
119
- LEErrorCode *success);
120
-
121
- /**
122
- * This function copies the glyph array into a caller supplied array.
123
- * The caller must ensure that the array is large enough to hold all
124
- * the glyphs.
125
- *
126
- * @param engine - the LayoutEngine
127
- * @param glyphs - the destiniation glyph array
128
- * @param success - set to an error code if the operation fails
129
- *
130
- * @internal
131
- */
132
- U_INTERNAL void U_EXPORT2
133
- le_getGlyphs(le_engine *engine,
134
- LEGlyphID glyphs[],
135
- LEErrorCode *success);
136
-
137
- /**
138
- * This function copies the character index array into a caller supplied array.
139
- * The caller must ensure that the array is large enough to hold a
140
- * character index for each glyph.
141
- *
142
- * @param engine - the LayoutEngine
143
- * @param charIndices - the destiniation character index array
144
- * @param success - set to an error code if the operation fails
145
- *
146
- * @internal
147
- */
148
- U_INTERNAL void U_EXPORT2
149
- le_getCharIndices(le_engine *engine,
150
- le_int32 charIndices[],
151
- LEErrorCode *success);
152
-
153
- /**
154
- * This function copies the character index array into a caller supplied array.
155
- * The caller must ensure that the array is large enough to hold a
156
- * character index for each glyph.
157
- *
158
- * @param engine - the LayoutEngine
159
- * @param charIndices - the destiniation character index array
160
- * @param indexBase - an offset that will be added to each index.
161
- * @param success - set to an error code if the operation fails
162
- *
163
- * @internal
164
- */
165
- U_INTERNAL void U_EXPORT2
166
- le_getCharIndicesWithBase(le_engine *engine,
167
- le_int32 charIndices[],
168
- le_int32 indexBase,
169
- LEErrorCode *success);
170
-
171
- /**
172
- * This function copies the position array into a caller supplied array.
173
- * The caller must ensure that the array is large enough to hold an
174
- * X and Y position for each glyph, plus an extra X and Y for the
175
- * advance of the last glyph.
176
- *
177
- * @param engine - the LayoutEngine
178
- * @param positions - the destiniation position array
179
- * @param success - set to an error code if the operation fails
180
- *
181
- * @internal
182
- */
183
- U_INTERNAL void U_EXPORT2
184
- le_getGlyphPositions(le_engine *engine,
185
- float positions[],
186
- LEErrorCode *success);
187
-
188
- /**
189
- * This function returns the X and Y position of the glyph at
190
- * the given index.
191
- *
192
- * Input parameters:
193
- * @param engine - the LayoutEngine
194
- * @param glyphIndex - the index of the glyph
195
- *
196
- * Output parameters:
197
- * @param x - the glyph's X position
198
- * @param y - the glyph's Y position
199
- * @param success - set to an error code if the operation fails
200
- *
201
- * @internal
202
- */
203
- U_INTERNAL void U_EXPORT2
204
- le_getGlyphPosition(le_engine *engine,
205
- le_int32 glyphIndex,
206
- float *x,
207
- float *y,
208
- LEErrorCode *success);
209
-
210
- /**
211
- * This function frees the glyph, character index and position arrays
212
- * so that the LayoutEngine can be reused to layout a different
213
- * characer array. (This function is also called by le_close)
214
- *
215
- * @param engine - the LayoutEngine
216
- * @param success - set to an error code if the operation fails
217
- *
218
- * @internal
219
- */
220
- U_INTERNAL void U_EXPORT2
221
- le_reset(le_engine *engine,
222
- LEErrorCode *success);
223
- #endif /* U_HIDE_INTERNAL_API */
224
-
225
- #endif
@@ -1,466 +0,0 @@
1
- /*
2
- *
3
- * (C) Copyright IBM Corp. 1998-2011 - All Rights Reserved
4
- *
5
- */
6
-
7
- #ifndef __PLAYOUT_H
8
- #define __PLAYOUT_H
9
-
10
- /*
11
- * ParagraphLayout doesn't make much sense without
12
- * BreakIterator...
13
- */
14
- #include "unicode/ubidi.h"
15
- #if ! UCONFIG_NO_BREAK_ITERATION
16
- #ifndef U_HIDE_INTERNAL_API
17
-
18
- #include "layout/LETypes.h"
19
- #include "plruns.h"
20
-
21
- /**
22
- * \file
23
- * \brief C API for paragraph layout.
24
- *
25
- * This is a technology preview. The API may
26
- * change significantly.
27
- *
28
- */
29
-
30
- /**
31
- * The opaque type for a paragraph layout.
32
- *
33
- * @internal
34
- */
35
- typedef void pl_paragraph;
36
-
37
- /**
38
- * The opaque type for a line in a paragraph layout.
39
- *
40
- * @internal
41
- */
42
- typedef void pl_line;
43
-
44
- /**
45
- * The opaque type for a visual run in a line.
46
- *
47
- * @internal
48
- */
49
- typedef void pl_visualRun;
50
-
51
- /**
52
- * Construct a <code>ParagraphLayout</code> object for a styled paragraph. The paragraph is specified
53
- * as runs of text all in the same font. An <code>LEFontInstance</code> object and a limit offset
54
- * are specified for each font run. The limit offset is the offset of the character immediately
55
- * after the font run.
56
- *
57
- * Clients can optionally specify directional runs and / or script runs. If these aren't specified
58
- * they will be computed.
59
- *
60
- * If any errors are encountered during construction, <code>status</code> will be set, and the object
61
- * will be set to be empty.
62
- *
63
- * @param chars is an array of the characters in the paragraph
64
- *
65
- * @param count is the number of characters in the paragraph.
66
- *
67
- * @param fontRuns a pointer to a <code>pl_fontRuns</code> object representing the font runs.
68
- *
69
- * @param levelRuns is a pointer to a <code>pl_valueRuns</code> object representing the directional levels.
70
- * If this pointer in <code>NULL</code> the levels will be determined by running the Unicde
71
- * Bidi algorithm.
72
- *
73
- * @param scriptRuns is a pointer to a <code>pl_valueRuns</code> object representing script runs.
74
- * If this pointer in <code>NULL</code> the script runs will be determined using the
75
- * Unicode code points.
76
- *
77
- * @param localeRuns is a pointer to a <code>pl_localeRuns</code> object representing locale runs.
78
- * The <code>Locale</code> objects are used to determind the language of the text. If this
79
- * pointer is <code>NULL</code> the default locale will be used for all of the text.
80
- *
81
- * @param paragraphLevel is the directionality of the paragraph, as in the UBiDi object.
82
- *
83
- * @param vertical is <code>TRUE</code> if the paragraph should be set vertically.
84
- *
85
- * @param status will be set to any error code encountered during construction.
86
- *
87
- * @return a pointer to the newly created <code>pl_paragraph</code> object. The object
88
- * will remain valid until <code>pl_close</code> is called.
89
- *
90
- * @see ubidi.h
91
- * @see longine.h
92
- * @see plruns.h
93
- *
94
- * @internal
95
- */
96
- U_INTERNAL pl_paragraph * U_EXPORT2
97
- pl_create(const LEUnicode chars[],
98
- le_int32 count,
99
- const pl_fontRuns *fontRuns,
100
- const pl_valueRuns *levelRuns,
101
- const pl_valueRuns *scriptRuns,
102
- const pl_localeRuns *localeRuns,
103
- UBiDiLevel paragraphLevel,
104
- le_bool vertical,
105
- LEErrorCode *status);
106
-
107
- /**
108
- * Close the given paragraph layout object.
109
- *
110
- * @param paragraph the <code>pl_paragraph</code> object to be
111
- * closed. Once this routine returns the object
112
- * can no longer be referenced
113
- *
114
- * @internal
115
- */
116
- U_INTERNAL void U_EXPORT2
117
- pl_close(pl_paragraph *paragraph);
118
-
119
- /**
120
- * Examine the given text and determine if it contains characters in any
121
- * script which requires complex processing to be rendered correctly.
122
- *
123
- * @param chars is an array of the characters in the paragraph
124
- *
125
- * @param count is the number of characters in the paragraph.
126
- *
127
- * @return <code>TRUE</code> if any of the text requires complex processing.
128
- *
129
- * @internal
130
- */
131
-
132
- U_INTERNAL le_bool U_EXPORT2
133
- pl_isComplex(const LEUnicode chars[],
134
- le_int32 count);
135
-
136
- /**
137
- * Return the resolved paragraph level. This is useful for those cases
138
- * where the bidi analysis has determined the level based on the first
139
- * strong character in the paragraph.
140
- *
141
- * @param paragraph the <code>pl_paragraph</code>
142
- *
143
- * @return the resolved paragraph level.
144
- *
145
- * @internal
146
- */
147
- U_INTERNAL UBiDiLevel U_EXPORT2
148
- pl_getParagraphLevel(pl_paragraph *paragraph);
149
-
150
- /**
151
- * Return the directionality of the text in the paragraph.
152
- *
153
- * @param paragraph the <code>pl_paragraph</code>
154
- *
155
- * @return <code>UBIDI_LTR</code> if the text is all left to right,
156
- * <code>UBIDI_RTL</code> if the text is all right to left,
157
- * or <code>UBIDI_MIXED</code> if the text has mixed direction.
158
- *
159
- * @internal
160
- */
161
- U_INTERNAL UBiDiDirection U_EXPORT2
162
- pl_getTextDirection(pl_paragraph *paragraph);
163
-
164
- /**
165
- * Get the max ascent value for all the fonts
166
- * in the paragraph.
167
- *
168
- * @param paragraph the <code>pl_paragraph</code>
169
- *
170
- * Return the max ascent value for all the fonts
171
- * in the paragraph.
172
- *
173
- * @param paragraph the <code>pl_paragraph</code>
174
- *
175
- * @return the ascent value.
176
- *
177
- * @internal
178
- */
179
- U_INTERNAL le_int32 U_EXPORT2
180
- pl_getAscent(const pl_paragraph *paragraph);
181
-
182
- /**
183
- * Return the max descent value for all the fonts
184
- * in the paragraph.
185
- *
186
- * @param paragraph the <code>pl_paragraph</code>
187
- *
188
- * @return the decent value.
189
- *
190
- * @internal
191
- */
192
- U_INTERNAL le_int32 U_EXPORT2
193
- pl_getDescent(const pl_paragraph *paragraph);
194
-
195
- /**
196
- * Return the max leading value for all the fonts
197
- * in the paragraph.
198
- *
199
- * @param paragraph the <code>pl_paragraph</code>
200
- *
201
- * @return the leading value.
202
- *
203
- * @internal
204
- */
205
- U_INTERNAL le_int32 U_EXPORT2
206
- pl_getLeading(const pl_paragraph *paragraph);
207
-
208
- /**
209
- * Reset line breaking to start from the beginning of the paragraph.
210
- *
211
- * @param paragraph the <code>pl_paragraph</code>
212
- *
213
- * @internal
214
- */
215
- U_INTERNAL void U_EXPORT2
216
- pl_reflow(pl_paragraph *paragraph);
217
-
218
- /**
219
- * Return a <code>pl_line</code> object which represents next line
220
- * in the paragraph. The width of the line is specified each time so that it can
221
- * be varied to support arbitrary paragraph shapes.
222
- *
223
- * @param paragraph the <code>pl_paragraph</code>
224
- * @param width is the width of the line. If <code>width</code> is less than or equal
225
- * to zero, a <code>ParagraphLayout::Line</code> object representing the
226
- * rest of the paragraph will be returned.
227
- *
228
- * @return a <code>ParagraphLayout::Line</code> object which represents the line. The caller
229
- * is responsible for deleting the object. Returns <code>NULL</code> if there are no
230
- * more lines in the paragraph.
231
- *
232
- * @see pl_line
233
- *
234
- * @internal
235
- */
236
- U_INTERNAL pl_line * U_EXPORT2
237
- pl_nextLine(pl_paragraph *paragraph, float width);
238
-
239
- /**
240
- * Close the given line object. Line objects are created
241
- * by <code>pl_nextLine</code> but it is the client's responsibility
242
- * to close them by calling this routine.
243
- *
244
- * @param line the <code>pl_line</code> object to close.
245
- *
246
- * @internal
247
- */
248
- U_INTERNAL void U_EXPORT2
249
- pl_closeLine(pl_line *line);
250
-
251
- /**
252
- * Count the number of visual runs in the line.
253
- *
254
- * @param line the <code>pl_line</code> object.
255
- *
256
- * @return the number of visual runs.
257
- *
258
- * @internal
259
- */
260
- U_INTERNAL le_int32 U_EXPORT2
261
- pl_countLineRuns(const pl_line *line);
262
-
263
- /**
264
- * Get the ascent of the line. This is the maximum ascent
265
- * of all the fonts on the line.
266
- *
267
- * @param line the <code>pl_line</code> object.
268
- *
269
- * @return the ascent of the line.
270
- *
271
- * @internal
272
- */
273
- U_INTERNAL le_int32 U_EXPORT2
274
- pl_getLineAscent(const pl_line *line);
275
-
276
- /**
277
- * Get the descent of the line. This is the maximum descent
278
- * of all the fonts on the line.
279
- *
280
- * @param line the <code>pl_line</code> object.
281
- *
282
- * @return the descent of the line.
283
- *
284
- * @internal
285
- */
286
- U_INTERNAL le_int32 U_EXPORT2
287
- pl_getLineDescent(const pl_line *line);
288
-
289
- /**
290
- * Get the leading of the line. This is the maximum leading
291
- * of all the fonts on the line.
292
- *
293
- * @param line the <code>pl_line</code> object.
294
- *
295
- * @return the leading of the line.
296
- *
297
- * @internal
298
- */
299
- U_INTERNAL le_int32 U_EXPORT2
300
- pl_getLineLeading(const pl_line *line);
301
-
302
- /**
303
- * Get the width of the line. This is a convenience method
304
- * which returns the last X position of the last visual run
305
- * in the line.
306
- *
307
- * @param line the <code>pl_line</code> object.
308
- *
309
- * @return the width of the line.
310
- *
311
- * @internal
312
- */
313
- U_INTERNAL le_int32 U_EXPORT2
314
- pl_getLineWidth(const pl_line *line);
315
-
316
- /**
317
- * Get a <code>ParagraphLayout::VisualRun</code> object for a given
318
- * visual run in the line.
319
- *
320
- * @param line the <code>pl_line</code> object.
321
- * @param runIndex is the index of the run, in visual order.
322
- *
323
- * @return the <code>pl_visualRun</code> object representing the
324
- * visual run. This object is owned by the <code>pl_line</code> object which
325
- * created it, and will remain valid for as long as the <code>pl_line</code>
326
- * object is valid.
327
- *
328
- * @see pl_visualRun
329
- *
330
- * @internal
331
- */
332
- U_INTERNAL const pl_visualRun * U_EXPORT2
333
- pl_getLineVisualRun(const pl_line *line, le_int32 runIndex);
334
-
335
- /**
336
- * Get the <code>le_font</code> object which
337
- * represents the font of the visual run. This will always
338
- * be a non-composite font.
339
- *
340
- * @param run the <code>pl_visualRun</code> object.
341
- *
342
- * @return the <code>le_font</code> object which represents the
343
- * font of the visual run.
344
- *
345
- * @see le_font
346
- *
347
- * @internal
348
- */
349
- U_INTERNAL const le_font * U_EXPORT2
350
- pl_getVisualRunFont(const pl_visualRun *run);
351
-
352
- /**
353
- * Get the direction of the visual run.
354
- *
355
- * @param run the <code>pl_visualRun</code> object.
356
- *
357
- * @return the direction of the run. This will be <code>UBIDI_LTR</code> if the
358
- * run is left-to-right and <code>UBIDI_RTL</code> if the line is right-to-left.
359
- *
360
- * @internal
361
- */
362
- U_INTERNAL UBiDiDirection U_EXPORT2
363
- pl_getVisualRunDirection(const pl_visualRun *run);
364
-
365
- /**
366
- * Get the number of glyphs in the visual run.
367
- *
368
- * @param run the <code>pl_visualRun</code> object.
369
- *
370
- * @return the number of glyphs.
371
- *
372
- * @internal
373
- */
374
- U_INTERNAL le_int32 U_EXPORT2
375
- pl_getVisualRunGlyphCount(const pl_visualRun *run);
376
-
377
- /**
378
- * Get the glyphs in the visual run. Glyphs with the values <code>0xFFFE</code> and
379
- * <code>0xFFFF</code> should be ignored.
380
- *
381
- * @param run the <code>pl_visualRun</code> object.
382
- *
383
- * @return the address of the array of glyphs for this visual run. The storage
384
- * is owned by the <code>pl_visualRun</code> object and must not be deleted.
385
- * It will remain valid as long as the <code>pl_visualRun</code> object is valid.
386
- *
387
- * @internal
388
- */
389
- U_INTERNAL const LEGlyphID * U_EXPORT2
390
- pl_getVisualRunGlyphs(const pl_visualRun *run);
391
-
392
- /**
393
- * Get the (x, y) positions of the glyphs in the visual run. To simplify storage
394
- * management, the x and y positions are stored in a single array with the x positions
395
- * at even offsets in the array and the corresponding y position in the following odd offset.
396
- * There is an extra (x, y) pair at the end of the array which represents the advance of
397
- * the final glyph in the run.
398
- *
399
- * @param run the <code>pl_visualRun</code> object.
400
- *
401
- * @return the address of the array of glyph positions for this visual run. The storage
402
- * is owned by the <code>pl_visualRun</code> object and must not be deleted.
403
- * It will remain valid as long as the <code>pl_visualRun</code> object is valid.
404
- *
405
- * @internal
406
- */
407
- U_INTERNAL const float * U_EXPORT2
408
- pl_getVisualRunPositions(const pl_visualRun *run);
409
-
410
- /**
411
- * Get the glyph-to-character map for this visual run. This maps the indices into
412
- * the glyph array to indices into the character array used to create the paragraph.
413
- *
414
- * @param run the <code>pl_visualRun</code> object.
415
- *
416
- * @return the address of the character-to-glyph map for this visual run. The storage
417
- * is owned by the <code>pl_visualRun</code> object and must not be deleted.
418
- * It will remain valid as long as the <code>pl_visualRun</code> object is valid.
419
- *
420
- * @internal
421
- */
422
- U_INTERNAL const le_int32 * U_EXPORT2
423
- pl_getVisualRunGlyphToCharMap(const pl_visualRun *run);
424
-
425
- /**
426
- * A convenience method which returns the ascent value for the font
427
- * associated with this run.
428
- *
429
- * @param run the <code>pl_visualRun</code> object.
430
- *
431
- * @return the ascent value of this run's font.
432
- *
433
- * @internal
434
- */
435
- U_INTERNAL le_int32 U_EXPORT2
436
- pl_getVisualRunAscent(const pl_visualRun *run);
437
-
438
- /**
439
- * A convenience method which returns the descent value for the font
440
- * associated with this run.
441
- *
442
- * @param run the <code>pl_visualRun</code> object.
443
- *
444
- * @return the descent value of this run's font.
445
- *
446
- * @internal
447
- */
448
- U_INTERNAL le_int32 U_EXPORT2
449
- pl_getVisualRunDescent(const pl_visualRun *run);
450
-
451
- /**
452
- * A convenience method which returns the leading value for the font
453
- * associated with this run.
454
- *
455
- * @param run the <code>pl_visualRun</code> object.
456
- *
457
- * @return the leading value of this run's font.
458
- *
459
- * @internal
460
- */
461
- U_INTERNAL le_int32 U_EXPORT2
462
- pl_getVisualRunLeading(const pl_visualRun *run);
463
-
464
- #endif /* U_HIDE_INTERNAL_API */
465
- #endif
466
- #endif