/psautohint

A standalone version of AFDKO’s autohinter

Primary LanguageCApache License 2.0Apache-2.0

Test and Build Codecov PyPI Language grade: C/C++ Language grade: Python Total alerts

Important Note: otfautohint

This repository is now retired. We have added a python port of its code to version 4.0.0 of AFDKO (to be released shortly, prerelease here). There is more information here. The new tool can be called from the command line as otfautohint, allowing it and psautohint to be used at the same time during a transition period. Please switch to otfautohint and file any new issues or PRs against that tool.

(psautohint was split off from AFDKO a number of years ago for technical reasons having to do with code organization. The Python port resolves those issues so we are adding it back into AFDKO to simplify distribution of our tools.)

PSAutoHint

A standalone version of AFDKO’s autohinter.

Building and running

This repository currently consists of a core autohinter written in C, a Python C extension providing an interface to it, and helper Python code.

To build the C extension:

python setup.py build

To install the C extension and the helper scripts globally:

pip install -r requirements.txt .

Alternatively to install them for the current user:

pip install -r requirements.txt --user .

The autohinter can be used by running:

psautohint

To build just the autohintexe binary:

python setup.py build_exe

Testing

We have a test suite that can be run with:

pytest

Debugging

For standard debugging, build with:

python setup.py build --debug

It is also possible to build a debug version with AddressSanitizer ("ASan") support (currently for Mac OS X only) with:

python setup.py build --asan
pip install .

Once it is installed, you can use the util/launch-asan.sh shell script to launch a Python process that invokes the ASan libraries needed for debugging. Attach Xcode the launched process, then execute code in the process that triggers memory usage problems and wait for ASan to do its magic.

NOTE: be sure to build and install psautohint as described above; using other techniques such as python setup.py install will cause a re-build without ASan and debug support, which won't work.