Take UFO font sources and generate OTF’s and webfonts
Python
Latest commit 9025ba2 Nov 1, 2013 @codingisacopingstrategy codingisacopingstrategy Make CSS generator smarter about which fonts to group together
CSS can only cover a limited set of styles: it knows about font weight, and
about the difference between regular and italic.

Anything else, like condensed, for example, will need to be  be put into a
different font family, because there is currently no way to encode it into CSS.

Example output:

@font-face {
    font-family: 'Nimbus Sans L';
    font-style: 'normal';
    font-weight: '400';
    src: url('NimbusSanL-Regu.eot'); /* IE9 Compat Modes */
    src: url('NimbusSanL-Regu.eot?#iefix') format('embedded-opentype'),
         url('NimbusSanL-Regu.woff') format('woff'),
         url('NimbusSanL-Regu.ttf')  format('truetype');
}

@font-face {
    font-family: 'Nimbus Sans L';
    font-style: 'italic';
    font-weight: '400';
    src: url('NimbusSanL-ReguItal.eot'); /* IE9 Compat Modes */
    src: url('NimbusSanL-ReguItal.eot?#iefix') format('embedded-opentype'),
         url('NimbusSanL-ReguItal.woff') format('woff'),
         url('NimbusSanL-ReguItal.ttf')  format('truetype');
}

@font-face {
    font-family: 'Nimbus Sans L Condensed';
    font-style: 'normal';
    font-weight: '400';
    src: url('NimbusSanL-ReguCond.eot'); /* IE9 Compat Modes */
    src: url('NimbusSanL-ReguCond.eot?#iefix') format('embedded-opentype'),
         url('NimbusSanL-ReguCond.woff') format('woff'),
         url('NimbusSanL-ReguCond.ttf')  format('truetype');
}

@font-face {
    font-family: 'Nimbus Sans L Condensed';
    font-style: 'italic';
    font-weight: '400';
    src: url('NimbusSanL-ReguCondItal.eot'); /* IE9 Compat Modes */
    src: url('NimbusSanL-ReguCondItal.eot?#iefix') format('embedded-opentype'),
         url('NimbusSanL-ReguCondItal.woff') format('woff'),
         url('NimbusSanL-ReguCondItal.ttf')  format('truetype');
}

README.rst

UFO2OTF

Ufo2otf is a command line utility that takes UFO font sources and generates OTF’s and webfonts.

Summary

usage: ufo2otf [-h] [--webfonts] [--afdko] [--diagnostics]
               infiles [infiles ...]

positional arguments:
  infiles        The source UFO files

optional arguments:
  -h, --help     show this help message and exit
  --webfonts     Generate webfonts in a ./webfonts subfolder
  --afdko        Generate the OTF with Adobe Font Development Kit for Opentype
  --diagnostics  Display information about available font compilers (no files
                 outputted)

Usage examples

$ ufo2otf OpenBodoni.ufo

will create a file called OpenBodoni.otf.

$ ufo2otf OpenBodoni-Regular.ufo OpenBodoni-Italic.ufo OpenBodoni-Bold.ufo

will create OpenBodoni-Regalur.otf, OpenBodoni-Italic.otf and OpenBodoni-Bold.otf.

Fontforge

By default, ufo2otf uses FontForge to generate the otf files. FontForge is a free and open source font editor that comes with a python extension. The python extension has access to the functionality of FontForge without needing to launch the graphical program itself.

Ufo2otf will warn you if FontForge is not present. Installing it can be as easy as:

debian, ubuntu:

$ sudo apt-get install fontforge python-fontforge

os x:

$ brew install fontforge

More info see: http://openfontlibrary.org/wiki/How_to_install_FontForge

AFDKO

Ufo2otf can also use the AFDKO to generate the fontfiles.

The Adobe Font Development Kit for Opentype are a set of tools made available by Adobe that can help you generate Opentype/CFF fonts from PostScript sources, and to add OpenType features in the progress.

Since the AFDKO is not open source, and not installable on Linux, it doesn’t make a lot of sense for Open Source projects. But it can be useful to have around, if only to compare the output to that of FontForge.

Please check http://www.adobe.com/devnet/opentype/afdko.html for installation instructions. Subsequently, one needs to install Tal Leming’s ufo2afdko package which in turn depends on Robofab:

http://code.typesupply.com/wiki/ufo2fdk http://robofab.org/

Webfonts

Passing the option --webfonts will generate a subfolder called webfonts. Ufo2otf autohints the font and proceeds to generate ttf, eot and woff files.

When using the AFDKO to convert the fonts the webfonts option is not available.

CSS

When using the --webfonts option, Ufo2otf will attempt to generate a CSS file to use with the generated webfonts, inspired by the service provided by the website Font Squirrel. However, where Font Squirrel will create a separate css @font-face family for each font style, Ufo2otf will try to construct your font declarations in such a way that one @font-face family can be used with multiple font-styles.

In doing so the script is bound by what CSS supports. Currently, Ufo2otf can distinguish between multiple font-weights and between regular and Italic fonts. If you have other styles to distinguish (condensed, outline etcetera) you will need to adjust the font-family property in the CSS to create separate families.

UFO

UFO is an open and exchangable format for fonts.It is easy to write programs that process UFO fonts, and they play well with versioning systems like Git.

http://unifiedfontobject.org/

History

Ufo2otf has been developed by Eric Schrijver for the Open Baskerville font project, a collaborative open source typeface.

http://klepas.org/openbaskerville/

License

Ufo2otf is licensed under the BSD license (see LICENSE.txt).

Argparse

This software includes a version of Python 2.7’s argparse module that is compatible with earlier version of Python. The author is Steven Bethard and the license is the Python Software Foundation license http://docs.python.org/license.html