-
Notifications
You must be signed in to change notification settings - Fork 30
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Glyph hash spec is different from some implementations #224
Comments
Hey Jens, that part of the spec was written by Adobe (@readroberts iirc). I am happy to get it updated, but this should be worked out with Adobe also (@skef @kaydeearts @miguelsousa). It might be useful to give us a tldr; digest of what is different from ps/otfautohint and fontTools here, and where it is off of the written spec (or, a PR that folks can debate). The other question would be how to handle backwards compatibility, if that is needed (not sure it is?) |
I'm not seeing Adobe raising significant objections to changing this aspect of the UFO spec, as long as its the actual algorithm that is documented rather than a pointer off to the HashPointPen code. On that front: we should probably confirm with fontTools that either things are currently as they want them to be for the foreseeable future, or see if they're willing to add a parameter (or whatever) that ensures that pen matches the UFO spec, in case they want to support other algorithms at some point. The current form of |
Here's a summary of the changes from fonttools/fonttools#2005:
The change regarding the composite glyphs, which were decomposed in the Adobe implementation, was to facilitate use of the HashPointPen in checking if TrueType instructions match the outline, as in the UFO glyph’s public.truetype.instructions. Example outputs (without applying the sha512 hashing): A simple TTF glyph:
A composite glyph:
A nested composite glyph:
A glyph with outline and component:
|
The decomposing of composite glyphs, as the Adobe version does, makes sense for the hinting of CFF glyphs, where it doesn't matter how the outline ended up in the glyph. The change in the FontTools implementation proved unsatisfactory now (fonttools/fonttools#3421) because of how the transform values are stored in UFO vs. TTF. UFO can use arbitrary precision for any value, but TTF quantizes the transformation matrix elements to F2Dot14 values. This quantization also must be done in the stored hash if you want to compare glyphs between UFO and TTF, which is necessary in how the hash is used for TrueType hinting. Maybe we need different requirements for how to build the hash depending on whether it is used in PS or TT hinting? |
@jenskutilek I thought about this, especially because at first glance of the description I wondered if the new hash was only on the "local" composite information rather than also taking the components into account. But the components are included, they're just not "unpacked". The only relevant gap between the two hashes would be if the patterns of compositing changed but the component outlines, including their ordering, did not. From the perspective of CFF(2) you'd get a false negative on the identity check. I think that's fine -- there would just be some extra calculation in such cases. |
When I adapted the HashPointPen for usage in ufo2ft, it was discussed and improved in fonttools/fonttools#2005, but the UFO spec hasn't been updated to reflect the changes.
So there are now at least two different implementations of the glyph hash calculation, one in Adobe's psautohint, the other one in FontTools.
ufo-spec/versions/ufo3/glyphs/glif.md
Lines 436 to 458 in 115eea9
What's the way to resolve this? My vote would go to updating the spec to the algorithm used in the FontTools HashPointPen.
The text was updated successfully, but these errors were encountered: