Add `ttfautohint.pc' file.
[ttfautohint.git] / TODO
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 control `gasp' table; Adam Twardoch suggest the following:
12   1. Calculate "gaspstem", i.e. the most common thickness of horizontal
13      stems (y direction distances) for lowercase Latin letters.
14   2. If gaspstem <= 0.03 * upm, apply gasp symmetric smoothing across the
15      entire range (rangeMaxPPEM 0xFFFF, value 15)
16   3. Else, calculate gaspthreshold as follows:
17        ceil(1.33 * upm / gaspstem) - 1
18   4. Apply no symmetric smoothing up to the gaspthreshold ppem (rangeMaxPPEM
19      gaspthreshold, value 7), and apply symmetric smoothing above.
21   In addition, ttfautohint should provide a commandline parameter that
22   allows the user to override the automatic logic.  If that parameter = 0,
23   then gasp value 15 should be applied across the entire range.  If the
24   parameter > 0, then up to that parameter value the gasp value 7 should be
25   applied, and gasp value 15 should be applied above.
27 create a separate blue zone class for `i' and `j':
28   . if the values differ more than a given threshold, handle them
29     separately
30   . otherwise, unify them with `f' and friends.
32 user-defined blue zones?
33   -> old-style digits
35 control the width of blue zones
37 add control over character ranges that define a script; in particular, add
38   support for the PUA
40 handle normal and bold fonts differently; cf. Infinality patches;
41   this should help avoid filling of bowls (like in `e') for bold shapes.
43 help font families harmonize well so that e.g. x height and stem width
44   change synchronously
46 control the minimum stem width
48 try to `embolden' fonts at small sizes to avoid drop-outs; cf. Infinality
49   patches
51 make switching between smooth and strong hinting dependent on user-defined
52   ranges
54 improve `adjust-subglyphs' by making the used PPEM value configurable
56 allow hinting of single glyphs, using a config file that holds the global
57   settings
59 better handling of `incomplete' fonts (this is, fonts that lack the minimum
60   set of glyphs necessary to determine the blue zones)
62 add second-pass analysis to improve positioning of composite glyphs
64 introduce a new control instructions command to apply a given delta to a
65 whole contour
68 minor improvements
69 ------------------
71 add a glossary to the documentation
73 reject fonts that are `hopeless' (for example, `Lipstick')
75 correctly set `lowestRecPPEM' field in `head'
77 control dropout mode
79 apply hinting in x direction also?
80   -> warper: shifting with and without scaling
81   -> `standard' autofit hinting
83 add a config and/or command file for batch handling
85 warn against overwrite of output file in command-line mode?
87 reduce output size of option -p:
88   1. compare outline rendered at EM value with unhinted outline
89   2. adjust subglyphs only if result of item 1 differs more than given
90      threshold (default 0.5%?)
92 make it possible to hint fonts that aren't alphabetic at all, for example,
93   icons; to do so, provide means to skip the global feature analysis
95 better control of -i output
97 allow processing of multiple files by using globs as in the Midnight
98   Commander?
100 allow composite fonts already processed by ttfautohint to be processed
101   again (due to option `hint-composites' this isn't urgent)
103 make ttfautohint remember options:
104   1. collect md5 checksums in a `~/.ttfautohint_history' file so that fonts
105      can be re-processed easily, using the same parameters
106   2. if fonts already processed by ttfautohint can be re-processed (which
107      isn't possible yet), parse the `version' string for parameters
109 implement (sort of) the opposite of -x, this is, decrease the x height
112 later enhancements
113 ------------------
115 add CJK autohinting module
117 instead of emitting bytecode, write the hints as a VTT or FontLab script
119 Windows/Mac installer
122 various
123 -------
125 testing with Windows and Apple font checkers
127 man page for ttfautohint library
129 install library
131 add help2man script so that parallel builds always work