mirror of
https://github.com/ryanoasis/nerd-fonts.git
synced 2025-01-19 03:12:07 +02:00
cc2b547703
[why] When the CI triggers a rebuild of the original-source and the font contents is unchanged we do not want to commit the new version back to the repo. But because fontforge puts the creation date into the font file it will always differ on every run, and we would needlessly create commits. [how] We could use the SOURCE_DATE_EPOCH approach and set the dates to the relevant change (commit) times like so: cd src/svgs export SOURCE_DATE_EPOCH="$(git log -1 --format=%ct -- *.svg)" and only afterwards call the generator script / fontforge. But that would need a complete git repo checkout and not just a shallow one (which is faster and thus is used by github action/checkout). Instead we can instruct fontforge to not put any timestamp into the file. The timestamps are anyhow a fontforge proprietary extension. Signed-off-by: Fini Jastrow <ulf.fini.jastrow@desy.de>
Contents
Note: Usually you need to call the scripts in this directory while actually being in this directory (i.e. pwd = .../nerd-fonts/bin/scripts
).
archive-font-patcher.sh
: Archives the font patcher script and subscripts and the required source glyph files [1]archive-fonts.sh
: Creates the release zip file of one or more font(s) from existingpatched-fonts/
content [1]data/
: Contains plain text files used to generate the CSS and cheat sheet filesdata/sankey/
: Contains instructions on how to create the sankey glyph table manually [3]docker-entrypoint.sh
: This script is packaged into the docker container and is usually used to start patching [2]fpfix.py
: Can be used to set isFixedPitch property in a font [x]generate-casks.sh
: Generates cask files for fonts from data inpatched-fonts/
andarchives/
, unused and not recommended by homebrew-fontsgenerate-css.sh
: Generates the Nerd Fonts CCS, which can be used to access the glyphs on a web page [1]generate-fontconfig.sh
: Generates font configuration to enable use of unpatched fonts with Symbols Only Nerd Font [1]generate-font-image-previews.sh
: Generates the preview images fornerdfonts.com
(i.e. gh-pages) [3]generate-glyph-info-from-set.py
: Generate thei_xxx.sh
file from a glyph source (font) file, if the glyphs are named correctly [4]generate-original-source.py
: Generateoriginal-source.otf
from single glyph svgs. [3]get-font-names-from-json.sh
: Helper to setup the CI font matrix fromdata/fonts.json
[1]gotta-patch-em-all-font-patcher!.sh
: Patch one or more fonts 'complete' with and withoutmono
and with and withoutwindows compat
[1]Hack/
: Special additional post patching script for Hack, invoked via Hack'sconfig.cfg
(not used when self-patching)lib/
: See its own READMEname_parser/
: Suite to set up sane Family and SubFamily names, used byfont-patcher
(on demand)release.sh
: Rough process how a release is created, not used (see.github/workflows/release.yml
)standardize-and-complete-readmes.sh
[1]test-fonts.sh
: Print-to-debug all glyphs we patch in [4]test-powerlines.sh
: Print-to-debug powerline examples [4]tests.sh
: Create some font usage gif movie? [x]update-all-contributors-website.py
: Update the contributors page onnerdfonts.com
(i.e. gh-pages) (Hardcoded paths!) [3]version-bump.sh
: Change version number in all scripts on a new release [1]
[1] Used by CI (github release workflow) [2] Used by CI (github docker-release workflow) [3] To be used manually (sigh) [4] To be used manually [x] Probably not used by anything