README
1 ------------------------------------------------------------------------------
2 ot-sanitise - TTF/OTF font transcoder
3
4 Description:
5 ot-sanitise is a program which validates and transcodes a truetype or
6 opentype font file using the OTS library:
7
8 transcoded_font = ValidateAndTranscode(original_font);
9 if (validation_error)
10 PrintErrorAndExit;
11 OutputToStdout(transcoded_font);
12
13 Usage:
14 $ ./ot-sanitise ttf_or_otf_file > transcoded_file
15
16 Example:
17 $ ./ot-sanitise sample.otf > transcoded_sample.otf
18 $ ./ot-sanitise malformed.ttf > transcoded_malformed.ttf
19 WARNING at ots/src/ots.cc:158: bad range shift
20 ERROR at ots/src/ots.cc:199 (bool<unnamed>::do_ots_process(ots::OpenTypeFile*, ots::OTSStream*, const uint8_t*, size_t))
21 Failed to sanitise file!
22 $
23
24 ------------------------------------------------------------------------------
25 idempotent - TTF/OTF font transcoder (for OTS debugging)
26
27 Description:
28 idempotent is a program which validates and transcodes a truetype or opentype
29 font file using OTS. This tool transcodes the original font twice and then
30 verifies that the two transcoded fonts are identical:
31
32 t1 = ValidateAndTranscode(original_font);
33 if (validation_error)
34 PrintErrorAndExit;
35 t2 = ValidateAndTranscode(t1);
36 if (validation_error)
37 PrintErrorAndExit;
38 if (t1 != t2)
39 PrintErrorAndExit;
40
41 This tool is basically for OTS developers.
42
43 Usage:
44 $ ./idempotent ttf_or_otf_file
45
46 Example:
47 $ ./idempotent sample.otf
48 $ ./idempotent malformed.ttf
49 WARNING at ots/src/ots.cc:158: bad range shift
50 ERROR at ots/src/ots.cc:199 (bool<unnamed>::do_ots_process(ots::OpenTypeFile*, ots::OTSStream*, const uint8_t*, size_t))
51 Failed to sanitise file!
52 $
53
54 ------------------------------------------------------------------------------
55 validator_checker - font validation checker
56
57 Description:
58 validator_checker is a program which is intended to validate malformed fonts.
59 If the program detects that the font is invalid, it prints "OK" and returns
60 with 0 (success). If it coulndn't detect any errors, the program then opens
61 the transcoded font and renders some characters using FreeType2:
62
63 transcoded_font = ValidateAndTranscode(malicious_font);
64 if (validation_error)
65 Print("OK");
66 OpenAndRenderSomeCharacters(transcoded_font); # may cause SIGSEGV
67 Print("OK");
68
69 If SEGV doesn't raise inside FreeType2 library, the program prints "OK" and
70 returns with 0 as well. You should run this tool under the catchsegv or
71 valgrind command so that you can easily verify that all transformed fonts
72 don't crash the library (see the example below).
73
74 Usage:
75 $ catchsegv ./validator_checker malicous_ttf_or_otf_file
76
77 Example:
78 $ for f in malformed/*.ttf ; do catchsegv ./validator-checker "$f" ; done
79 OK: the malicious font was filtered: malformed/1.ttf
80 OK: the malicious font was filtered: malformed/2.ttf
81 OK: FreeType2 didn't crash: malformed/3.ttf
82 OK: the malicious font was filtered: malformed/4.ttf
83 $
84
85 ------------------------------------------------------------------------------
86 perf - performance checker
87
88 Description:
89 perf is a program which validates and transcodes a truetype or opentype font
90 file N times using OTS, then prints the elapsed time:
91
92 for (N times)
93 ValidateAndTranscode(original_font);
94 Print(elapsed_time_in_us / N);
95
96 Usage:
97 $ ./perf ttf_or_otf_file
98
99 Example:
100 $ ./perf sample.ttf
101 903 [us] sample.ttf (139332 bytes, 154 [byte/us])
102 $ ./perf sample-bold.otf
103 291 [us] sample-bold.otf (150652 bytes, 517 [byte/us])
104
105 ------------------------------------------------------------------------------
106 side-by-side - font quality checker
107
108 Description:
109 side-by-side is a program which renders some characters (ASCII, Latin-1, CJK)
110 using both original font and transcoded font and checks that the two rendering
111 results are exactly equal.
112
113 The following Unicode characters are used during the test:
114 0x0020 - 0x007E // Basic Latin
115 0x00A1 - 0x017F // Latin-1
116 0x1100 - 0x11FF // Hangul
117 0x3040 - 0x309F // Japanese HIRAGANA letters
118 0x3130 - 0x318F // Hangul
119 0x4E00 - 0x4F00 // CJK Kanji/Hanja
120 0xAC00 - 0xAD00 // Hangul
121
122 This tool uses FreeType2 library.
123 Note: This tool doesn't check kerning (GPOS/kern) nor font substitution
124 (GSUB). These should be tested in Layout tests if necessary.
125
126 Usage:
127 $ ./side-by-side ttf_or_otf_file
128
129 Example:
130 $ ./side-by-side linux/kochi-gothic.ttf # no problem
131 $ ./side-by-side free/kredit1.ttf # this is known issue of OTS.
132 bitmap metrics doesn't match! (14, 57), (37, 45)
133 EXPECTED:
134
135 +#######*.
136 +##########+
137 .###+.#. .#.
138 *#* # #*
139 ##. # ##
140 ## # ##
141 ## # ##
142 ## #. ##
143 ##. #. .##
144 ##. #. .##
145 *#+ *+ +#*
146 *#+ *+ +#*
147 *#+ *+ +#*
148 *#+ *+ +#*
149 *#+ *+ *#*
150 *#+ ++ *#+
151 +#* +* *#+
152 +#* +* *#+
153 +#* +* *#+
154 +#* +* ##.
155 +#* +* ##.
156 .## .# ##
157 .## .# ##
158 .## .# ##
159 ## # ##
160 ## # ##
161 ## # .##
162 ## # .##
163 ## .#+ +#*
164 ## +######*
165 ##.+#######*
166 *##########*
167 +##########+
168 #########*
169 .########
170 +####+
171
172
173
174
175
176
177 .*######*
178 +##*.*#####
179 .##+.#+ +#
180 *#* ## #+
181 ##*### ##
182 ###### ##
183 ##+.##+ +##
184 ## ##########
185 ## +#########
186 ## +########
187 *#. .########*
188 .#* #########.
189 +##########+
190 +*######*
191
192 ACTUAL:
193
194 .*##*+
195 +##+.##*.
196 .#* .##.+#*
197 *# ### *#+
198 #*######+ .*#+
199 #########*. +#*.
200 ###########* +#*
201 *############+ *#+
202 +##############. .##.
203 *##############* +#*
204 +###############+ *#+
205 *###############+ .*#+
206 .###############*. +#*.
207 +###############* +#*
208 *###############+ *#+
209 .*###############+ .*#+
210 +###############*. +#*
211 +###############* **
212 *###############+ #+
213 .###############* ##
214 +############+ ##
215 +########* .##
216 .######. +###
217 +#####+ .*#..#
218 +#####* *###..#
219 *#####. +#######*
220 +#####+ .*########.
221 +#####* +#########*
222 *#####. +##########+
223 +#####+ *#########*.
224 .#####* +##########+
225 *#####. +##########*
226 +#####+ *#########*.
227 .#####* +##########+
228 *#####+ +##########*
229 .#*++#+ *#########*.
230 .#+ ## +##########+
231 ****###+.##########*
232 ##################.
233 ###+ *#########+
234 ## +########*
235 *#+ *########.
236 ##.#######+
237 +#######*
238 *###*.
239
240
241 Glyph mismatch! (file: free/kredit1.ttf, U+0021, 100pt)!
242 $
243 ------------------------------------------------------------------------------
244