cairo 1.15.13-x64-mingw32 → 1.15.14-x64-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 (151) hide show
  1. checksums.yaml +4 -4
  2. data/NEWS +24 -0
  3. data/README.rdoc +11 -40
  4. data/Rakefile +4 -2
  5. data/ext/cairo/rb_cairo.h +1 -1
  6. data/ext/cairo/rb_cairo_context.c +35 -3
  7. data/ext/cairo/rb_cairo_font_options.c +5 -6
  8. data/ext/cairo/rb_cairo_private.h +2 -2
  9. data/ext/cairo/rb_cairo_scaled_font.c +11 -2
  10. data/ext/cairo/rb_cairo_surface.c +89 -48
  11. data/lib/2.2/cairo.so +0 -0
  12. data/lib/2.3/cairo.so +0 -0
  13. data/lib/2.4/cairo.so +0 -0
  14. data/lib/2.5/cairo.so +0 -0
  15. data/test/{cairo-test-utils.rb → helper.rb} +4 -5
  16. data/test/run-test.rb +3 -10
  17. data/test/test_context.rb +6 -6
  18. data/test/test_font_extents.rb +1 -1
  19. data/test/test_font_face.rb +1 -1
  20. data/test/test_font_options.rb +1 -1
  21. data/test/test_image_surface.rb +2 -2
  22. data/test/test_pdf_surface.rb +1 -1
  23. data/test/test_quartz_image_surface.rb +1 -1
  24. data/test/test_raster_source_pattern.rb +13 -13
  25. data/test/test_recording_surface.rb +2 -2
  26. data/test/test_region.rb +1 -1
  27. data/test/test_scaled_font.rb +1 -1
  28. data/test/test_script_device.rb +1 -1
  29. data/test/test_script_surface.rb +1 -1
  30. data/test/test_surface.rb +5 -5
  31. data/test/test_svg_surface.rb +1 -1
  32. data/test/test_tee_surface.rb +2 -2
  33. data/test/test_text_cluster.rb +1 -1
  34. data/test/test_text_extents.rb +1 -1
  35. data/test/test_text_to_glyphs_data.rb +1 -1
  36. data/test/test_xml_device.rb +1 -1
  37. data/test/test_xml_surface.rb +2 -2
  38. data/vendor/local/bin/fc-cache.exe +0 -0
  39. data/vendor/local/bin/fc-cat.exe +0 -0
  40. data/vendor/local/bin/fc-conflist.exe +0 -0
  41. data/vendor/local/bin/fc-list.exe +0 -0
  42. data/vendor/local/bin/fc-match.exe +0 -0
  43. data/vendor/local/bin/fc-pattern.exe +0 -0
  44. data/vendor/local/bin/fc-query.exe +0 -0
  45. data/vendor/local/bin/fc-scan.exe +0 -0
  46. data/vendor/local/bin/fc-validate.exe +0 -0
  47. data/vendor/local/bin/libcairo-2.dll +0 -0
  48. data/vendor/local/bin/libcairo-gobject-2.dll +0 -0
  49. data/vendor/local/bin/libcairo-script-interpreter-2.dll +0 -0
  50. data/vendor/local/bin/libfontconfig-1.dll +0 -0
  51. data/vendor/local/bin/libfreetype-6.dll +0 -0
  52. data/vendor/local/bin/libpixman-1-0.dll +0 -0
  53. data/vendor/local/bin/libpng-config +1 -1
  54. data/vendor/local/bin/libpng16-16.dll +0 -0
  55. data/vendor/local/bin/libpng16-config +1 -1
  56. data/vendor/local/bin/libxml2-2.dll +0 -0
  57. data/vendor/local/bin/png-fix-itxt.exe +0 -0
  58. data/vendor/local/bin/pngfix.exe +0 -0
  59. data/vendor/local/bin/xmlcatalog.exe +0 -0
  60. data/vendor/local/bin/xmllint.exe +0 -0
  61. data/vendor/local/bin/zlib1211.dll +0 -0
  62. data/vendor/local/include/freetype2/freetype/config/ftconfig.h +82 -3
  63. data/vendor/local/include/freetype2/freetype/config/ftheader.h +43 -85
  64. data/vendor/local/include/freetype2/freetype/config/ftoption.h +43 -56
  65. data/vendor/local/include/freetype2/freetype/config/ftstdlib.h +1 -1
  66. data/vendor/local/include/freetype2/freetype/freetype.h +185 -85
  67. data/vendor/local/include/freetype2/freetype/ftadvanc.h +1 -1
  68. data/vendor/local/include/freetype2/freetype/ftbbox.h +2 -2
  69. data/vendor/local/include/freetype2/freetype/ftbdf.h +1 -1
  70. data/vendor/local/include/freetype2/freetype/ftbitmap.h +2 -2
  71. data/vendor/local/include/freetype2/freetype/ftbzip2.h +1 -1
  72. data/vendor/local/include/freetype2/freetype/ftcache.h +1 -16
  73. data/vendor/local/include/freetype2/freetype/ftchapters.h +3 -0
  74. data/vendor/local/include/freetype2/freetype/ftcid.h +2 -2
  75. data/vendor/local/include/freetype2/freetype/ftdriver.h +1225 -0
  76. data/vendor/local/include/freetype2/freetype/fterrdef.h +1 -1
  77. data/vendor/local/include/freetype2/freetype/fterrors.h +1 -1
  78. data/vendor/local/include/freetype2/freetype/ftfntfmt.h +1 -1
  79. data/vendor/local/include/freetype2/freetype/ftgasp.h +6 -1
  80. data/vendor/local/include/freetype2/freetype/ftglyph.h +3 -3
  81. data/vendor/local/include/freetype2/freetype/ftgxval.h +5 -5
  82. data/vendor/local/include/freetype2/freetype/ftgzip.h +4 -1
  83. data/vendor/local/include/freetype2/freetype/ftimage.h +18 -18
  84. data/vendor/local/include/freetype2/freetype/ftincrem.h +2 -13
  85. data/vendor/local/include/freetype2/freetype/ftlcdfil.h +5 -18
  86. data/vendor/local/include/freetype2/freetype/ftlist.h +1 -1
  87. data/vendor/local/include/freetype2/freetype/ftlzw.h +1 -1
  88. data/vendor/local/include/freetype2/freetype/ftmac.h +1 -1
  89. data/vendor/local/include/freetype2/freetype/ftmm.h +99 -11
  90. data/vendor/local/include/freetype2/freetype/ftmodapi.h +12 -11
  91. data/vendor/local/include/freetype2/freetype/ftmoderr.h +1 -1
  92. data/vendor/local/include/freetype2/freetype/ftotval.h +1 -1
  93. data/vendor/local/include/freetype2/freetype/ftoutln.h +4 -7
  94. data/vendor/local/include/freetype2/freetype/ftparams.h +205 -0
  95. data/vendor/local/include/freetype2/freetype/ftpfr.h +4 -4
  96. data/vendor/local/include/freetype2/freetype/ftrender.h +2 -2
  97. data/vendor/local/include/freetype2/freetype/ftsizes.h +1 -1
  98. data/vendor/local/include/freetype2/freetype/ftsnames.h +8 -42
  99. data/vendor/local/include/freetype2/freetype/ftstroke.h +6 -6
  100. data/vendor/local/include/freetype2/freetype/ftsynth.h +1 -1
  101. data/vendor/local/include/freetype2/freetype/ftsystem.h +1 -1
  102. data/vendor/local/include/freetype2/freetype/fttrigon.h +1 -1
  103. data/vendor/local/include/freetype2/freetype/fttypes.h +2 -2
  104. data/vendor/local/include/freetype2/freetype/ftwinfnt.h +2 -2
  105. data/vendor/local/include/freetype2/freetype/t1tables.h +10 -1
  106. data/vendor/local/include/freetype2/freetype/ttnameid.h +2 -2
  107. data/vendor/local/include/freetype2/freetype/tttables.h +1 -1
  108. data/vendor/local/include/freetype2/freetype/tttags.h +1 -1
  109. data/vendor/local/include/freetype2/ft2build.h +1 -1
  110. data/vendor/local/include/libpng16/png.h +40 -40
  111. data/vendor/local/include/libpng16/pngconf.h +15 -14
  112. data/vendor/local/include/libpng16/pnglibconf.h +1 -1
  113. data/vendor/local/include/png.h +40 -40
  114. data/vendor/local/include/pngconf.h +15 -14
  115. data/vendor/local/include/pnglibconf.h +1 -1
  116. data/vendor/local/lib/libcairo-gobject.dll.a +0 -0
  117. data/vendor/local/lib/libcairo-gobject.la +1 -1
  118. data/vendor/local/lib/libcairo-script-interpreter.a +0 -0
  119. data/vendor/local/lib/libcairo-script-interpreter.dll.a +0 -0
  120. data/vendor/local/lib/libcairo.a +0 -0
  121. data/vendor/local/lib/libcairo.dll.a +0 -0
  122. data/vendor/local/lib/libfontconfig.dll.a +0 -0
  123. data/vendor/local/lib/libfreetype.a +0 -0
  124. data/vendor/local/lib/libfreetype.dll.a +0 -0
  125. data/vendor/local/lib/libfreetype.la +3 -3
  126. data/vendor/local/lib/libpixman-1.dll.a +0 -0
  127. data/vendor/local/lib/libpng.a +0 -0
  128. data/vendor/local/lib/libpng.dll.a +0 -0
  129. data/vendor/local/lib/libpng.la +2 -2
  130. data/vendor/local/lib/libpng16.a +0 -0
  131. data/vendor/local/lib/libpng16.dll.a +0 -0
  132. data/vendor/local/lib/libpng16.la +2 -2
  133. data/vendor/local/lib/libxml2.dll.a +0 -0
  134. data/vendor/local/lib/libz.dll.a +0 -0
  135. data/vendor/local/lib/pkgconfig/freetype2.pc +2 -2
  136. data/vendor/local/lib/pkgconfig/libpng.pc +1 -1
  137. data/vendor/local/lib/pkgconfig/libpng16.pc +1 -1
  138. data/vendor/local/share/aclocal/freetype2.m4 +1 -1
  139. data/vendor/local/share/license/freetype/README +9 -9
  140. data/vendor/local/share/license/freetype/README.git +1 -1
  141. data/vendor/local/share/license/libpng/README +2 -2
  142. data/vendor/local/share/man/man3/libpng.3 +50 -54
  143. data/vendor/local/share/man/man3/libpngpf.3 +8 -4
  144. metadata +9 -14
  145. data/vendor/local/bin/freetype-config +0 -211
  146. data/vendor/local/include/freetype2/freetype/ftautoh.h +0 -533
  147. data/vendor/local/include/freetype2/freetype/ftcffdrv.h +0 -321
  148. data/vendor/local/include/freetype2/freetype/ftpcfdrv.h +0 -105
  149. data/vendor/local/include/freetype2/freetype/ftttdrv.h +0 -328
  150. data/vendor/local/include/freetype2/freetype/ttunpat.h +0 -63
  151. data/vendor/local/share/man/man1/freetype-config.1 +0 -146
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* Quick computation of advance widths (specification only). */
6
6
  /* */
