Skip to main content

Merge together two source fonts in UFO format

Project description

ufomerge

This command line utility and Python library merges together two UFO source format fonts into a single file. It can be used to include glyphs from one font into another font. It takes care of handling:

  • Glyph outlines and information
  • Kerning
  • lib entries
  • Including any needed components
  • "Subsetting" and merging layout rules

Usage

To merge the glyphs of font-b.ufo into font-a.ufo and save as merged.ufo:

$ ufomerge --output merged.ufo font-a.ufo font-b.ufo

To include particular glyphs:

$ ufomerge --output merged.ufo --glyphs alpha,beta,gamma font-a.ufo font-b.ufo

To include glyphs referencing particular Unicode codepoints:

$ ufomerge --output merged.ufo --unicodes 0x03B1,0x03B2,0x03B3 font-a.ufo font-b.ufo

Other useful command line parameters:

  • -G/--glyphs-file: Read the glyphs from a file containing one glyph per line.
  • -U/--codepoints-file: Read the Unicode codepoints from a file containing one codepoint per line.
  • -x/--exclude-glyphs: Stop the given glyphs from being included.
  • -v/--verbose: Be noisier.

What to do about existing glyphs:

  • --skip-existing (the default): If a glyph from font-b already exists in font-a, nothing happens.
  • --replace-existing: If a glyph from font-b already exists in font-a, the new glyph replaces the old one.

What do to about OpenType layout (features.fea). Suppose there is a rule sub A B by C;, and the incoming glyphs are A and B:

  • --subset-layout (the default): the rule is dropped, because C is not part of the target glyphset. The ligature stops working.
  • --layout-closure: C is added to the target glyphset and merged into font-a so the ligature continues to work.
  • --ignore-layout: No layout rules are copied from font-b at all.

Usage as a Python library

ufomerge provides two functions, merge_ufos and subset_ufo. Both take ufoLib2.Font objects, and are documented in their docstrings.

License

This software is licensed under the Apache license. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ufomerge-1.8.2.tar.gz (22.5 kB view details)

Uploaded Source

Built Distribution

ufomerge-1.8.2-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file ufomerge-1.8.2.tar.gz.

File metadata

  • Download URL: ufomerge-1.8.2.tar.gz
  • Upload date:
  • Size: 22.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.6

File hashes

Hashes for ufomerge-1.8.2.tar.gz
Algorithm Hash digest
SHA256 86bebe4fa6c7f3935eb96e55716bc6a155111c191e1cbc0720c4ffcf0cb53a9d
MD5 e1b91ca476525fcb6e7a350d9c07e8ae
BLAKE2b-256 cc98176d0dbd2af9126375754d76b2876ee3b65377fe2324fb4d67a7d52a13eb

See more details on using hashes here.

File details

Details for the file ufomerge-1.8.2-py3-none-any.whl.

File metadata

  • Download URL: ufomerge-1.8.2-py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.6

File hashes

Hashes for ufomerge-1.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a3aad8dd0cb3574007cc87d2e77bb03006a23e44ceadc0dc8226cfbdd6235fd0
MD5 a0cc57fb87943e130c071417b24abd1d
BLAKE2b-256 6263aabaf8cbfcf3edf2cd384977d38a32af3a6e00c9592d3841e243fd11a732

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page