Issue with components from intermediate layers
anthrotype opened this issue · 18 comments
If a font contains a mixed glyph (with outlines and components) that should get decomposed at build time, and any of the components in turn reference a glyph that has intermediate ("brace") layers, currently the mixed glyph has to have the same set of intermediate layers as its components' base glyphs, otherwise the latter are ignored as the mixed glyph is decomposed and thus the originally mixed now decomposed glyph will not display as expected (i.e. with the expected intermediate layers) in the generated font.
Glyphs.app itself does not impose this, and the mixed-composite glyph needs not replicate the intermediate layers of the component glyphs.
The following test file, IntermediateLayer.glyphs.zip, contains glyph "i" which is composed of "idotless" and an outline for the i's dot. The "idotless" glyph has an additional intermediate layer (drawn as a triangle to make it clear if the intermediate is working or not when rendered).
If the "{700}" intermediate layer is removed from the glyph "i", the font compiled with fontmake (as well as fontc) will render the glyph "i" incorrectly at wght=700, the stem of the i rendered as a rectangle instead of a triangle (like in idotless at wght=700).
I noticed this issue while working on #859 where @RosaWagner's test font similarly uses a _part.line
component in a bunch of ABCDE etc. glyphs which also contain regular outlines thus should be decomposed. The workaround there was to add all the intermediate layers to the composite glyphs (manually one by one..)
Adding the extra intermediate layer to the composites what needed in Glyphs 2 but in Glyphs 3 it is not any more.
Could you explain how this is supposed to work?
For each glyph that has a mixture of outlines and components, for each of the components, if the component's base glyph has any intermediate layers that the parent glyph has not, then a new intermediate layer is added to the parent glyph containing decomposed outlines interpolated at that intermediate layer's location?
The short explanation is: Look at all components, if the base glyphs has brace layers. If so, make a as many copies of the layer for each brace location (if not already present). Then re-interpolate the paths and then decompose the components (getting the outlines from the base glyphs brace layers).
Ah came here to report the same. The issue is blocking the onboarding of the brand fonts by Reddit.
this is going to take some time to implement, it's non trivial fix, I suggest you create the intermediate layers in the sources for all the composite glyphs that use a component that in turn has some intermediate layers
we're running into the same issue with
Afrotype/danfo#2
I've just hit this with my grand Get Rid Of SemiBold In Noto plan, but from the other way around: A glyph with an intermediate layer uses a component which does not have such a layer will not compile because fontmake can't find a layer for the component. So I'm up for implementing it.
Now I can't actually reproduce your bug.
Sorry my fault, I should have been clearer. In the original comment I wrote
If the "{700}" intermediate layer is removed from the glyph "i", ...
Basically the .glyphs file in the uploaded archive works fine, exactly because both the composite glyph (i) and the glyph used as component (idotless) have the same set of intermediates; you actually need to modify the file and remove the {700}
layer from "i", save the file and the compile with fontmake, to be able to trigger the issue.
This one below will show the issue when compiled with fontmake:
IntermediateLayer-bad.glyphs.zip
When exported directly from Glyphs.app it works just like the original .glyphs file which contained explicit matching intermediate layers
I have GlyphsApp-native code for this. Shall I attempt a PR?
Edit: Link pointed to wrong file. Corrected it.
thanks but we don't want to expand the intermediate layers to full masters like that script seems to be doing. We only want to sync composites' and respective components' intermediate layers. #971 was one side of the problem, we need to do the second part. Maybe @simoncozens will be able to tackle this?
The tricky part was the 'reinterpolate' part which Simon addressed in #971 already.
What do you mean exactly with "reinterpolate part"?
The outlines of my font interpolate correctly, I think. My problem is that the composite glyphs show no adjusted width at those designspace locations.
What do you mean exactly with "reinterpolate part"?
when inserting a new brace layer we need to interpolate the new layer at that location
I will soon have a fix for this in googlefonts/ufo2ft#826. Once that's merged and released, we can revert the changes in #971, which will no longer be needed since ufo2ft will take care of "aligning", so to speak, the composite glyphs and referenced components intermediate locations as needed (i.e. only when the composite glyphs are actually going to be decomposed). Right now, glyphsLib is unconditonally interpolating intermediate layers for glyphs used as components in composite glyphs that have additional masters, not present in the components' glyphs. But that may lead to unnecessary additional delta sets in gvar if these composite glyphs end up not being decomposed any more at compile time.
This should be now fixed for good by fontmake 3.9.0 https://github.com/googlefonts/fontmake/releases/tag/v3.9.0
please test and let me know if that's not the case!