7
- /* Copyright 2008-2017 by */
7
+ /* Copyright 2008-2018 by */
8
8
  /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* FreeType exact bbox computation (specification). */
6
6
  /* */
7
- /* Copyright 1996-2017 by */
7
+ /* Copyright 1996-2018 by */
8
8
  /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -61,7 +61,7 @@ FT_BEGIN_HEADER
61
61
  /* Compute the exact bounding box of an outline. This is slower */
62
62
  /* than computing the control box. However, it uses an advanced */
63
63
  /* algorithm that returns _very_ quickly when the two boxes */
64
- /* coincide. Otherwise, the outline Bézier arcs are traversed to */
64
+ /* coincide. Otherwise, the outline Bezier arcs are traversed to */
65
65
  /* extract their extrema. */
66
66
  /* */
67
67
  /* <Input> */
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* FreeType API for accessing BDF-specific strings (specification). */
6
6
  /* */
7
- /* Copyright 2002-2017 by */
7
+ /* Copyright 2002-2018 by */
8
8
  /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* FreeType utility functions for bitmaps (specification). */
6
6
  /* */
7
- /* Copyright 2004-2017 by */
7
+ /* Copyright 2004-2018 by */
8
8
  /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -97,7 +97,7 @@ FT_BEGIN_HEADER
97
97
  FT_EXPORT( FT_Error )
98
98
  FT_Bitmap_Copy( FT_Library library,
99
99
  const FT_Bitmap *source,
100
- FT_Bitmap *target);
100
+ FT_Bitmap *target );
101
101
 
102
102
 
103
103
  /*************************************************************************/
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* Bzip2-compressed stream support. */
6
6
  /* */
7
- /* Copyright 2010-2017 by */
7
+ /* Copyright 2010-2018 by */
8
8
  /* Joel Klinghed. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* FreeType Cache subsystem (specification). */
6
6
  /* */
7
- /* Copyright 1996-2017 by */
7
+ /* Copyright 1996-2018 by */
8
8
  /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -540,13 +540,6 @@ FT_BEGIN_HEADER
540
540
  FTC_FaceID face_id );
541
541
 
542
542
 
543
- /*************************************************************************/
544
- /* */
545
- /* <Section> */
546
- /* cache_subsystem */
547
- /* */
548
- /*************************************************************************/
549
-
550
543
  /*************************************************************************
551
544
  *
552
545
  * @type:
@@ -623,14 +616,6 @@ FT_BEGIN_HEADER
623
616
  FT_UInt32 char_code );
624
617
 
625
618
 
626
- /*************************************************************************/
627
- /* */
628
- /* <Section> */
629
- /* cache_subsystem */
630
- /* */
631
- /*************************************************************************/
632
-
633
-
634
619
  /*************************************************************************/
635
620
  /*************************************************************************/
636
621
  /*************************************************************************/
@@ -76,8 +76,11 @@
76
76
  /* <Sections> */
77
77
  /* auto_hinter */
78
78
  /* cff_driver */
79
+ /* t1_cid_driver */
79
80
  /* tt_driver */
80
81
  /* pcf_driver */
82
+ /* properties */
83
+ /* parameter_tags */
81
84
  /* */
82
85
  /***************************************************************************/
83
86
 
@@ -4,7 +4,7 @@
4
4
  /* */
5
5
  /* FreeType API for accessing CID font information (specification). */
6
6
  /* */
7
- /* Copyright 2007-2017 by */
7
+ /* Copyright 2007-2018 by */
8
8
  /* Dereg Clegg and Michael Toftdal. */
9
9
  /* */
10
10
  /* This file is part of the FreeType project, and may only be used, */
@@ -87,7 +87,7 @@ FT_BEGIN_HEADER
87
87
  FT_Get_CID_Registry_Ordering_Supplement( FT_Face face,
88
88
  const char* *registry,
89
89
  const char* *ordering,
90
- FT_Int *supplement);
90
+ FT_Int *supplement );
91
91
 
92
92
 
