cairo 1.15.13-x86-mingw32 → 1.15.14-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/NEWS +24 -0
- data/README.rdoc +11 -40
- data/Rakefile +4 -2
- data/ext/cairo/rb_cairo.h +1 -1
- data/ext/cairo/rb_cairo_context.c +35 -3
- data/ext/cairo/rb_cairo_font_options.c +5 -6
- data/ext/cairo/rb_cairo_private.h +2 -2
- data/ext/cairo/rb_cairo_scaled_font.c +11 -2
- data/ext/cairo/rb_cairo_surface.c +89 -48
- data/lib/2.2/cairo.so +0 -0
- data/lib/2.3/cairo.so +0 -0
- data/lib/2.4/cairo.so +0 -0
- data/lib/2.5/cairo.so +0 -0
- data/test/{cairo-test-utils.rb → helper.rb} +4 -5
- data/test/run-test.rb +3 -10
- data/test/test_context.rb +6 -6
- data/test/test_font_extents.rb +1 -1
- data/test/test_font_face.rb +1 -1
- data/test/test_font_options.rb +1 -1
- data/test/test_image_surface.rb +2 -2
- data/test/test_pdf_surface.rb +1 -1
- data/test/test_quartz_image_surface.rb +1 -1
- data/test/test_raster_source_pattern.rb +13 -13
- data/test/test_recording_surface.rb +2 -2
- data/test/test_region.rb +1 -1
- data/test/test_scaled_font.rb +1 -1
- data/test/test_script_device.rb +1 -1
- data/test/test_script_surface.rb +1 -1
- data/test/test_surface.rb +5 -5
- data/test/test_svg_surface.rb +1 -1
- data/test/test_tee_surface.rb +2 -2
- data/test/test_text_cluster.rb +1 -1
- data/test/test_text_extents.rb +1 -1
- data/test/test_text_to_glyphs_data.rb +1 -1
- data/test/test_xml_device.rb +1 -1
- data/test/test_xml_surface.rb +2 -2
- data/vendor/local/bin/fc-cache.exe +0 -0
- data/vendor/local/bin/fc-cat.exe +0 -0
- data/vendor/local/bin/fc-conflist.exe +0 -0
- data/vendor/local/bin/fc-list.exe +0 -0
- data/vendor/local/bin/fc-match.exe +0 -0
- data/vendor/local/bin/fc-pattern.exe +0 -0
- data/vendor/local/bin/fc-query.exe +0 -0
- data/vendor/local/bin/fc-scan.exe +0 -0
- data/vendor/local/bin/fc-validate.exe +0 -0
- data/vendor/local/bin/libcairo-2.dll +0 -0
- data/vendor/local/bin/libcairo-gobject-2.dll +0 -0
- data/vendor/local/bin/libcairo-script-interpreter-2.dll +0 -0
- data/vendor/local/bin/libfontconfig-1.dll +0 -0
- data/vendor/local/bin/libfreetype-6.dll +0 -0
- data/vendor/local/bin/libpixman-1-0.dll +0 -0
- data/vendor/local/bin/libpng-config +1 -1
- data/vendor/local/bin/libpng16-16.dll +0 -0
- data/vendor/local/bin/libpng16-config +1 -1
- data/vendor/local/bin/libxml2-2.dll +0 -0
- data/vendor/local/bin/png-fix-itxt.exe +0 -0
- data/vendor/local/bin/pngfix.exe +0 -0
- data/vendor/local/bin/xmlcatalog.exe +0 -0
- data/vendor/local/bin/xmllint.exe +0 -0
- data/vendor/local/bin/zlib1211.dll +0 -0
- data/vendor/local/include/freetype2/freetype/config/ftconfig.h +82 -3
- data/vendor/local/include/freetype2/freetype/config/ftheader.h +43 -85
- data/vendor/local/include/freetype2/freetype/config/ftoption.h +43 -56
- data/vendor/local/include/freetype2/freetype/config/ftstdlib.h +1 -1
- data/vendor/local/include/freetype2/freetype/freetype.h +185 -85
- data/vendor/local/include/freetype2/freetype/ftadvanc.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftbbox.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftbdf.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftbitmap.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftbzip2.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftcache.h +1 -16
- data/vendor/local/include/freetype2/freetype/ftchapters.h +3 -0
- data/vendor/local/include/freetype2/freetype/ftcid.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftdriver.h +1225 -0
- data/vendor/local/include/freetype2/freetype/fterrdef.h +1 -1
- data/vendor/local/include/freetype2/freetype/fterrors.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftfntfmt.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftgasp.h +6 -1
- data/vendor/local/include/freetype2/freetype/ftglyph.h +3 -3
- data/vendor/local/include/freetype2/freetype/ftgxval.h +5 -5
- data/vendor/local/include/freetype2/freetype/ftgzip.h +4 -1
- data/vendor/local/include/freetype2/freetype/ftimage.h +18 -18
- data/vendor/local/include/freetype2/freetype/ftincrem.h +2 -13
- data/vendor/local/include/freetype2/freetype/ftlcdfil.h +5 -18
- data/vendor/local/include/freetype2/freetype/ftlist.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftlzw.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftmac.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftmm.h +99 -11
- data/vendor/local/include/freetype2/freetype/ftmodapi.h +12 -11
- data/vendor/local/include/freetype2/freetype/ftmoderr.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftotval.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftoutln.h +4 -7
- data/vendor/local/include/freetype2/freetype/ftparams.h +205 -0
- data/vendor/local/include/freetype2/freetype/ftpfr.h +4 -4
- data/vendor/local/include/freetype2/freetype/ftrender.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftsizes.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftsnames.h +8 -42
- data/vendor/local/include/freetype2/freetype/ftstroke.h +6 -6
- data/vendor/local/include/freetype2/freetype/ftsynth.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftsystem.h +1 -1
- data/vendor/local/include/freetype2/freetype/fttrigon.h +1 -1
- data/vendor/local/include/freetype2/freetype/fttypes.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftwinfnt.h +2 -2
- data/vendor/local/include/freetype2/freetype/t1tables.h +10 -1
- data/vendor/local/include/freetype2/freetype/ttnameid.h +2 -2
- data/vendor/local/include/freetype2/freetype/tttables.h +1 -1
- data/vendor/local/include/freetype2/freetype/tttags.h +1 -1
- data/vendor/local/include/freetype2/ft2build.h +1 -1
- data/vendor/local/include/libpng16/png.h +40 -40
- data/vendor/local/include/libpng16/pngconf.h +15 -14
- data/vendor/local/include/libpng16/pnglibconf.h +1 -1
- data/vendor/local/include/png.h +40 -40
- data/vendor/local/include/pngconf.h +15 -14
- data/vendor/local/include/pnglibconf.h +1 -1
- data/vendor/local/lib/libcairo-gobject.dll.a +0 -0
- data/vendor/local/lib/libcairo-gobject.la +1 -1
- data/vendor/local/lib/libcairo-script-interpreter.a +0 -0
- data/vendor/local/lib/libcairo-script-interpreter.dll.a +0 -0
- data/vendor/local/lib/libcairo.a +0 -0
- data/vendor/local/lib/libcairo.dll.a +0 -0
- data/vendor/local/lib/libfontconfig.dll.a +0 -0
- data/vendor/local/lib/libfreetype.a +0 -0
- data/vendor/local/lib/libfreetype.dll.a +0 -0
- data/vendor/local/lib/libfreetype.la +3 -3
- data/vendor/local/lib/libpixman-1.dll.a +0 -0
- data/vendor/local/lib/libpng.a +0 -0
- data/vendor/local/lib/libpng.dll.a +0 -0
- data/vendor/local/lib/libpng.la +2 -2
- data/vendor/local/lib/libpng16.a +0 -0
- data/vendor/local/lib/libpng16.dll.a +0 -0
- data/vendor/local/lib/libpng16.la +2 -2
- data/vendor/local/lib/libxml2.dll.a +0 -0
- data/vendor/local/lib/libz.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/freetype2.pc +2 -2
- data/vendor/local/lib/pkgconfig/libpng.pc +1 -1
- data/vendor/local/lib/pkgconfig/libpng16.pc +1 -1
- data/vendor/local/share/aclocal/freetype2.m4 +1 -1
- data/vendor/local/share/license/freetype/README +9 -9
- data/vendor/local/share/license/freetype/README.git +1 -1
- data/vendor/local/share/license/libpng/README +2 -2
- data/vendor/local/share/man/man3/libpng.3 +50 -54
- data/vendor/local/share/man/man3/libpngpf.3 +8 -4
- metadata +9 -14
- data/vendor/local/bin/freetype-config +0 -211
- data/vendor/local/include/freetype2/freetype/ftautoh.h +0 -533
- data/vendor/local/include/freetype2/freetype/ftcffdrv.h +0 -321
- data/vendor/local/include/freetype2/freetype/ftpcfdrv.h +0 -105
- data/vendor/local/include/freetype2/freetype/ftttdrv.h +0 -328
- data/vendor/local/include/freetype2/freetype/ttunpat.h +0 -63
- data/vendor/local/share/man/man1/freetype-config.1 +0 -146
@@ -5,7 +5,7 @@
|
|
5
5
|
/* ANSI-specific library and header configuration file (specification */
|
6
6
|
/* only). */
|
7
7
|
/* */
|
8
|
-
/* Copyright 2002-
|
8
|
+
/* Copyright 2002-2018 by */
|
9
9
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
10
10
|
/* */
|
11
11
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType high-level API and common types (specification only). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 1996-
|
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, */
|
@@ -138,6 +138,7 @@ FT_BEGIN_HEADER
|
|
138
138
|
/* FT_FACE_FLAG_TRICKY */
|
139
139
|
/* FT_FACE_FLAG_KERNING */
|
140
140
|
/* FT_FACE_FLAG_MULTIPLE_MASTERS */
|
141
|
+
/* FT_FACE_FLAG_VARIATION */
|
141
142
|
/* FT_FACE_FLAG_GLYPH_NAMES */
|
142
143
|
/* FT_FACE_FLAG_EXTERNAL_STREAM */
|
143
144
|
/* FT_FACE_FLAG_HINTER */
|
@@ -147,14 +148,16 @@ FT_BEGIN_HEADER
|
|
147
148
|
/* FT_HAS_KERNING */
|
148
149
|
/* FT_HAS_FIXED_SIZES */
|
149
150
|
/* FT_HAS_GLYPH_NAMES */
|
150
|
-
/* FT_HAS_MULTIPLE_MASTERS */
|
151
151
|
/* FT_HAS_COLOR */
|
152
|
+
/* FT_HAS_MULTIPLE_MASTERS */
|
152
153
|
/* */
|
153
154
|
/* FT_IS_SFNT */
|
154
155
|
/* FT_IS_SCALABLE */
|
155
156
|
/* FT_IS_FIXED_WIDTH */
|
156
157
|
/* FT_IS_CID_KEYED */
|
157
158
|
/* FT_IS_TRICKY */
|
159
|
+
/* FT_IS_NAMED_INSTANCE */
|
160
|
+
/* FT_IS_VARIATION */
|
158
161
|
/* */
|
159
162
|
/* FT_STYLE_FLAG_BOLD */
|
160
163
|
/* FT_STYLE_FLAG_ITALIC */
|
@@ -648,7 +651,7 @@ FT_BEGIN_HEADER
|
|
648
651
|
/* FT_ENCODING_MS_SYMBOL :: */
|
649
652
|
/* Microsoft Symbol encoding, used to encode mathematical symbols */
|
650
653
|
/* and wingdings. For more information, see */
|
651
|
-
/* `
|
654
|
+
/* `https://www.microsoft.com/typography/otspec/recom.htm', */
|
652
655
|
/* `http://www.kostis.net/charsets/symbol.htm', and */
|
653
656
|
/* `http://www.kostis.net/charsets/wingding.htm'. */
|
654
657
|
/* */
|
@@ -657,7 +660,7 @@ FT_BEGIN_HEADER
|
|
657
660
|
/* */
|
658
661
|
/* FT_ENCODING_SJIS :: */
|
659
662
|
/* Shift JIS encoding for Japanese. More info at */
|
660
|
-
/* `
|
663
|
+
/* `https://en.wikipedia.org/wiki/Shift_JIS'. See note on */
|
661
664
|
/* multi-byte encodings below. */
|
662
665
|
/* */
|
663
666
|
/* FT_ENCODING_PRC :: */
|
@@ -673,7 +676,7 @@ FT_BEGIN_HEADER
|
|
673
676
|
/* Corresponds to the Korean encoding system known as Extended */
|
674
677
|
/* Wansung (MS Windows code page 949). */
|
675
678
|
/* For more information see */
|
676
|
-
/* `
|
679
|
+
/* `https://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WindowsBestFit/bestfit949.txt'. */
|
677
680
|
/* */
|
678
681
|
/* FT_ENCODING_JOHAB :: */
|
679
682
|
/* The Korean standard character set (KS~C 5601-1992), which */
|
@@ -721,11 +724,12 @@ FT_BEGIN_HEADER
|
|
721
724
|
/* Same as FT_ENCODING_JOHAB. Deprecated. */
|
722
725
|
/* */
|
723
726
|
/* <Note> */
|
724
|
-
/* By default, FreeType
|
725
|
-
/*
|
726
|
-
/*
|
727
|
-
/*
|
728
|
-
/*
|
727
|
+
/* By default, FreeType enables a Unicode charmap and tags it with */
|
728
|
+
/* FT_ENCODING_UNICODE when it is either provided or can be generated */
|
729
|
+
/* from PostScript glyph name dictionaries in the font file. */
|
730
|
+
/* All other encodings are considered legacy and tagged only if */
|
731
|
+
/* explicitly defined in the font file. Otherwise, FT_ENCODING_NONE */
|
732
|
+
/* is used. */
|
729
733
|
/* */
|
730
734
|
/* FT_ENCODING_NONE is set by the BDF and PCF drivers if the charmap */
|
731
735
|
/* is neither Unicode nor ISO-8859-1 (otherwise it is set to */
|
@@ -749,7 +753,7 @@ FT_BEGIN_HEADER
|
|
749
753
|
/* @FT_Get_CMap_Language_ID to query the Mac language ID that may */
|
750
754
|
/* be needed to be able to distinguish Apple encoding variants. See */
|
751
755
|
/* */
|
752
|
-
/*
|
756
|
+
/* https://www.unicode.org/Public/MAPPINGS/VENDORS/APPLE/Readme.txt */
|
753
757
|
/* */
|
754
758
|
/* to get an idea how to do that. Basically, if the language ID */
|
755
759
|
/* is~0, don't use it, otherwise subtract 1 from the language ID. */
|
@@ -888,34 +892,41 @@ FT_BEGIN_HEADER
|
|
888
892
|
/* are set to~0 if there is only one face in */
|
889
893
|
/* the font file. */
|
890
894
|
/* */
|
891
|
-
/* Bits 16-30 are relevant to GX
|
892
|
-
/* variation fonts only, holding
|
893
|
-
/* instance index for the current
|
894
|
-
/* (starting with value~1; value~0
|
895
|
-
/* font access without a named
|
896
|
-
/* non-variation fonts, bits
|
897
|
-
/* ignored. If we have the third
|
898
|
-
/* instance of face~4, say, `face_index'
|
899
|
-
/* set to 0x00030004.
|
895
|
+
/* [Since 2.6.1] Bits 16-30 are relevant to GX */
|
896
|
+
/* and OpenType variation fonts only, holding */
|
897
|
+
/* the named instance index for the current */
|
898
|
+
/* face index (starting with value~1; value~0 */
|
899
|
+
/* indicates font access without a named */
|
900
|
+
/* instance). For non-variation fonts, bits */
|
901
|
+
/* 16-30 are ignored. If we have the third */
|
902
|
+
/* named instance of face~4, say, `face_index' */
|
903
|
+
/* is set to 0x00030004. */
|
900
904
|
/* */
|
901
905
|
/* Bit 31 is always zero (this is, */
|
902
906
|
/* `face_index' is always a positive value). */
|
903
907
|
/* */
|
908
|
+
/* [Since 2.9] Changing the design coordinates */
|
909
|
+
/* with @FT_Set_Var_Design_Coordinates or */
|
910
|
+
/* @FT_Set_Var_Blend_Coordinates does not */
|
911
|
+
/* influence the named instance index value */
|
912
|
+
/* (only @FT_Set_Named_Instance does that). */
|
913
|
+
/* */
|
904
914
|
/* face_flags :: A set of bit flags that give important */
|
905
915
|
/* information about the face; see */
|
906
916
|
/* @FT_FACE_FLAG_XXX for the details. */
|
907
917
|
/* */
|
908
918
|
/* style_flags :: The lower 16~bits contain a set of bit */
|
909
919
|
/* flags indicating the style of the face; see */
|
910
|
-
/* @FT_STYLE_FLAG_XXX for the details.
|
911
|
-
/*
|
912
|
-
/*
|
913
|
-
/*
|
914
|
-
/*
|
915
|
-
/*
|
916
|
-
/*
|
917
|
-
/*
|
918
|
-
/*
|
920
|
+
/* @FT_STYLE_FLAG_XXX for the details. */
|
921
|
+
/* */
|
922
|
+
/* [Since 2.6.1] Bits 16-30 hold the number */
|
923
|
+
/* of named instances available for the */
|
924
|
+
/* current face if we have a GX or OpenType */
|
925
|
+
/* variation (sub)font. Bit 31 is always zero */
|
926
|
+
/* (this is, `style_flags' is always a */
|
927
|
+
/* positive value). Note that a variation */
|
928
|
+
/* font has always at least one named */
|
929
|
+
/* instance, namely the default instance. */
|
919
930
|
/* */
|
920
931
|
/* num_glyphs :: The number of glyphs in the face. If the */
|
921
932
|
/* face is scalable and has sbits (see */
|
@@ -1052,6 +1063,9 @@ FT_BEGIN_HEADER
|
|
1052
1063
|
/* `descender', `height', `underline_position', and */
|
1053
1064
|
/* `underline_thickness'. */
|
1054
1065
|
/* */
|
1066
|
+
/* Especially for TrueType fonts see also the documentation for */
|
1067
|
+
/* @FT_Size_Metrics. */
|
1068
|
+
/* */
|
1055
1069
|
typedef struct FT_FaceRec_
|
1056
1070
|
{
|
1057
1071
|
FT_Long num_faces;
|
@@ -1162,7 +1176,7 @@ FT_BEGIN_HEADER
|
|
1162
1176
|
/* interpolating between them. Supported formats are Adobe MM, */
|
1163
1177
|
/* TrueType GX, and OpenType variation fonts. */
|
1164
1178
|
/* */
|
1165
|
-
/* See
|
1179
|
+
/* See section @multiple_masters for API details. */
|
1166
1180
|
/* */
|
1167
1181
|
/* FT_FACE_FLAG_GLYPH_NAMES :: */
|
1168
1182
|
/* The face contains glyph names, which can be retrieved using */
|
@@ -1212,8 +1226,15 @@ FT_BEGIN_HEADER
|
|
1212
1226
|
/* tricky fonts; they are hard-coded in file `ttobjs.c'. */
|
1213
1227
|
/* */
|
1214
1228
|
/* FT_FACE_FLAG_COLOR :: */
|
1215
|
-
/* The face has color glyph tables. To access color
|
1216
|
-
/* @FT_LOAD_COLOR.
|
1229
|
+
/* [Since 2.5.1] The face has color glyph tables. To access color */
|
1230
|
+
/* glyphs use @FT_LOAD_COLOR. */
|
1231
|
+
/* */
|
1232
|
+
/* FT_FACE_FLAG_VARIATION :: */
|
1233
|
+
/* [Since 2.9] Set if the current face (or named instance) has been */
|
1234
|
+
/* altered with @FT_Set_MM_Design_Coordinates, */
|
1235
|
+
/* @FT_Set_Var_Design_Coordinates, or */
|
1236
|
+
/* @FT_Set_Var_Blend_Coordinates. This flag is unset by a call to */
|
1237
|
+
/* @FT_Set_Named_Instance. */
|
1217
1238
|
/* */
|
1218
1239
|
#define FT_FACE_FLAG_SCALABLE ( 1L << 0 )
|
1219
1240
|
#define FT_FACE_FLAG_FIXED_SIZES ( 1L << 1 )
|
@@ -1230,6 +1251,7 @@ FT_BEGIN_HEADER
|
|
1230
1251
|
#define FT_FACE_FLAG_CID_KEYED ( 1L << 12 )
|
1231
1252
|
#define FT_FACE_FLAG_TRICKY ( 1L << 13 )
|
1232
1253
|
#define FT_FACE_FLAG_COLOR ( 1L << 14 )
|
1254
|
+
#define FT_FACE_FLAG_VARIATION ( 1L << 15 )
|
1233
1255
|
|
1234
1256
|
|
1235
1257
|
/*************************************************************************
|
@@ -1391,11 +1413,37 @@ FT_BEGIN_HEADER
|
|
1391
1413
|
* A macro that returns true whenever a face object is a named instance
|
1392
1414
|
* of a GX or OpenType variation font.
|
1393
1415
|
*
|
1416
|
+
* [Since 2.9] Changing the design coordinates with
|
1417
|
+
* @FT_Set_Var_Design_Coordinates or @FT_Set_Var_Blend_Coordinates does
|
1418
|
+
* not influence the return value of this macro (only
|
1419
|
+
* @FT_Set_Named_Instance does that).
|
1420
|
+
*
|
1421
|
+
* @since:
|
1422
|
+
* 2.7
|
1423
|
+
*
|
1394
1424
|
*/
|
1395
1425
|
#define FT_IS_NAMED_INSTANCE( face ) \
|
1396
1426
|
( (face)->face_index & 0x7FFF0000L )
|
1397
1427
|
|
1398
1428
|
|
1429
|
+
/*************************************************************************
|
1430
|
+
*
|
1431
|
+
* @macro:
|
1432
|
+
* FT_IS_VARIATION( face )
|
1433
|
+
*
|
1434
|
+
* @description:
|
1435
|
+
* A macro that returns true whenever a face object has been altered
|
1436
|
+
* by @FT_Set_MM_Design_Coordinates, @FT_Set_Var_Design_Coordinates, or
|
1437
|
+
* @FT_Set_Var_Blend_Coordinates.
|
1438
|
+
*
|
1439
|
+
* @since:
|
1440
|
+
* 2.9
|
1441
|
+
*
|
1442
|
+
*/
|
1443
|
+
#define FT_IS_VARIATION( face ) \
|
1444
|
+
( (face)->face_flags & FT_FACE_FLAG_VARIATION )
|
1445
|
+
|
1446
|
+
|
1399
1447
|
/*************************************************************************
|
1400
1448
|
*
|
1401
1449
|
* @macro:
|
@@ -1437,6 +1485,9 @@ FT_BEGIN_HEADER
|
|
1437
1485
|
* A macro that returns true whenever a face object contains
|
1438
1486
|
* tables for color glyphs.
|
1439
1487
|
*
|
1488
|
+
* @since:
|
1489
|
+
* 2.5.1
|
1490
|
+
*
|
1440
1491
|
*/
|
1441
1492
|
#define FT_HAS_COLOR( face ) \
|
1442
1493
|
( (face)->face_flags & FT_FACE_FLAG_COLOR )
|
@@ -1534,7 +1585,7 @@ FT_BEGIN_HEADER
|
|
1534
1585
|
/* to the following. */
|
1535
1586
|
/* */
|
1536
1587
|
/* { */
|
1537
|
-
/* scaled_ascender = FT_MulFix( face->
|
1588
|
+
/* scaled_ascender = FT_MulFix( face->ascender, */
|
1538
1589
|
/* size_metrics->y_scale ); */
|
1539
1590
|
/* } */
|
1540
1591
|
/* */
|
@@ -1548,6 +1599,43 @@ FT_BEGIN_HEADER
|
|
1548
1599
|
/* */
|
1549
1600
|
/* The `FT_Size_Metrics' structure is valid for bitmap fonts also. */
|
1550
1601
|
/* */
|
1602
|
+
/* */
|
1603
|
+
/* *TrueType* *fonts* *with* *native* *bytecode* *hinting* */
|
1604
|
+
/* */
|
1605
|
+
/* All applications that handle TrueType fonts with native hinting */
|
1606
|
+
/* must be aware that TTFs expect different rounding of vertical font */
|
1607
|
+
/* dimensions. The application has to cater for this, especially if */
|
1608
|
+
/* it wants to rely on a TTF's vertical data (for example, to */
|
1609
|
+
/* properly align box characters vertically). */
|
1610
|
+
/* */
|
1611
|
+
/* Only the application knows _in_ _advance_ that it is going to use */
|
1612
|
+
/* native hinting for TTFs! FreeType, on the other hand, selects the */
|
1613
|
+
/* hinting mode not at the time of creating an @FT_Size object but */
|
1614
|
+
/* much later, namely while calling @FT_Load_Glyph. */
|
1615
|
+
/* */
|
1616
|
+
/* Here is some pseudo code that illustrates a possible solution. */
|
1617
|
+
/* */
|
1618
|
+
/* { */
|
1619
|
+
/* font_format = FT_Get_Font_Format( face ); */
|
1620
|
+
/* */
|
1621
|
+
/* if ( !strcmp( font_format, "TrueType" ) && */
|
1622
|
+
/* do_native_bytecode_hinting ) */
|
1623
|
+
/* { */
|
1624
|
+
/* ascender = ROUND( FT_MulFix( face->ascender, */
|
1625
|
+
/* size_metrics->y_scale ) ); */
|
1626
|
+
/* descender = ROUND( FT_MulFix( face->descender, */
|
1627
|
+
/* size_metrics->y_scale ) ); */
|
1628
|
+
/* } */
|
1629
|
+
/* else */
|
1630
|
+
/* { */
|
1631
|
+
/* ascender = size_metrics->ascender; */
|
1632
|
+
/* descender = size_metrics->descender; */
|
1633
|
+
/* } */
|
1634
|
+
/* */
|
1635
|
+
/* height = size_metrics->height; */
|
1636
|
+
/* max_advance = size_metrics->max_advance; */
|
1637
|
+
/* } */
|
1638
|
+
/* */
|
1551
1639
|
typedef struct FT_Size_Metrics_
|
1552
1640
|
{
|
1553
1641
|
FT_UShort x_ppem; /* horizontal pixels per EM */
|
@@ -1689,17 +1777,13 @@ FT_BEGIN_HEADER
|
|
1689
1777
|
/* @FT_GLYPH_FORMAT_COMPOSITE, but other values */
|
1690
1778
|
/* are possible. */
|
1691
1779
|
/* */
|
1692
|
-
/* bitmap :: This field is used as a bitmap descriptor
|
1693
|
-
/*
|
1694
|
-
/*
|
1695
|
-
/*
|
1696
|
-
/* change between calls of @FT_Load_Glyph and a */
|
1697
|
-
/* few other functions. */
|
1780
|
+
/* bitmap :: This field is used as a bitmap descriptor. */
|
1781
|
+
/* Note that the address and content of the */
|
1782
|
+
/* bitmap buffer can change between calls of */
|
1783
|
+
/* @FT_Load_Glyph and a few other functions. */
|
1698
1784
|
/* */
|
1699
1785
|
/* bitmap_left :: The bitmap's left bearing expressed in */
|
1700
|
-
/* integer pixels.
|
1701
|
-
/* @FT_GLYPH_FORMAT_BITMAP, this is, if the */
|
1702
|
-
/* glyph slot contains a bitmap. */
|
1786
|
+
/* integer pixels. */
|
1703
1787
|
/* */
|
1704
1788
|
/* bitmap_top :: The bitmap's top bearing expressed in integer */
|
1705
1789
|
/* pixels. This is the distance from the */
|
@@ -1746,7 +1830,9 @@ FT_BEGIN_HEADER
|
|
1746
1830
|
/* If @FT_Load_Glyph is called with default flags (see */
|
1747
1831
|
/* @FT_LOAD_DEFAULT) the glyph image is loaded in the glyph slot in */
|
1748
1832
|
/* its native format (e.g., an outline glyph for TrueType and Type~1 */
|
1749
|
-
/* formats).
|
1833
|
+
/* formats). [Since 2.9] The prospective bitmap metrics are */
|
1834
|
+
/* calculated according to @FT_LOAD_TARGET_XXX and other flags even */
|
1835
|
+
/* for the outline glyph, even if @FT_LOAD_RENDER is not set. */
|
1750
1836
|
/* */
|
1751
1837
|
/* This image can later be converted into a bitmap by calling */
|
1752
1838
|
/* @FT_Render_Glyph. This function searches the current renderer for */
|
@@ -1895,8 +1981,8 @@ FT_BEGIN_HEADER
|
|
1895
1981
|
/* */
|
1896
1982
|
/* If compilation option FT_CONFIG_OPTION_ENVIRONMENT_PROPERTIES is */
|
1897
1983
|
/* set, this function reads the `FREETYPE_PROPERTIES' environment */
|
1898
|
-
/* variable to control driver properties. See
|
1899
|
-
/*
|
1984
|
+
/* variable to control driver properties. See section @properties */
|
1985
|
+
/* for more. */
|
1900
1986
|
/* */
|
1901
1987
|
FT_EXPORT( FT_Error )
|
1902
1988
|
FT_Init_FreeType( FT_Library *alibrary );
|
@@ -1977,8 +2063,8 @@ FT_BEGIN_HEADER
|
|
1977
2063
|
/* data :: A pointer to the parameter data. */
|
1978
2064
|
/* */
|
1979
2065
|
/* <Note> */
|
1980
|
-
/* The ID and function of parameters are driver-specific. See
|
1981
|
-
/*
|
2066
|
+
/* The ID and function of parameters are driver-specific. See */
|
2067
|
+
/* section @parameter_tags for more information. */
|
1982
2068
|
/* */
|
1983
2069
|
typedef struct FT_Parameter_
|
1984
2070
|
{
|
@@ -2155,14 +2241,14 @@ FT_BEGIN_HEADER
|
|
2155
2241
|
/* with value~0). Set it to~0 if there is only one */
|
2156
2242
|
/* face in the font file. */
|
2157
2243
|
/* */
|
2158
|
-
/* Bits 16-30 are relevant to GX and
|
2159
|
-
/* fonts only, specifying the named
|
2160
|
-
/* the current face index (starting
|
2161
|
-
/* value~0 makes FreeType ignore named
|
2162
|
-
/* non-variation fonts, bits 16-30 are
|
2163
|
-
/* Assuming that you want to access the third
|
2164
|
-
/* instance in face~4, `face_index' should be set
|
2165
|
-
/* 0x00030004. If you want to access face~4 without
|
2244
|
+
/* [Since 2.6.1] Bits 16-30 are relevant to GX and */
|
2245
|
+
/* OpenType variation fonts only, specifying the named */
|
2246
|
+
/* instance index for the current face index (starting */
|
2247
|
+
/* with value~1; value~0 makes FreeType ignore named */
|
2248
|
+
/* instances). For non-variation fonts, bits 16-30 are */
|
2249
|
+
/* ignored. Assuming that you want to access the third */
|
2250
|
+
/* named instance in face~4, `face_index' should be set */
|
2251
|
+
/* to 0x00030004. If you want to access face~4 without */
|
2166
2252
|
/* variation handling, simply set `face_index' to */
|
2167
2253
|
/* value~4. */
|
2168
2254
|
/* */
|
@@ -2748,6 +2834,10 @@ FT_BEGIN_HEADER
|
|
2748
2834
|
/* since its glyph indices are not listed in any of the font's */
|
2749
2835
|
/* charmaps. */
|
2750
2836
|
/* */
|
2837
|
+
/* If no active cmap is set up (i.e., `face->charmap' is zero), the */
|
2838
|
+
/* call to @FT_Get_Char_Index is omitted, and the function behaves */
|
2839
|
+
/* identically to @FT_Load_Glyph. */
|
2840
|
+
/* */
|
2751
2841
|
FT_EXPORT( FT_Error )
|
2752
2842
|
FT_Load_Char( FT_Face face,
|
2753
2843
|
FT_ULong char_code,
|
@@ -2869,26 +2959,26 @@ FT_BEGIN_HEADER
|
|
2869
2959
|
* Disable the auto-hinter. See also the note below.
|
2870
2960
|
*
|
2871
2961
|
* FT_LOAD_COLOR ::
|
2872
|
-
* Load embedded color bitmap images. The resulting color
|
2873
|
-
* if available, will have the @FT_PIXEL_MODE_BGRA format.
|
2874
|
-
* flag is not set and color bitmaps are found, they are
|
2875
|
-
* to 256-level gray bitmaps transparently, using the
|
2962
|
+
* [Since 2.5] Load embedded color bitmap images. The resulting color
|
2963
|
+
* bitmaps, if available, will have the @FT_PIXEL_MODE_BGRA format.
|
2964
|
+
* If the flag is not set and color bitmaps are found, they are
|
2965
|
+
* converted to 256-level gray bitmaps transparently, using the
|
2876
2966
|
* @FT_PIXEL_MODE_GRAY format.
|
2877
2967
|
*
|
2878
2968
|
* FT_LOAD_COMPUTE_METRICS ::
|
2879
|
-
* Compute glyph metrics from the glyph data, without
|
2880
|
-
* bundled metrics tables (for example, the `hdmx' table in
|
2881
|
-
* fonts). This flag is mainly used by font validating or
|
2882
|
-
* editing applications, which need to ignore, verify, or edit
|
2883
|
-
* tables.
|
2969
|
+
* [Since 2.6.1] Compute glyph metrics from the glyph data, without
|
2970
|
+
* the use of bundled metrics tables (for example, the `hdmx' table in
|
2971
|
+
* TrueType fonts). This flag is mainly used by font validating or
|
2972
|
+
* font editing applications, which need to ignore, verify, or edit
|
2973
|
+
* those tables.
|
2884
2974
|
*
|
2885
2975
|
* Currently, this flag is only implemented for TrueType fonts.
|
2886
2976
|
*
|
2887
2977
|
* FT_LOAD_BITMAP_METRICS_ONLY ::
|
2888
|
-
* Request loading of the metrics and bitmap image
|
2889
|
-
* (possibly embedded) bitmap glyph without
|
2890
|
-
* the bitmap image data itself. No effect if
|
2891
|
-
* not a bitmap image.
|
2978
|
+
* [Since 2.7.1] Request loading of the metrics and bitmap image
|
2979
|
+
* information of a (possibly embedded) bitmap glyph without
|
2980
|
+
* allocating or copying the bitmap image data itself. No effect if
|
2981
|
+
* the target glyph is not a bitmap image.
|
2892
2982
|
*
|
2893
2983
|
* This flag unsets @FT_LOAD_RENDER.
|
2894
2984
|
*
|
@@ -2980,7 +3070,7 @@ FT_BEGIN_HEADER
|
|
2980
3070
|
*
|
2981
3071
|
* Advance widths are rounded to integer values; however, using the
|
2982
3072
|
* `lsb_delta' and `rsb_delta' fields of @FT_GlyphSlotRec, it is
|
2983
|
-
* possible to get fractional advance widths for
|
3073
|
+
* possible to get fractional advance widths for subpixel positioning
|
2984
3074
|
* (which is recommended to use).
|
2985
3075
|
*
|
2986
3076
|
* If configuration option AF_CONFIG_OPTION_TT_SIZE_METRICS is active,
|
@@ -3119,13 +3209,13 @@ FT_BEGIN_HEADER
|
|
3119
3209
|
/* opacity). */
|
3120
3210
|
/* */
|
3121
3211
|
/* FT_RENDER_MODE_LCD :: */
|
3122
|
-
/* This mode corresponds to horizontal RGB and BGR
|
3212
|
+
/* This mode corresponds to horizontal RGB and BGR subpixel */
|
3123
3213
|
/* displays like LCD screens. It produces 8-bit bitmaps that are */
|
3124
3214
|
/* 3~times the width of the original glyph outline in pixels, and */
|
3125
3215
|
/* which use the @FT_PIXEL_MODE_LCD mode. */
|
3126
3216
|
/* */
|
3127
3217
|
/* FT_RENDER_MODE_LCD_V :: */
|
3128
|
-
/* This mode corresponds to vertical RGB and BGR
|
3218
|
+
/* This mode corresponds to vertical RGB and BGR subpixel displays */
|
3129
3219
|
/* (like PDA screens, rotated LCD displays, etc.). It produces */
|
3130
3220
|
/* 8-bit bitmaps that are 3~times the height of the original */
|
3131
3221
|
/* glyph outline in pixels and use the @FT_PIXEL_MODE_LCD_V mode. */
|
@@ -3471,7 +3561,14 @@ FT_BEGIN_HEADER
|
|
3471
3561
|
/* retrieve it. FreeType follows Adobe TechNote #5902, `Generating */
|
3472
3562
|
/* PostScript Names for Fonts Using OpenType Font Variations'. */
|
3473
3563
|
/* */
|
3474
|
-
/*
|
3564
|
+
/* https://download.macromedia.com/pub/developer/opentype/tech-notes/5902.AdobePSNameGeneration.html */
|
3565
|
+
/* */
|
3566
|
+
/* [Since 2.9] Special PostScript names for named instances are only */
|
3567
|
+
/* returned if the named instance is set with @FT_Set_Named_Instance */
|
3568
|
+
/* (and the font has corresponding entries in its `fvar' table). If */
|
3569
|
+
/* @FT_IS_VARIATION returns true, the algorithmically derived */
|
3570
|
+
/* PostScript name is provided, not looking up special entries for */
|
3571
|
+
/* named instances. */
|
3475
3572
|
/* */
|
3476
3573
|
FT_EXPORT( const char* )
|
3477
3574
|
FT_Get_Postscript_Name( FT_Face face );
|
@@ -3702,17 +3799,17 @@ FT_BEGIN_HEADER
|
|
3702
3799
|
* Note that only a subset of the available properties can be
|
3703
3800
|
* controlled.
|
3704
3801
|
*
|
3705
|
-
* *
|
3706
|
-
* property `no-stem-darkening' provided by the `autofit'
|
3707
|
-
* modules; see @no-stem-darkening
|
3708
|
-
* @no-stem-darkening[cff]).
|
3802
|
+
* * @FT_PARAM_TAG_STEM_DARKENING (stem darkening, corresponding to the
|
3803
|
+
* property `no-stem-darkening' provided by the `autofit', `cff',
|
3804
|
+
* `type1', and `t1cid' modules; see @no-stem-darkening).
|
3709
3805
|
*
|
3710
|
-
* * LCD filter weights
|
3806
|
+
* * @FT_PARAM_TAG_LCD_FILTER_WEIGHTS (LCD filter weights, corresponding
|
3711
3807
|
* to function @FT_Library_SetLcdFilterWeights).
|
3712
3808
|
*
|
3713
|
-
* *
|
3714
|
-
*
|
3715
|
-
*
|
3809
|
+
* * @FT_PARAM_TAG_RANDOM_SEED (seed value for the CFF, Type~1, and CID
|
3810
|
+
* `random' operator, corresponding to the `random-seed' property
|
3811
|
+
* provided by the `cff', `type1', and `t1cid' modules; see
|
3812
|
+
* @random-seed).
|
3716
3813
|
*
|
3717
3814
|
* Pass NULL as `data' in @FT_Parameter for a given tag to reset the
|
3718
3815
|
* option and use the library or module default again.
|
@@ -3775,6 +3872,9 @@ FT_BEGIN_HEADER
|
|
3775
3872
|
* FT_Face_Properties( face, 1, &property );
|
3776
3873
|
* }
|
3777
3874
|
*
|
3875
|
+
* @since:
|
3876
|
+
* 2.8
|
3877
|
+
*
|
3778
3878
|
*/
|
3779
3879
|
FT_EXPORT( FT_Error )
|
3780
3880
|
FT_Face_Properties( FT_Face face,
|
@@ -3899,7 +3999,7 @@ FT_BEGIN_HEADER
|
|
3899
3999
|
/* and subsetting restrictions associated with a font. */
|
3900
4000
|
/* */
|
3901
4001
|
/* See */
|
3902
|
-
/*
|
4002
|
+
/* https://www.adobe.com/content/dam/Adobe/en/devnet/acrobat/pdfs/FontPolicies.pdf */
|
3903
4003
|
/* for more details. */
|
3904
4004
|
/* */
|
3905
4005
|
/* <Values> */
|
@@ -3999,9 +4099,9 @@ FT_BEGIN_HEADER
|
|
3999
4099
|
/* Sequences' (IVS), collected in the `Ideographic Variation */
|
4000
4100
|
/* Database' (IVD). */
|
4001
4101
|
/* */
|
4002
|
-
/*
|
4003
|
-
/*
|
4004
|
-
/*
|
4102
|
+
/* https://unicode.org/Public/UCD/latest/ucd/StandardizedVariants.txt */
|
4103
|
+
/* https://unicode.org/reports/tr37/ */
|
4104
|
+
/* https://unicode.org/ivd/ */
|
4005
4105
|
/* */
|
4006
4106
|
/* To date (January 2017), the character with the most ideographic */
|
4007
4107
|
/* variations is U+9089, having 32 such IVS. */
|
@@ -4456,7 +4556,7 @@ FT_BEGIN_HEADER
|
|
4456
4556
|
*
|
4457
4557
|
*/
|
4458
4558
|
#define FREETYPE_MAJOR 2
|
4459
|
-
#define FREETYPE_MINOR
|
4559
|
+
#define FREETYPE_MINOR 9
|
4460
4560
|
#define FREETYPE_PATCH 1
|
4461
4561
|
|
4462
4562
|
|