Summary: | Status of OpenType Collection support | ||
---|---|---|---|
Product: | Ghostscript | Reporter: | Werner Lemberg <wl> |
Component: | Font API | Assignee: | Chris Liddell (chrisl) <chris.liddell> |
Status: | RESOLVED INVALID | ||
Severity: | normal | CC: | jungshik.shin |
Priority: | P4 | ||
Version: | unspecified | ||
Hardware: | PC | ||
OS: | Linux | ||
Customer: | Word Size: | --- |
Description
Werner Lemberg
2016-05-29 23:18:31 UTC
(In reply to Werner Lemberg from comment #0) > It seems that ghostscript currently doesn't support OpenType Collections > (OTC). Are there plans to support it? > > Similarly, will ghostscript extend its Type42 support so that it can handle > arbitrary SFNT fonts, including OTCs? Right now I'm wondering whether I > should do that in FreeType... > > Or asking differently: What format should be used if you want to have an OTC > as a PostScript resource embedded into a PS file? You can't - Postscript does not support Opentype fonts at all, nor does it support Truetype Collections. In fact, Postscript doesn't even support Truetype fonts, only Type 42 - okay, strictly speaking, Type 42 is largely just a thin wrapper around a TTF..... We're not really in a position to change what's included in the Postscript spec. *Ghostscript* (so outside the realms of the Postscript spec) has custom extensions to allow wider support for font loading from disk. For embedding the content of a OTTO or OTC in Postscript, you would have to extract the CFF (from the appropriate index, in the case of an OTC), and embed the CFF stream as a Postscript Type 2 font. Better support for reading TTC, OTTO and OTC font files from disk are certainly on my to-do list, but haven't yet reached the top the list. But once done, our Postscript output will still not contain a TTC/OTTO/OTC font, but the closest Postscript legal equivalent. Thanks for the quick reply. I was imprecise, sorry; I've meant embedding a CFF stream in the PS file, of course. (In reply to Werner Lemberg from comment #2) > Thanks for the quick reply. > > I was imprecise, sorry; I've meant embedding a CFF stream in the PS file, of > course. Maybe I misunderstood then, but, from a Postscript job, we'll never get an OTTO nor OTC (nor TTC). If we get a Truetype it will be wrapped up as a Type 42. If a font started out as an OTTO or OTC, what will be embedded in the Postscript is the CFF stream wrapped in a Type 2 font. If you're pondering whether to extend Freetype's Type 42 support to support something other that TrueType outlines, then the answer is "no" - a Type 42 with something other than TTF outlines is invalid. (Note that the way the Ghostscript/Freetype integration works, Freetype never sees a Type 42 from us: what we pass to Freetype is a Truetype.) And I certainly do plan to extend/improve our support of OTTO/OTC/TTC files, but heaven knows when I'll have the time....... but because of the way we have to load such fonts, Freetype will still only ever see Truetype or CFF fonts derived from those inputs. Werner, Are you happy with the information here? Or do you need/want more from us? In other words, can I close this bug? Thanks! Yes, I got all the information, so please close. (In reply to Werner Lemberg from comment #5) > Thanks! Yes, I got all the information, so please close. Thanks. (In reply to Chris Liddell (chrisl) from comment #3) > And I certainly do plan to extend/improve our support of OTTO/OTC/TTC files, > but heaven knows when I'll have the time....... but because of the way we > have to load such fonts, Freetype will still only ever see Truetype or CFF > fonts derived from those inputs. Is there a bug filed against OTTO/OTC/TTC support for tracking this issue? If not, I'll file a new bug on that issue. I noticed that ghostscript is shipped with 'DroidSansFallback.ttf' as a CJK substitution font (that Android used to have but does not use any more). It'd be really nice if Noto Sans CJK ( https://www.google.com/get/noto/help/cjk/ https://github.com/googlei18n/noto-cjk ) can be used in ghostscript because they have a lot better support for CJK. Currently, it cannot be because Noto Sans CJK comes in OTF (with CFF) or OTC. It's probably covered by a combination of: http://bugs.ghostscript.com/show_bug.cgi?id=690110 and http://bugs.ghostscript.com/show_bug.cgi?id=695903 |