93
93
  /**********************************************************************
@@ -0,0 +1,1225 @@
1
+ /***************************************************************************/
2
+ /* */
3
+ /* ftdriver.h */
4
+ /* */
5
+ /* FreeType API for controlling driver modules (specification only). */
6
+ /* */
7
+ /* Copyright 2017-2018 by */
8
+ /* David Turner, Robert Wilhelm, and Werner Lemberg. */
9
+ /* */
10
+ /* This file is part of the FreeType project, and may only be used, */
11
+ /* modified, and distributed under the terms of the FreeType project */
12
+ /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
13
+ /* this file you indicate that you have read the license and */
14
+ /* understand and accept it fully. */
15
+ /* */
16
+ /***************************************************************************/
17
+
18
+
19
+ #ifndef FTDRIVER_H_
20
+ #define FTDRIVER_H_
21
+
22
+ #include <ft2build.h>
23
+ #include FT_FREETYPE_H
24
+ #include FT_PARAMETER_TAGS_H
25
+
26
+ #ifdef FREETYPE_H
27
+ #error "freetype.h of FreeType 1 has been loaded!"
28
+ #error "Please fix the directory search order for header files"
29
+ #error "so that freetype.h of FreeType 2 is found first."
30
+ #endif
31
+
32
+
33
+ FT_BEGIN_HEADER
34
+
35
+
36
+ /**************************************************************************
37
+ *
38
+ * @section:
39
+ * auto_hinter
40
+ *
41
+ * @title:
42
+ * The auto-hinter
43
+ *
44
+ * @abstract:
45
+ * Controlling the auto-hinting module.
46
+ *
47
+ * @description:
48
+ * While FreeType's auto-hinter doesn't expose API functions by itself,
49
+ * it is possible to control its behaviour with @FT_Property_Set and
50
+ * @FT_Property_Get. The following lists the available properties
51
+ * together with the necessary macros and structures.
52
+ *
53
+ * Note that the auto-hinter's module name is `autofitter' for
54
+ * historical reasons.
55
+ *
56
+ * Available properties are @increase-x-height, @no-stem-darkening
57
+ * (experimental), @darkening-parameters (experimental), @warping
58
+ * (experimental), @glyph-to-script-map (experimental), @fallback-script
59
+ * (experimental), and @default-script (experimental), as documented in
60
+ * the @properties section.
61
+ *
62
+ */
63
+
64
+
65
+ /**************************************************************************
66
+ *
67
+ * @section:
68
+ * cff_driver
69
+ *
70
+ * @title:
71
+ * The CFF driver
72
+ *
73
+ * @abstract:
74
+ * Controlling the CFF driver module.
75
+ *
76
+ * @description:
77
+ * While FreeType's CFF driver doesn't expose API functions by itself,
78
+ * it is possible to control its behaviour with @FT_Property_Set and
79
+ * @FT_Property_Get.
80
+ *
81
+ * The CFF driver's module name is `cff'.
82
+ *
83
+ * Available properties are @hinting-engine, @no-stem-darkening,
84
+ * @darkening-parameters, and @random-seed, as documented in the
85
+ * @properties section.
86
+ *
87
+ *
88
+ * *Hinting* *and* *antialiasing* *principles* *of* *the* *new* *engine*
89
+ *
90
+ * The rasterizer is positioning horizontal features (e.g., ascender
91
+ * height & x-height, or crossbars) on the pixel grid and minimizing the
92
+ * amount of antialiasing applied to them, while placing vertical
93
+ * features (vertical stems) on the pixel grid without hinting, thus
94
+ * representing the stem position and weight accurately. Sometimes the
95
+ * vertical stems may be only partially black. In this context,
96
+ * `antialiasing' means that stems are not positioned exactly on pixel
97
+ * borders, causing a fuzzy appearance.
98
+ *
99
+ * There are two principles behind this approach.
100
+ *
101
+ * 1) No hinting in the horizontal direction: Unlike `superhinted'
102
+ * TrueType, which changes glyph widths to accommodate regular
103
+ * inter-glyph spacing, Adobe's approach is `faithful to the design' in
104
+ * representing both the glyph width and the inter-glyph spacing
105
+ * designed for the font. This makes the screen display as close as it
106
+ * can be to the result one would get with infinite resolution, while
107
+ * preserving what is considered the key characteristics of each glyph.
108
+ * Note that the distances between unhinted and grid-fitted positions at
109
+ * small sizes are comparable to kerning values and thus would be
110
+ * noticeable (and distracting) while reading if hinting were applied.
111
+ *
112
+ * One of the reasons to not hint horizontally is antialiasing for LCD
113
+ * screens: The pixel geometry of modern displays supplies three
114
+ * vertical subpixels as the eye moves horizontally across each visible
115
+ * pixel. On devices where we can be certain this characteristic is
116
+ * present a rasterizer can take advantage of the subpixels to add
117
+ * increments of weight. In Western writing systems this turns out to
118
+ * be the more critical direction anyway; the weights and spacing of
119
+ * vertical stems (see above) are central to Armenian, Cyrillic, Greek,
120
+ * and Latin type designs. Even when the rasterizer uses greyscale
121
+ * antialiasing instead of color (a necessary compromise when one
122
+ * doesn't know the screen characteristics), the unhinted vertical
123
+ * features preserve the design's weight and spacing much better than
124
+ * aliased type would.
125
+ *
126
+ * 2) Alignment in the vertical direction: Weights and spacing along the
127
+ * y~axis are less critical; what is much more important is the visual
128
+ * alignment of related features (like cap-height and x-height). The
129
+ * sense of alignment for these is enhanced by the sharpness of grid-fit
130
+ * edges, while the cruder vertical resolution (full pixels instead of
131
+ * 1/3 pixels) is less of a problem.
132
+ *
133
+ * On the technical side, horizontal alignment zones for ascender,
134
+ * x-height, and other important height values (traditionally called
135
+ * `blue zones') as defined in the font are positioned independently,
136
+ * each being rounded to the nearest pixel edge, taking care of
137
+ * overshoot suppression at small sizes, stem darkening, and scaling.
138
+ *
139
+ * Hstems (this is, hint values defined in the font to help align
140
+ * horizontal features) that fall within a blue zone are said to be
141
+ * `captured' and are aligned to that zone. Uncaptured stems are moved
142
+ * in one of four ways, top edge up or down, bottom edge up or down.
143
+ * Unless there are conflicting hstems, the smallest movement is taken
144
+ * to minimize distortion.
145
+ *
146
+ */
147
+
148
+
149
+ /**************************************************************************
150
+ *
151
+ * @section:
152
+ * pcf_driver
153
+ *
154
+ * @title:
155
+ * The PCF driver
156
+ *
157
+ * @abstract:
158
+ * Controlling the PCF driver module.
159
+ *
160
+ * @description:
161
+ * While FreeType's PCF driver doesn't expose API functions by itself,
162
+ * it is possible to control its behaviour with @FT_Property_Set and
163
+ * @FT_Property_Get. Right now, there is a single property
164
+ * @no-long-family-names available if FreeType is compiled with
165
+ * PCF_CONFIG_OPTION_LONG_FAMILY_NAMES.
166
+ *
167
+ * The PCF driver's module name is `pcf'.
168
+ *
169
+ */
170
+
171
+
172
+ /**************************************************************************
173
+ *
174
+ * @section:
175
+ * t1_cid_driver
176
+ *
177
+ * @title:
178
+ * The Type 1 and CID drivers
179
+ *
180
+ * @abstract:
181
+ * Controlling the Type~1 and CID driver modules.
182
+ *
183
+ * @description:
184
+ * It is possible to control the behaviour of FreeType's Type~1 and
185
+ * Type~1 CID drivers with @FT_Property_Set and @FT_Property_Get.
186
+ *
187
+ * Behind the scenes, both drivers use the Adobe CFF engine for hinting;
188
+ * however, the used properties must be specified separately.
189
+ *
190
+ * The Type~1 driver's module name is `type1'; the CID driver's module
191
+ * name is `t1cid'.
192
+ *
193
+ * Available properties are @hinting-engine, @no-stem-darkening,
194
+ * @darkening-parameters, and @random-seed, as documented in the
195
+ * @properties section.
196
+ *
197
+ * Please see the @cff_driver section for more details on the new
198
+ * hinting engine.
199
+ *
200
+ */
201
+
202
+
203
+ /**************************************************************************
204
+ *
205
+ * @section:
206
+ * tt_driver
207
+ *
208
+ * @title:
209
+ * The TrueType driver
210
+ *
211
+ * @abstract:
212
+ * Controlling the TrueType driver module.
213
+ *
214
+ * @description:
215
+ * While FreeType's TrueType driver doesn't expose API functions by
216
+ * itself, it is possible to control its behaviour with @FT_Property_Set
217
+ * and @FT_Property_Get. The following lists the available properties
218
+ * together with the necessary macros and structures.
219
+ *
220
+ * The TrueType driver's module name is `truetype'.
221
+ *
222
+ * A single property @interpreter-version is available, as documented in
223
+ * the @properties section.
224
+ *
225
+ * We start with a list of definitions, kindly provided by Greg
226
+ * Hitchcock.
227
+ *
228
+ * _Bi-Level_ _Rendering_
229
+ *
230
+ * Monochromatic rendering, exclusively used in the early days of
231
+ * TrueType by both Apple and Microsoft. Microsoft's GDI interface
232
+ * supported hinting of the right-side bearing point, such that the
233
+ * advance width could be non-linear. Most often this was done to
234
+ * achieve some level of glyph symmetry. To enable reasonable
235
+ * performance (e.g., not having to run hinting on all glyphs just to
236
+ * get the widths) there was a bit in the head table indicating if the
237
+ * side bearing was hinted, and additional tables, `hdmx' and `LTSH', to
238
+ * cache hinting widths across multiple sizes and device aspect ratios.
239
+ *
240
+ * _Font_ _Smoothing_
241
+ *
242
+ * Microsoft's GDI implementation of anti-aliasing. Not traditional
243
+ * anti-aliasing as the outlines were hinted before the sampling. The
244
+ * widths matched the bi-level rendering.
245
+ *
246
+ * _ClearType_ _Rendering_
247
+ *
248
+ * Technique that uses physical subpixels to improve rendering on LCD
249
+ * (and other) displays. Because of the higher resolution, many methods
250
+ * of improving symmetry in glyphs through hinting the right-side
251
+ * bearing were no longer necessary. This lead to what GDI calls
252
+ * `natural widths' ClearType, see
253
+ * http://www.beatstamm.com/typography/RTRCh4.htm#Sec21. Since hinting
254
+ * has extra resolution, most non-linearity went away, but it is still
255
+ * possible for hints to change the advance widths in this mode.
256
+ *
257
+ * _ClearType_ _Compatible_ _Widths_
258
+ *
259
+ * One of the earliest challenges with ClearType was allowing the
260
+ * implementation in GDI to be selected without requiring all UI and
261
+ * documents to reflow. To address this, a compatible method of
262
+ * rendering ClearType was added where the font hints are executed once
263
+ * to determine the width in bi-level rendering, and then re-run in
264
+ * ClearType, with the difference in widths being absorbed in the font
265
+ * hints for ClearType (mostly in the white space of hints); see
266
+ * http://www.beatstamm.com/typography/RTRCh4.htm#Sec20. Somewhat by
267
+ * definition, compatible width ClearType allows for non-linear widths,
268
+ * but only when the bi-level version has non-linear widths.
269
+ *
270
+ * _ClearType_ _Subpixel_ _Positioning_
271
+ *
272
+ * One of the nice benefits of ClearType is the ability to more crisply
273
+ * display fractional widths; unfortunately, the GDI model of integer
274
+ * bitmaps did not support this. However, the WPF and Direct Write
275
+ * frameworks do support fractional widths. DWrite calls this `natural
276
+ * mode', not to be confused with GDI's `natural widths'. Subpixel
277
+ * positioning, in the current implementation of Direct Write,
278
+ * unfortunately does not support hinted advance widths, see
279
+ * http://www.beatstamm.com/typography/RTRCh4.htm#Sec22. Note that the
280
+ * TrueType interpreter fully allows the advance width to be adjusted in
281
+ * this mode, just the DWrite client will ignore those changes.
282
+ *
283
+ * _ClearType_ _Backward_ _Compatibility_
284
+ *
285
+ * This is a set of exceptions made in the TrueType interpreter to
286
+ * minimize hinting techniques that were problematic with the extra
287
+ * resolution of ClearType; see
288
+ * http://www.beatstamm.com/typography/RTRCh4.htm#Sec1 and
289
+ * https://www.microsoft.com/typography/cleartype/truetypecleartype.aspx.
290
+ * This technique is not to be confused with ClearType compatible
291
+ * widths. ClearType backward compatibility has no direct impact on
292
+ * changing advance widths, but there might be an indirect impact on
293
+ * disabling some deltas. This could be worked around in backward
294
+ * compatibility mode.
295
+ *
296
+ * _Native_ _ClearType_ _Mode_
297
+ *
298
+ * (Not to be confused with `natural widths'.) This mode removes all
299
+ * the exceptions in the TrueType interpreter when running with
300
+ * ClearType. Any issues on widths would still apply, though.
301
+ *
302
+ */
303
+
304
+
305
+ /**************************************************************************
306
+ *
307
+ * @section:
308
+ * properties
309
+ *
310
+ * @title:
311
+ * Driver properties
312
+ *
313
+ * @abstract:
314
+ * Controlling driver modules.
315
+ *
316
+ * @description:
317
+ * Driver modules can be controlled by setting and unsetting properties,
318
+ * using the functions @FT_Property_Set and @FT_Property_Get. This
319
+ * section documents the available properties, together with auxiliary
320
+ * macros and structures.
321
+ *
322
+ */
323
+
324
+
325
+ /**************************************************************************
326
+ *
327
+ * @enum:
328
+ * FT_HINTING_XXX
329
+ *
330
+ * @description:
331
+ * A list of constants used for the @hinting-engine property to
332
+ * select the hinting engine for CFF, Type~1, and CID fonts.
333
+ *
334
+ * @values:
335
+ * FT_HINTING_FREETYPE ::
336
+ * Use the old FreeType hinting engine.
337
+ *
338
+ * FT_HINTING_ADOBE ::
339
+ * Use the hinting engine contributed by Adobe.
340
+ *
341
+ * @since:
342
+ * 2.9
343
+ *
344
+ */
345
+ #define FT_HINTING_FREETYPE 0
346
+ #define FT_HINTING_ADOBE 1
347
+
348
+ /* these constants (introduced in 2.4.12) are deprecated */
349
+ #define FT_CFF_HINTING_FREETYPE FT_HINTING_FREETYPE
350
+ #define FT_CFF_HINTING_ADOBE FT_HINTING_ADOBE
351
+
352
+
353
+ /**************************************************************************
354
+ *
355
+ * @property:
356
+ * hinting-engine
357
+ *
358
+ * @description:
359
+ * Thanks to Adobe, which contributed a new hinting (and parsing)
360
+ * engine, an application can select between `freetype' and `adobe' if
361
+ * compiled with CFF_CONFIG_OPTION_OLD_ENGINE. If this configuration
362
+ * macro isn't defined, `hinting-engine' does nothing.
363
+ *
364
+ * The same holds for the Type~1 and CID modules if compiled with
365
+ * T1_CONFIG_OPTION_OLD_ENGINE.
366
+ *
367
+ * For the `cff' module, the default engine is `freetype' if
368
+ * CFF_CONFIG_OPTION_OLD_ENGINE is defined, and `adobe' otherwise.
369
+ *
370
+ * For both the `type1' and `t1cid' modules, the default engine is
371
+ * `freetype' if T1_CONFIG_OPTION_OLD_ENGINE is defined, and `adobe'
372
+ * otherwise.
373
+ *
374
+ * The following example code demonstrates how to select Adobe's hinting
375
+ * engine for the `cff' module (omitting the error handling).
376
+ *
377
+ * {
378
+ * FT_Library library;
379
+ * FT_UInt hinting_engine = FT_CFF_HINTING_ADOBE;
380
+ *
381
+ *
382
+ * FT_Init_FreeType( &library );
383
+ *
384
+ * FT_Property_Set( library, "cff",
385
+ * "hinting-engine", &hinting_engine );
386
+ * }
387
+ *
388
+ * @note:
389
+ * This property can be used with @FT_Property_Get also.
390
+ *
391
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
392
+ * variable (using values `adobe' or `freetype').
393
+ *
394
+ * @since:
395
+ * 2.4.12 (for `cff' module)
396
+ *
397
+ * 2.9 (for `type1' and `t1cid' modules)
398
+ *
399
+ */
400
+
401
+
402
+ /**************************************************************************
403
+ *
404
+ * @property:
405
+ * no-stem-darkening
406
+ *
407
+ * @description:
408
+ * All glyphs that pass through the auto-hinter will be emboldened
409
+ * unless this property is set to TRUE. The same is true for the CFF,
410
+ * Type~1, and CID font modules if the `Adobe' engine is selected (which
411
+ * is the default).
412
+ *
413
+ * Stem darkening emboldens glyphs at smaller sizes to make them more
414
+ * readable on common low-DPI screens when using linear alpha blending
415
+ * and gamma correction, see @FT_Render_Glyph. When not using linear
416
+ * alpha blending and gamma correction, glyphs will appear heavy and
417
+ * fuzzy!
418
+ *
419
+ * Gamma correction essentially lightens fonts since shades of grey are
420
+ * shifted to higher pixel values (=~higher brightness) to match the
421
+ * original intention to the reality of our screens. The side-effect is
422
+ * that glyphs `thin out'. Mac OS~X and Adobe's proprietary font
423
+ * rendering library implement a counter-measure: stem darkening at
424
+ * smaller sizes where shades of gray dominate. By emboldening a glyph
425
+ * slightly in relation to its pixel size, individual pixels get higher
426
+ * coverage of filled-in outlines and are therefore `blacker'. This
427
+ * counteracts the `thinning out' of glyphs, making text remain readable
428
+ * at smaller sizes.
429
+ *
430
+ * By default, the Adobe engines for CFF, Type~1, and CID fonts darken
431
+ * stems at smaller sizes, regardless of hinting, to enhance contrast.
432
+ * Setting this property, stem darkening gets switched off.
433
+ *
434
+ * For the auto-hinter, stem-darkening is experimental currently and
435
+ * thus switched off by default (this is, `no-stem-darkening' is set to
436
+ * TRUE by default). Total consistency with the CFF driver is not
437
+ * achieved right now because the emboldening method differs and glyphs
438
+ * must be scaled down on the Y-axis to keep outline points inside their
439
+ * precomputed blue zones. The smaller the size (especially 9ppem and
440
+ * down), the higher the loss of emboldening versus the CFF driver.
441
+ *
442
+ * Note that stem darkening is never applied if @FT_LOAD_NO_SCALE is
443
+ * set.
444
+ *
445
+ * {
446
+ * FT_Library library;
447
+ * FT_Bool no_stem_darkening = TRUE;
448
+ *
449
+ *
450
+ * FT_Init_FreeType( &library );
451
+ *
452
+ * FT_Property_Set( library, "cff",
453
+ * "no-stem-darkening", &no_stem_darkening );
454
+ * }
455
+ *
456
+ * @note:
457
+ * This property can be used with @FT_Property_Get also.
458
+ *
459
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
460
+ * variable (using values 1 and 0 for `on' and `off', respectively).
461
+ * It can also be set per face using @FT_Face_Properties with
462
+ * @FT_PARAM_TAG_STEM_DARKENING.
463
+ *
464
+ * @since:
465
+ * 2.4.12 (for `cff' module)
466
+ *
467
+ * 2.6.2 (for `autofitter' module)
468
+ *
469
+ * 2.9 (for `type1' and `t1cid' modules)
470
+ *
471
+ */
472
+
473
+
474
+ /**************************************************************************
475
+ *
476
+ * @property:
477
+ * darkening-parameters
478
+ *
479
+ * @description:
480
+ * By default, the Adobe hinting engine, as used by the CFF, Type~1, and
481
+ * CID font drivers, darkens stems as follows (if the
482
+ * `no-stem-darkening' property isn't set):
483
+ *
484
+ * {
485
+ * stem width <= 0.5px: darkening amount = 0.4px
486
+ * stem width = 1px: darkening amount = 0.275px
487
+ * stem width = 1.667px: darkening amount = 0.275px
488
+ * stem width >= 2.333px: darkening amount = 0px
489
+ * }
490
+ *
491
+ * and piecewise linear in-between. At configuration time, these four
492
+ * control points can be set with the macro
493
+ * `CFF_CONFIG_OPTION_DARKENING_PARAMETERS'; the CFF, Type~1, and CID
494
+ * drivers share these values. At runtime, the control points can be
495
+ * changed using the `darkening-parameters' property, as the following
496
+ * example demonstrates for the Type~1 driver.
497
+ *
498
+ * {
499
+ * FT_Library library;
500
+ * FT_Int darken_params[8] = { 500, 300, // x1, y1
501
+ * 1000, 200, // x2, y2
502
+ * 1500, 100, // x3, y3
503
+ * 2000, 0 }; // x4, y4
504
+ *
505
+ *
506
+ * FT_Init_FreeType( &library );
507
+ *
508
+ * FT_Property_Set( library, "type1",
509
+ * "darkening-parameters", darken_params );
510
+ * }
511
+ *
512
+ * The x~values give the stem width, and the y~values the darkening
513
+ * amount. The unit is 1000th of pixels. All coordinate values must be
514
+ * positive; the x~values must be monotonically increasing; the
515
+ * y~values must be monotonically decreasing and smaller than or
516
+ * equal to 500 (corresponding to half a pixel); the slope of each
517
+ * linear piece must be shallower than -1 (e.g., -.4).
518
+ *
519
+ * The auto-hinter provides this property, too, as an experimental
520
+ * feature. See @no-stem-darkening for more.
521
+ *
522
+ * @note:
523
+ * This property can be used with @FT_Property_Get also.
524
+ *
525
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
526
+ * variable, using eight comma-separated integers without spaces. Here
527
+ * the above example, using `\' to break the line for readability.
528
+ *
529
+ * {
530
+ * FREETYPE_PROPERTIES=\
531
+ * type1:darkening-parameters=500,300,1000,200,1500,100,2000,0
532
+ * }
533
+ *
534
+ * @since:
535
+ * 2.5.1 (for `cff' module)
536
+ *
537
+ * 2.6.2 (for `autofitter' module)
538
+ *
539
+ * 2.9 (for `type1' and `t1cid' modules)
540
+ *
541
+ */
542
+
543
+
544
+ /**************************************************************************
545
+ *
546
+ * @property:
547
+ * random-seed
548
+ *
549
+ * @description:
550
+ * By default, the seed value for the CFF `random' operator and the
551
+ * similar `0 28 callothersubr pop' command for the Type~1 and CID
552
+ * drivers is set to a random value. However, mainly for debugging
553
+ * purposes, it is often necessary to use a known value as a seed so
554
+ * that the pseudo-random number sequences generated by `random' are
555
+ * repeatable.
556
+ *
557
+ * The `random-seed' property does that. Its argument is a signed 32bit
558
+ * integer; if the value is zero or negative, the seed given by the
559
+ * `intitialRandomSeed' private DICT operator in a CFF file gets used
560
+ * (or a default value if there is no such operator). If the value is
561
+ * positive, use it instead of `initialRandomSeed', which is
562
+ * consequently ignored.
563
+ *
564
+ * @note:
565
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
566
+ * variable. It can also be set per face using @FT_Face_Properties with
567
+ * @FT_PARAM_TAG_RANDOM_SEED.
568
+ *
569
+ * @since:
570
+ * 2.8 (for `cff' module)
571
+ *
572
+ * 2.9 (for `type1' and `t1cid' modules)
573
+ *
574
+ */
575
+
576
+
577
+ /**************************************************************************
578
+ *
579
+ * @property:
580
+ * no-long-family-names
581
+ *
582
+ * @description:
583
+ * If PCF_CONFIG_OPTION_LONG_FAMILY_NAMES is active while compiling
584
+ * FreeType, the PCF driver constructs long family names.
585
+ *
586
+ * There are many PCF fonts just called `Fixed' which look completely
587
+ * different, and which have nothing to do with each other. When
588
+ * selecting `Fixed' in KDE or Gnome one gets results that appear rather
589
+ * random, the style changes often if one changes the size and one
590
+ * cannot select some fonts at all. The improve this situation, the PCF
591
+ * module prepends the foundry name (plus a space) to the family name.
592
+ * It also checks whether there are `wide' characters; all put together,
593
+ * family names like `Sony Fixed' or `Misc Fixed Wide' are constructed.
594
+ *
595
+ * If `no-long-family-names' is set, this feature gets switched off.
596
+ *
597
+ * {
598
+ * FT_Library library;
599
+ * FT_Bool no_long_family_names = TRUE;
600
+ *
601
+ *
602
+ * FT_Init_FreeType( &library );
603
+ *
604
+ * FT_Property_Set( library, "pcf",
605
+ * "no-long-family-names",
606
+ * &no_long_family_names );
607
+ * }
608
+ *
609
+ * @note:
610
+ * This property can be used with @FT_Property_Get also.
611
+ *
612
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
613
+ * variable (using values 1 and 0 for `on' and `off', respectively).
614
+ *
615
+ * @since:
616
+ * 2.8
617
+ */
618
+
619
+
620
+ /**************************************************************************
621
+ *
622
+ * @enum:
623
+ * TT_INTERPRETER_VERSION_XXX
624
+ *
625
+ * @description:
626
+ * A list of constants used for the @interpreter-version property to
627
+ * select the hinting engine for Truetype fonts.
628
+ *
629
+ * The numeric value in the constant names represents the version
630
+ * number as returned by the `GETINFO' bytecode instruction.
631
+ *
632
+ * @values:
633
+ * TT_INTERPRETER_VERSION_35 ::
634
+ * Version~35 corresponds to MS rasterizer v.1.7 as used e.g. in
635
+ * Windows~98; only grayscale and B/W rasterizing is supported.
636
+ *
637
+ * TT_INTERPRETER_VERSION_38 ::
638
+ * Version~38 corresponds to MS rasterizer v.1.9; it is roughly
639
+ * equivalent to the hinting provided by DirectWrite ClearType (as can
640
+ * be found, for example, in the Internet Explorer~9 running on
641
+ * Windows~7). It is used in FreeType to select the `Infinality'
642
+ * subpixel hinting code. The code may be removed in a future
643
+ * version.
644
+ *
645
+ * TT_INTERPRETER_VERSION_40 ::
646
+ * Version~40 corresponds to MS rasterizer v.2.1; it is roughly
647
+ * equivalent to the hinting provided by DirectWrite ClearType (as can
648
+ * be found, for example, in Microsoft's Edge Browser on Windows~10).
649
+ * It is used in FreeType to select the `minimal' subpixel hinting
650
+ * code, a stripped-down and higher performance version of the
651
+ * `Infinality' code.
652
+ *
653
+ * @note:
654
+ * This property controls the behaviour of the bytecode interpreter
655
+ * and thus how outlines get hinted. It does *not* control how glyph
656
+ * get rasterized! In particular, it does not control subpixel color
657
+ * filtering.
658
+ *
659
+ * If FreeType has not been compiled with the configuration option
660
+ * TT_CONFIG_OPTION_SUBPIXEL_HINTING, selecting version~38 or~40 causes
661
+ * an `FT_Err_Unimplemented_Feature' error.
662
+ *
663
+ * Depending on the graphics framework, Microsoft uses different
664
+ * bytecode and rendering engines. As a consequence, the version
665
+ * numbers returned by a call to the `GETINFO' bytecode instruction are
666
+ * more convoluted than desired.
667
+ *
668
+ * Here are two tables that try to shed some light on the possible
669
+ * values for the MS rasterizer engine, together with the additional
670
+ * features introduced by it.
671
+ *
672
+ * {
673
+ * GETINFO framework version feature
674
+ * -------------------------------------------------------------------
675
+ * 3 GDI (Win 3.1), v1.0 16-bit, first version
676
+ * TrueImage
677
+ * 33 GDI (Win NT 3.1), v1.5 32-bit
678
+ * HP Laserjet
679
+ * 34 GDI (Win 95) v1.6 font smoothing,
680
+ * new SCANTYPE opcode
681
+ * 35 GDI (Win 98/2000) v1.7 (UN)SCALED_COMPONENT_OFFSET
682
+ * bits in composite glyphs
683
+ * 36 MGDI (Win CE 2) v1.6+ classic ClearType
684
+ * 37 GDI (XP and later), v1.8 ClearType
685
+ * GDI+ old (before Vista)
686
+ * 38 GDI+ old (Vista, Win 7), v1.9 subpixel ClearType,
687
+ * WPF Y-direction ClearType,
688
+ * additional error checking
689
+ * 39 DWrite (before Win 8) v2.0 subpixel ClearType flags
690
+ * in GETINFO opcode,
691
+ * bug fixes
692
+ * 40 GDI+ (after Win 7), v2.1 Y-direction ClearType flag
693
+ * DWrite (Win 8) in GETINFO opcode,
694
+ * Gray ClearType
695
+ * }
696
+ *
697
+ * The `version' field gives a rough orientation only, since some
698
+ * applications provided certain features much earlier (as an example,
699
+ * Microsoft Reader used subpixel and Y-direction ClearType already in
700
+ * Windows 2000). Similarly, updates to a given framework might include
701
+ * improved hinting support.
702
+ *
703
+ * {
704
+ * version sampling rendering comment
705
+ * x y x y
706
+ * --------------------------------------------------------------
707
+ * v1.0 normal normal B/W B/W bi-level
708
+ * v1.6 high high gray gray grayscale
709
+ * v1.8 high normal color-filter B/W (GDI) ClearType
710
+ * v1.9 high high color-filter gray Color ClearType
711
+ * v2.1 high normal gray B/W Gray ClearType
712
+ * v2.1 high high gray gray Gray ClearType
713
+ * }
714
+ *
715
+ * Color and Gray ClearType are the two available variants of
716
+ * `Y-direction ClearType', meaning grayscale rasterization along the
717
+ * Y-direction; the name used in the TrueType specification for this
718
+ * feature is `symmetric smoothing'. `Classic ClearType' is the
719
+ * original algorithm used before introducing a modified version in
720
+ * Win~XP. Another name for v1.6's grayscale rendering is `font
721
+ * smoothing', and `Color ClearType' is sometimes also called `DWrite
722
+ * ClearType'. To differentiate between today's Color ClearType and the
723
+ * earlier ClearType variant with B/W rendering along the vertical axis,
724
+ * the latter is sometimes called `GDI ClearType'.
725
+ *
726
+ * `Normal' and `high' sampling describe the (virtual) resolution to
727
+ * access the rasterized outline after the hinting process. `Normal'
728
+ * means 1 sample per grid line (i.e., B/W). In the current Microsoft
729
+ * implementation, `high' means an extra virtual resolution of 16x16 (or
730
+ * 16x1) grid lines per pixel for bytecode instructions like `MIRP'.
731
+ * After hinting, these 16 grid lines are mapped to 6x5 (or 6x1) grid
732
+ * lines for color filtering if Color ClearType is activated.
733
+ *
734
+ * Note that `Gray ClearType' is essentially the same as v1.6's
735
+ * grayscale rendering. However, the GETINFO instruction handles it
736
+ * differently: v1.6 returns bit~12 (hinting for grayscale), while v2.1
737
+ * returns bits~13 (hinting for ClearType), 18 (symmetrical smoothing),
738
+ * and~19 (Gray ClearType). Also, this mode respects bits 2 and~3 for
739
+ * the version~1 gasp table exclusively (like Color ClearType), while
740
+ * v1.6 only respects the values of version~0 (bits 0 and~1).
741
+ *
742
+ * Keep in mind that the features of the above interpreter versions
743
+ * might not map exactly to FreeType features or behavior because it is
744
+ * a fundamentally different library with different internals.
745
+ *
746
+ */
747
+ #define TT_INTERPRETER_VERSION_35 35
748
+ #define TT_INTERPRETER_VERSION_38 38
749
+ #define TT_INTERPRETER_VERSION_40 40
750
+
751
+
752
+ /**************************************************************************
753
+ *
754
+ * @property:
755
+ * interpreter-version
756
+ *
757
+ * @description:
758
+ * Currently, three versions are available, two representing the
759
+ * bytecode interpreter with subpixel hinting support (old `Infinality'
760
+ * code and new stripped-down and higher performance `minimal' code) and
761
+ * one without, respectively. The default is subpixel support if
762
+ * TT_CONFIG_OPTION_SUBPIXEL_HINTING is defined, and no subpixel support
763
+ * otherwise (since it isn't available then).
764
+ *
765
+ * If subpixel hinting is on, many TrueType bytecode instructions behave
766
+ * differently compared to B/W or grayscale rendering (except if `native
767
+ * ClearType' is selected by the font). Microsoft's main idea is to
768
+ * render at a much increased horizontal resolution, then sampling down
769
+ * the created output to subpixel precision. However, many older fonts
770
+ * are not suited to this and must be specially taken care of by
771
+ * applying (hardcoded) tweaks in Microsoft's interpreter.
772
+ *
773
+ * Details on subpixel hinting and some of the necessary tweaks can be
774
+ * found in Greg Hitchcock's whitepaper at
775
+ * `https://www.microsoft.com/typography/cleartype/truetypecleartype.aspx'.
776
+ * Note that FreeType currently doesn't really `subpixel hint' (6x1, 6x2,
777
+ * or 6x5 supersampling) like discussed in the paper. Depending on the
778
+ * chosen interpreter, it simply ignores instructions on vertical stems
779
+ * to arrive at very similar results.
780
+ *
781
+ * The following example code demonstrates how to deactivate subpixel
782
+ * hinting (omitting the error handling).
783
+ *
784
+ * {
785
+ * FT_Library library;
786
+ * FT_Face face;
787
+ * FT_UInt interpreter_version = TT_INTERPRETER_VERSION_35;
788
+ *
789
+ *
790
+ * FT_Init_FreeType( &library );
791
+ *
792
+ * FT_Property_Set( library, "truetype",
793
+ * "interpreter-version",
794
+ * &interpreter_version );
795
+ * }
796
+ *
797
+ * @note:
798
+ * This property can be used with @FT_Property_Get also.
799
+ *
800
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
801
+ * variable (using values `35', `38', or `40').
802
+ *
803
+ * @since:
804
+ * 2.5
805
+ */
806
+
807
+
808
+ /**************************************************************************
809
+ *
810
+ * @property:
811
+ * glyph-to-script-map
812
+ *
813
+ * @description:
814
+ * *Experimental* *only*
815
+ *
816
+ * The auto-hinter provides various script modules to hint glyphs.
817
+ * Examples of supported scripts are Latin or CJK. Before a glyph is
818
+ * auto-hinted, the Unicode character map of the font gets examined, and
819
+ * the script is then determined based on Unicode character ranges, see
820
+ * below.
821
+ *
822
+ * OpenType fonts, however, often provide much more glyphs than
823
+ * character codes (small caps, superscripts, ligatures, swashes, etc.),
824
+ * to be controlled by so-called `features'. Handling OpenType features
825
+ * can be quite complicated and thus needs a separate library on top of
826
+ * FreeType.
827
+ *
828
+ * The mapping between glyph indices and scripts (in the auto-hinter
829
+ * sense, see the @FT_AUTOHINTER_SCRIPT_XXX values) is stored as an
830
+ * array with `num_glyphs' elements, as found in the font's @FT_Face
831
+ * structure. The `glyph-to-script-map' property returns a pointer to
832
+ * this array, which can be modified as needed. Note that the
833
+ * modification should happen before the first glyph gets processed by
834
+ * the auto-hinter so that the global analysis of the font shapes
835
+ * actually uses the modified mapping.
836
+ *
837
+ * The following example code demonstrates how to access it (omitting
838
+ * the error handling).
839
+ *
840
+ * {
841
+ * FT_Library library;
842
+ * FT_Face face;
843
+ * FT_Prop_GlyphToScriptMap prop;
844
+ *
845
+ *
846
+ * FT_Init_FreeType( &library );
847
+ * FT_New_Face( library, "foo.ttf", 0, &face );
848
+ *
849
+ * prop.face = face;
850
+ *
851
+ * FT_Property_Get( library, "autofitter",
852
+ * "glyph-to-script-map", &prop );
853
+ *
854
+ * // adjust `prop.map' as needed right here
855
+ *
856
+ * FT_Load_Glyph( face, ..., FT_LOAD_FORCE_AUTOHINT );
857
+ * }
858
+ *
859
+ * @since:
860
+ * 2.4.11
861
+ *
862
+ */
863
+
864
+
865
+ /**************************************************************************
866
+ *
867
+ * @enum:
868
+ * FT_AUTOHINTER_SCRIPT_XXX
869
+ *
870
+ * @description:
871
+ * *Experimental* *only*
872
+ *
873
+ * A list of constants used for the @glyph-to-script-map property to
874
+ * specify the script submodule the auto-hinter should use for hinting a
875
+ * particular glyph.
876
+ *
877
+ * @values:
878
+ * FT_AUTOHINTER_SCRIPT_NONE ::
879
+ * Don't auto-hint this glyph.
880
+ *
881
+ * FT_AUTOHINTER_SCRIPT_LATIN ::
882
+ * Apply the latin auto-hinter. For the auto-hinter, `latin' is a
883
+ * very broad term, including Cyrillic and Greek also since characters
884
+ * from those scripts share the same design constraints.
885
+ *
886
+ * By default, characters from the following Unicode ranges are
887
+ * assigned to this submodule.
888
+ *
889
+ * {
890
+ * U+0020 - U+007F // Basic Latin (no control characters)
891
+ * U+00A0 - U+00FF // Latin-1 Supplement (no control characters)
892
+ * U+0100 - U+017F // Latin Extended-A
893
+ * U+0180 - U+024F // Latin Extended-B
894
+ * U+0250 - U+02AF // IPA Extensions
895
+ * U+02B0 - U+02FF // Spacing Modifier Letters
896
+ * U+0300 - U+036F // Combining Diacritical Marks
897
+ * U+0370 - U+03FF // Greek and Coptic
898
+ * U+0400 - U+04FF // Cyrillic
899
+ * U+0500 - U+052F // Cyrillic Supplement
900
+ * U+1D00 - U+1D7F // Phonetic Extensions
901
+ * U+1D80 - U+1DBF // Phonetic Extensions Supplement
902
+ * U+1DC0 - U+1DFF // Combining Diacritical Marks Supplement
903
+ * U+1E00 - U+1EFF // Latin Extended Additional
904
+ * U+1F00 - U+1FFF // Greek Extended
905
+ * U+2000 - U+206F // General Punctuation
906
+ * U+2070 - U+209F // Superscripts and Subscripts
907
+ * U+20A0 - U+20CF // Currency Symbols
908
+ * U+2150 - U+218F // Number Forms
909
+ * U+2460 - U+24FF // Enclosed Alphanumerics
910
+ * U+2C60 - U+2C7F // Latin Extended-C
911
+ * U+2DE0 - U+2DFF // Cyrillic Extended-A
912
+ * U+2E00 - U+2E7F // Supplemental Punctuation
913
+ * U+A640 - U+A69F // Cyrillic Extended-B
914
+ * U+A720 - U+A7FF // Latin Extended-D
915
+ * U+FB00 - U+FB06 // Alphab. Present. Forms (Latin Ligatures)
916
+ * U+1D400 - U+1D7FF // Mathematical Alphanumeric Symbols
917
+ * U+1F100 - U+1F1FF // Enclosed Alphanumeric Supplement
918
+ * }
919
+ *
920
+ * FT_AUTOHINTER_SCRIPT_CJK ::
921
+ * Apply the CJK auto-hinter, covering Chinese, Japanese, Korean, old
922
+ * Vietnamese, and some other scripts.
923
+ *
924
+ * By default, characters from the following Unicode ranges are
925
+ * assigned to this submodule.
926
+ *
927
+ * {
928
+ * U+1100 - U+11FF // Hangul Jamo
929
+ * U+2E80 - U+2EFF // CJK Radicals Supplement
930
+ * U+2F00 - U+2FDF // Kangxi Radicals
931
+ * U+2FF0 - U+2FFF // Ideographic Description Characters
932
+ * U+3000 - U+303F // CJK Symbols and Punctuation
933
+ * U+3040 - U+309F // Hiragana
934
+ * U+30A0 - U+30FF // Katakana
935
+ * U+3100 - U+312F // Bopomofo
936
+ * U+3130 - U+318F // Hangul Compatibility Jamo
937
+ * U+3190 - U+319F // Kanbun
938
+ * U+31A0 - U+31BF // Bopomofo Extended
939
+ * U+31C0 - U+31EF // CJK Strokes
940
+ * U+31F0 - U+31FF // Katakana Phonetic Extensions
941
+ * U+3200 - U+32FF // Enclosed CJK Letters and Months
942
+ * U+3300 - U+33FF // CJK Compatibility
943
+ * U+3400 - U+4DBF // CJK Unified Ideographs Extension A
944
+ * U+4DC0 - U+4DFF // Yijing Hexagram Symbols
945
+ * U+4E00 - U+9FFF // CJK Unified Ideographs
946
+ * U+A960 - U+A97F // Hangul Jamo Extended-A
947
+ * U+AC00 - U+D7AF // Hangul Syllables
948
+ * U+D7B0 - U+D7FF // Hangul Jamo Extended-B
949
+ * U+F900 - U+FAFF // CJK Compatibility Ideographs
950
+ * U+FE10 - U+FE1F // Vertical forms
951
+ * U+FE30 - U+FE4F // CJK Compatibility Forms
952
+ * U+FF00 - U+FFEF // Halfwidth and Fullwidth Forms
953
+ * U+1B000 - U+1B0FF // Kana Supplement
954
+ * U+1D300 - U+1D35F // Tai Xuan Hing Symbols
955
+ * U+1F200 - U+1F2FF // Enclosed Ideographic Supplement
956
+ * U+20000 - U+2A6DF // CJK Unified Ideographs Extension B
957
+ * U+2A700 - U+2B73F // CJK Unified Ideographs Extension C
958
+ * U+2B740 - U+2B81F // CJK Unified Ideographs Extension D
959
+ * U+2F800 - U+2FA1F // CJK Compatibility Ideographs Supplement
960
+ * }
961
+ *
962
+ * FT_AUTOHINTER_SCRIPT_INDIC ::
963
+ * Apply the indic auto-hinter, covering all major scripts from the
964
+ * Indian sub-continent and some other related scripts like Thai, Lao,
965
+ * or Tibetan.
966
+ *
967
+ * By default, characters from the following Unicode ranges are
968
+ * assigned to this submodule.
969
+ *
970
+ * {
971
+ * U+0900 - U+0DFF // Indic Range
972
+ * U+0F00 - U+0FFF // Tibetan
973
+ * U+1900 - U+194F // Limbu
974
+ * U+1B80 - U+1BBF // Sundanese
975
+ * U+A800 - U+A82F // Syloti Nagri
976
+ * U+ABC0 - U+ABFF // Meetei Mayek
977
+ * U+11800 - U+118DF // Sharada
978
+ * }
979
+ *
980
+ * Note that currently Indic support is rudimentary only, missing blue
981
+ * zone support.
982
+ *
983
+ * @since:
984
+ * 2.4.11
985
+ *
986
+ */
987
+ #define FT_AUTOHINTER_SCRIPT_NONE 0
988
+ #define FT_AUTOHINTER_SCRIPT_LATIN 1
989
+ #define FT_AUTOHINTER_SCRIPT_CJK 2
990
+ #define FT_AUTOHINTER_SCRIPT_INDIC 3
991
+
992
+
993
+ /**************************************************************************
994
+ *
995
+ * @struct:
996
+ * FT_Prop_GlyphToScriptMap
997
+ *
998
+ * @description:
999
+ * *Experimental* *only*
1000
+ *
1001
+ * The data exchange structure for the @glyph-to-script-map property.
1002
+ *
1003
+ * @since:
1004
+ * 2.4.11
1005
+ *
1006
+ */
1007
+ typedef struct FT_Prop_GlyphToScriptMap_
1008
+ {
1009
+ FT_Face face;
1010
+ FT_UShort* map;
1011
+
1012
+ } FT_Prop_GlyphToScriptMap;
1013
+
1014
+
1015
+ /**************************************************************************
1016
+ *
1017
+ * @property:
1018
+ * fallback-script
1019
+ *
1020
+ * @description:
1021
+ * *Experimental* *only*
1022
+ *
1023
+ * If no auto-hinter script module can be assigned to a glyph, a
1024
+ * fallback script gets assigned to it (see also the
1025
+ * @glyph-to-script-map property). By default, this is
1026
+ * @FT_AUTOHINTER_SCRIPT_CJK. Using the `fallback-script' property,
1027
+ * this fallback value can be changed.
1028
+ *
1029
+ * {
1030
+ * FT_Library library;
1031
+ * FT_UInt fallback_script = FT_AUTOHINTER_SCRIPT_NONE;
1032
+ *
1033
+ *
1034
+ * FT_Init_FreeType( &library );
1035
+ *
1036
+ * FT_Property_Set( library, "autofitter",
1037
+ * "fallback-script", &fallback_script );
1038
+ * }
1039
+ *
1040
+ * @note:
1041
+ * This property can be used with @FT_Property_Get also.
1042
+ *
1043
+ * It's important to use the right timing for changing this value: The
1044
+ * creation of the glyph-to-script map that eventually uses the
1045
+ * fallback script value gets triggered either by setting or reading a
1046
+ * face-specific property like @glyph-to-script-map, or by auto-hinting
1047
+ * any glyph from that face. In particular, if you have already created
1048
+ * an @FT_Face structure but not loaded any glyph (using the
1049
+ * auto-hinter), a change of the fallback script will affect this face.
1050
+ *
1051
+ * @since:
1052
+ * 2.4.11
1053
+ *
1054
+ */
1055
+
1056
+
1057
+ /**************************************************************************
1058
+ *
1059
+ * @property:
1060
+ * default-script
1061
+ *
1062
+ * @description:
1063
+ * *Experimental* *only*
1064
+ *
1065
+ * If FreeType gets compiled with FT_CONFIG_OPTION_USE_HARFBUZZ to make
1066
+ * the HarfBuzz library access OpenType features for getting better
1067
+ * glyph coverages, this property sets the (auto-fitter) script to be
1068
+ * used for the default (OpenType) script data of a font's GSUB table.
1069
+ * Features for the default script are intended for all scripts not
1070
+ * explicitly handled in GSUB; an example is a `dlig' feature,
1071
+ * containing the combination of the characters `T', `E', and `L' to
1072
+ * form a `TEL' ligature.
1073
+ *
1074
+ * By default, this is @FT_AUTOHINTER_SCRIPT_LATIN. Using the
1075
+ * `default-script' property, this default value can be changed.
1076
+ *
1077
+ * {
1078
+ * FT_Library library;
1079
+ * FT_UInt default_script = FT_AUTOHINTER_SCRIPT_NONE;
1080
+ *
1081
+ *
1082
+ * FT_Init_FreeType( &library );
1083
+ *
1084
+ * FT_Property_Set( library, "autofitter",
1085
+ * "default-script", &default_script );
1086
+ * }
1087
+ *
1088
+ * @note:
1089
+ * This property can be used with @FT_Property_Get also.
1090
+ *
1091
+ * It's important to use the right timing for changing this value: The
1092
+ * creation of the glyph-to-script map that eventually uses the
1093
+ * default script value gets triggered either by setting or reading a
1094
+ * face-specific property like @glyph-to-script-map, or by auto-hinting
1095
+ * any glyph from that face. In particular, if you have already created
1096
+ * an @FT_Face structure but not loaded any glyph (using the
1097
+ * auto-hinter), a change of the default script will affect this face.
1098
+ *
1099
+ * @since:
1100
+ * 2.5.3
1101
+ *
1102
+ */
1103
+
1104
+
1105
+ /**************************************************************************
1106
+ *
1107
+ * @property:
1108
+ * increase-x-height
1109
+ *
1110
+ * @description:
1111
+ * For ppem values in the range 6~<= ppem <= `increase-x-height', round
1112
+ * up the font's x~height much more often than normally. If the value
1113
+ * is set to~0, which is the default, this feature is switched off. Use
1114
+ * this property to improve the legibility of small font sizes if
1115
+ * necessary.
1116
+ *
1117
+ * {
1118
+ * FT_Library library;
1119
+ * FT_Face face;
1120
+ * FT_Prop_IncreaseXHeight prop;
1121
+ *
1122
+ *
1123
+ * FT_Init_FreeType( &library );
1124
+ * FT_New_Face( library, "foo.ttf", 0, &face );
1125
+ * FT_Set_Char_Size( face, 10 * 64, 0, 72, 0 );
1126
+ *
1127
+ * prop.face = face;
1128
+ * prop.limit = 14;
1129
+ *
1130
+ * FT_Property_Set( library, "autofitter",
1131
+ * "increase-x-height", &prop );
1132
+ * }
1133
+ *
1134
+ * @note:
1135
+ * This property can be used with @FT_Property_Get also.
1136
+ *
1137
+ * Set this value right after calling @FT_Set_Char_Size, but before
1138
+ * loading any glyph (using the auto-hinter).
1139
+ *
1140
+ * @since:
1141
+ * 2.4.11
1142
+ *
1143
+ */
1144
+
1145
+
1146
+ /**************************************************************************
1147
+ *
1148
+ * @struct:
1149
+ * FT_Prop_IncreaseXHeight
1150
+ *
1151
+ * @description:
1152
+ * The data exchange structure for the @increase-x-height property.
1153
+ *
1154
+ */
1155
+ typedef struct FT_Prop_IncreaseXHeight_
1156
+ {
1157
+ FT_Face face;
1158
+ FT_UInt limit;
1159
+
1160
+ } FT_Prop_IncreaseXHeight;
1161
+
1162
+
1163
+ /**************************************************************************
1164
+ *
1165
+ * @property:
1166
+ * warping
1167
+ *
1168
+ * @description:
1169
+ * *Experimental* *only*
1170
+ *
1171
+ * If FreeType gets compiled with option AF_CONFIG_OPTION_USE_WARPER to
1172
+ * activate the warp hinting code in the auto-hinter, this property
1173
+ * switches warping on and off.
1174
+ *
1175
+ * Warping only works in `normal' auto-hinting mode replacing it.
1176
+ * The idea of the code is to slightly scale and shift a glyph along
1177
+ * the non-hinted dimension (which is usually the horizontal axis) so
1178
+ * that as much of its segments are aligned (more or less) to the grid.
1179
+ * To find out a glyph's optimal scaling and shifting value, various
1180
+ * parameter combinations are tried and scored.
1181
+ *
1182
+ * By default, warping is off. The example below shows how to switch on
1183
+ * warping (omitting the error handling).
1184
+ *
1185
+ * {
1186
+ * FT_Library library;
1187
+ * FT_Bool warping = 1;
1188
+ *
1189
+ *
1190
+ * FT_Init_FreeType( &library );
1191
+ *
1192
+ * FT_Property_Set( library, "autofitter",
1193
+ * "warping", &warping );
1194
+ * }
1195
+ *
1196
+ * @note:
1197
+ * This property can be used with @FT_Property_Get also.
1198
+ *
1199
+ * This property can be set via the `FREETYPE_PROPERTIES' environment
1200
+ * variable (using values 1 and 0 for `on' and `off', respectively).
1201
+ *
1202
+ * The warping code can also change advance widths. Have a look at the
1203
+ * `lsb_delta' and `rsb_delta' fields in the @FT_GlyphSlotRec structure
1204
+ * for details on improving inter-glyph distances while rendering.
1205
+ *
1206
+ * Since warping is a global property of the auto-hinter it is best to
1207
+ * change its value before rendering any face. Otherwise, you should
1208
+ * reload all faces that get auto-hinted in `normal' hinting mode.
1209
+ *
1210
+ * @since:
1211
+ * 2.6
1212
+ *
1213
+ */
1214
+
1215
+
1216
+ /* */
1217
+
1218
+
1219
+ FT_END_HEADER
1220
+
1221
+
1222
+ #endif /* FTDRIVER_H_ */
1223
+
1224
+
1225
+ /* END */