[Fontconfig] Fontconfig language update proposal

Nicolas Mailhot nicolas.mailhot at laposte.net
Sat Nov 23 19:24:04 UTC 2019


Hi all,

CONTEXT

I've now spent several years redoing font packaging automation in
Fedora, culminating with this guideline change proposal:
https://pagure.io/packaging-committee/pull-request/934

It should soon be dead easy to package industrial quantities of nice
OFL fonts Fedora-side, without giving up on quality, right?

Unfortunately, no. Font files have gotten a lot more complex in the
past decade. But font authors are no more careful than they were in the
past. Thus, the amount of fixing required fontconfig-side has grown.

However, the fontconfig language is little more expressive today, than
it was a decade ago. Despite Fedora shipping fontconfig templates
maintained by Akira himself, our fontconfig state is, at best, poor.

PROPOSAL

I would like the fontconfig project to consider a configuration
language update based on the following proposal:
https://gitlab.freedesktop.org/fontconfig/fontconfig/issues/200

It is based on the experience, gained, analysing hundreds of Fedora
fontconfig files, while streamlining the corresponding packaging.

This update is a mix of:
– syntax sugar enhancements
– tweaked fontconfig engine behaviour
– new features

It is presented both in traditional XML, and in YAML.

The proposal is only intended as documentation of the kind of thing
that would be useful to fontconfig users. I don’t care if this exact
syntax is adopted, or if it’s only partially implemented. Please
provide something that does the kind of thing I documented.

The current fontconfig syntax is awkward for simple traditional font
projects, and does not scale at all to the level required for modern
complex font project.

CONCISENESS

The proposal results in drastically more succinct config files, which
are easier to write, review and maintain. Conciseness is its own
feature.

For example, the description of IBM Plex Sans takes 106 lines in the
XML variant, and 27 lines in the YAML Variant. That may seem awful,
but my current incomplete attempt to describe Plex Sans with today’s
fontconfig syntax is more than 1700 lines long.

Given what I know of today’s fontconfig syntax, this attempt will never
achieve what’s in the proposal. The necessary logic is missing in the
fontconfig engine. It's not just a templating problem.

And, the missing logic is not complex. fontconfig is very close to
where it should be engine-side. Little things just snowball out of
control in presence of complex font projects.

Plex is not a pathological font project. On the contrary, it’s well
funded, and its authors clearly try to do the right thing. But, Plex
is modern, complex font project. That leaves a lot of room for small
mistakes.

ORDERING INDEPENDANCE

The proposal results in largely order-independant config files,
removing the need to agonize over proper ordering and ordering side-
effects, and removing the need to split configuration for a font family
over multiple files (that required specifying engine behaviour tweaks).

CORRECT ABSTRACTION LEVEL

The proposal avoids over-specifying low-level fontconfig behaviour,
leaving room to tweak the logic when new lessons are learnt, without
requiring the rewrite of thousands of configuration lines spread over
hundreds of files.

DOING THE CORRECT THING BY DEFAULT

The proposal makes some fixes automatic (generally, just applying
OpenType recommendations), so they're not forgotten half the time, and
we can all focus on more interesting things.

COMPATIBILITY

The proposal is backwards-compatible.

I hope you’ll find it interesting.

Best regards,

-- 
Nicolas Mailhot



More information about the Fontconfig mailing list