-
Notifications
You must be signed in to change notification settings - Fork 51
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
MTI features plist as custom parameter, exported to UFO data/ #326
Comments
It's not exactly what you want, but in order to roundtrip UFO -> Glyphs -> UFO, I store all the contents of the data folder in base64 in the Glyphs file's userData, and restore the data files when going back to UFO. |
I am not sure whether a Glyphs.app user can define one's own "private" custom parameters for one's own tools' consumption, not for the Glyphs.app core to use. Another problem with self-defined custom parameters is that only strings seems to be allowed, so if want to store a structured data like this one (a dictionary keyed by table tags, with values the respective text file names) I would have to resort to some special formatting like Maybe I'm abusing the concept of custom parameters, and I should rather use the The problem with |
thanks jany, but I think it would be best to keep those files as external files, as they may be edited from an external editor I guess. |
I’m thinking on adding support for MTI sources somehow to Glyphs. As a similar case, if you add a featurePrefix with the name "morx" this will be used to compile AAT tables (of you have the apple font tools installed). Something similar could be done for MIT sources. I can’t compile those, yet, but that shouldn’t be to complicated. The plist contains OT data for each instances, so I would put it there. Glyphs is fine with "custom" custom parameters (they are just shown grey to signal that Glyphs doesn’t know/use them. |
I look into the possibility to store dicts in the custom custom parameters. For now, we could defined three keys, like: |
in the case of Noto, they refer to the masters actually, and the instance GPOS is interpolated with fonttools.varLib.interpolate_layout. But I guess that's an implementation detail. |
thanks!
yeah, maybe that's good enough for now.
but if two users define the same private name to mean different things then there could be problems. |
I recommend the reverse name keys in userData but for custom parameter I prefer shorter and more readable keys. |
that's a good point, but the risk of clashing still persists. |
It wouldn’t be that hard to write a userData editor as a plugin/extension for Glyphs.app. |
@moyogo you volunteering? 😛 |
True. But there is a UI for user facing data already ;) |
then I missed it. Where can I find it? |
The custom parameter list |
oh, I thought you meant the |
that was fast, thanks :) |
Yes. Thats why I suggested three entry in this particular use case. |
I've been thinking.. even if we were able to store the paths to these MTI feature files as master's custom parameters in the .glyphs source, instead of in the external .plist files, this would not solve the problem for a group of Noto sources (i.e. Devanagari, Bengali, Malayalam and Tamil) that have two MTI plists, one for the normal fonts and the other for the UI variant, but only one .glyphs source file shared by both. These .glyphs sources needs to be built twice: once with one set of MTI sources, then again for the UI variants with the corresponding UI .plist, and using the weird I am tempted to simply duplicate the .glyphs sources in the noto-source repo, and enforce a one-to-one relation between .glyphs and MTI .plist sources: e.g. so there would be NotoSansDevanagariUI-MM.glyphs which is the same as NotoSansDevanagari-MM.glyphs, but its masters uses different MTI sources. For Noto Sans Myanmar and Khmer, the UI variants are in different |
I would add a second set of instances on for the normal and one for the UI fonts. Then you can add all specific settings like family name and feature files. |
That is already the case. The Devanagari glyphs source contains both the non UI and the UI instances. However for the MTI features we need to associate them to the masters, as the instances’s GPOS is interpolated at the binary level using fontTools.varLib.interpolate_layout. |
I see. I still would try to control that by instances settings. Maybe add a suffix to the UI-MTI sources and define the suffix in the instances. So the masters have "Mastername.mti" and the instance can add a suffix that the file "Mastername-UI.mti" will be used instead? It is a bit of a hack but better than duplicating the file. |
fontmake has an
--mti-source
option to load Monotype feature files from a plist file containing a mapping of OpenType table tags (GSUB, GPOS, GDEF) to text files containing feature specifications in MTI feature file format.http://monotype.github.io/OpenType_Table_Source/otl_source.html
When building the master UFOs from a glyphs source, if that command line option is provided, fontmake reads the plist and copies the content of the referenced text files inside each master UFO's
data
directory, prefixed with a private reverse-domain prefix that ufo2ft uses to load these data files and pass them on to fontTools.mtiLib for compilation.I would like that we could store the filenames of these external MTI feature files inside the Glyphs source file itself, in the form of masters custom parameters, and the glyphsLib could read these upon building the UFO masters and store them in the data folder, just like fontmake does.
This way, the fontmake command line to build from a glyphs source file with MTI features would not contain the extra option and its output determined only by the content of the single input glyphs file.
This is how this plist files currently look like:
The text was updated successfully, but these errors were encountered: