Maintenance status: The trufont project is currently discontinued. Although we will happily accept bug fixes, no new features are currently planned.
TruFont is a multiplatform font editor built with Python3 and PyQt5.
The wx
branch contains a stub wxWidgets port of the app.
-
Install Python 3.6 (or later):
- OS X: Install using Homebrew:
brew install python3
- Windows: Download installer from python.org/downloads
- Linux: It's usually packaged with the OS.
- OS X: Install using Homebrew:
-
Set up a new Python virtual environment. Although this is not required, it's highly recommended, since TruFont has lots of dependencies, which may (or may not) conflict with other modules you installed globally.
-
To create a new virtual environment in
ENV_DIR
:python3 -m venv ENV_DIR
This creates a new
ENV_DIR
folder (you can choose the name you want). Thebin
subfolder (orScripts
if you are on Windows) contains a newpython
executable, and thepip
installer linked to that. -
Activate the newly created environment:
- OS X or Linux:
source ENV_DIR/bin/activate
- Windows:
ENV_DIR\Scripts\activate.bat
This temporarily adds the virtual environment's scripts folder to your console's
PATH
, so you can accesspython
,pip
and thetrufont
script from anywhere. - OS X or Linux:
-
Run
deactivate
when you wish to exit the virtual environment. This restores the default systemPATH
.
-
-
Install/update TruFont to the latest stable release:
pip install --upgrade trufont
-
Run the app as
trufont
.
Here's a quick tutorial if you'd like to contribute to TruFont.
-
Click the "Fork" button above, and clone the forked git repository to a new directory called
trufont
:git clone https://github.com/<YOUR_USERNAME>/trufont
-
Move into the new folder and run this command to add the upstream repository url to the local list of remotes:
git remote add upstream https://github.com/trufont/trufont
This enables you to keep up-to-date with the upstream development.
-
Synchronize your fork's
master
branch with theupstream/master
, especially before creating new branches:git checkout master git fetch upstream git rebase upstream/master git push
-
Install pre-commit. It will run some checks every time you are about to commit something.
pip install pre-commit pre-commit install
-
Now, you can create and checkout your new feature branch:
git checkout -b my-cool-new-feature
-
Use pip to install TruFont in "editable" mode:
pip install --editable .
Instead of copying
trufont
to your Python site-packages directory, this command only creates a link to the source directory inside the git repository. You can then modify the code in place, or synchronize the latest upstream changes (as in step 4) without having to re-install. -
It is also recommended to regularly update the dependencies to the curently tested versions as listed in `requirements.txt`:
pip install --upgrade -r requirements.txt
-
Once you have commited your patch, push the new branch to your fork:
git push -u origin my-cool-new-feature
-
Finally, click "New pull request" on TruFont's GitHub page to submit your patch.