Updates to new release.
[ttfautohint.git] / TODO
blob27bca0789c1a3d8e375b4c961a29840d6113acc9
2 important improvements
3 ----------------------
5 add features to the GUI
6   -> direct control over `actions'
7   -> preview similar to ftgrid
8   -> autocompletion of file names with tab key
10 handle OT features
11   -> use HarfBuzz?
13 control `gasp' table; Adam Twardoch suggest the following:
15   1. Calculate "gaspstem", i.e. the most common thickness of horizontal
16      stems (y direction distances) for lowercase Latin letters.
17   2. If gaspstem <= 0.03 * upm, apply gasp symmetric smoothing across the
18      entire range (rangeMaxPPEM 0xFFFF, value 15)
19   3. Else, calculate gaspthreshold as follows:
20        ceil(1.33 * upm / gaspstem) - 1
21   4. Apply no symmetric smoothing up to the gaspthreshold ppem (rangeMaxPPEM
22      gaspthreshold, value 7), and apply symmetric smoothing above.
24   In addition, ttfautohint should provide a commandline parameter that
25   allows the user to override the automatic logic.  If that parameter = 0,
26   then gasp value 15 should be applied across the entire range.  If the
27   parameter > 0, then up to that parameter value the gasp value 7 should be
28   applied, and gasp value 15 should be applied above.
30 create a separate blue zone class for `i' and `j':
31   . if the values differ more than a given threshold, handle them
32     separately
33   . otherwise, unify them with `f' and friends.
35 control the characters used for blue zones
36   -> non-latin scripts
38 user-defined blue zones?
39   -> old-style digits
41 control the width of blue zones
43 add control over character ranges which define a script; in particular, add
44   support for the PUA
46 handle normal and bold fonts differently; cf. Infinality patches;
47   this should help avoid filling of bowls (like in `e') for bold shapes.
49 control the minimum stem width
51 try to `embolden' fonts at small sizes to avoid drop-outs; cf. Infinality
52   patches
54 implement `x-height-snapping-exceptions'
56 improve `pre-hinting' by making the used PPEM value configurable
58 allow hinting of single glyphs, using a config file which holds the global
59   settings
61 better handling of `incomplete' fonts (this is, fonts which lack the minimum
62   set of glyphs necessary to determine the blue zones)
65 minor improvements
66 ------------------
68 reject fonts which are `hopeless' (for example, `Lipstick')
70 correctly set `lowestRecPPEM' field in `head'
72 control dropout mode
74 apply hinting in x direction also?
75   -> warper: shifting with and without scaling
76   -> `standard' autofit hinting
78 add a config and/or command file for batch handling
80 warn against overwrite of output file in TTY mode?
82 reduce output size of option -p:
83   1. compare outline rendered at EM value with unhinted outline
84   2. pre-hint only if 1. differs more than given threshold (default 0.5%?)
86 make it possible to hint fonts which aren't alphabetic at all, for example,
87   icons; to do so, provide means to skip the global feature analysis
89 better control -i output
91 allow processing of multiple files by using globs as in the Midnight
92   Commander
94 allow composite fonts already processed by ttfautohint to be processed
95   again
97 make ttfautohint remember options:
98   1. collect md5 checksums in a `~/.ttfautohint_history' file so that fonts
99      can be re-processed easily, using the same parameters
100   2. if fonts already processed by ttfautohint can be re-processed (which
101      isn't possible yet), parse the `version' string for parameters
103 implement (sort of) the opposite of -x, this is, decrease the x height
106 later enhancements
107 ------------------
109 add CJK autohinting module
110 add Hebrew autohinting module
112 instead of emitting bytecode, write the hints as a VTT or FontLab script
114 Windows/Mac installer
117 various
118 -------
120 testing with Windows and Apple font checkers
122 man page for ttfautohint library
124 install library
126 add help2man script so that parallel builds always work