mirror of
https://github.com/ryanoasis/nerd-fonts.git
synced 2024-12-19 20:12:52 +02:00
f6f80995a1
See #1233 Signed-off-by: Fini Jastrow <ulf.fini.jastrow@desy.de>
99 lines
3.9 KiB
Bash
Executable File
99 lines
3.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Nerd Fonts Version: 3.0.1
|
|
# Script Version: 1.2.0
|
|
# Iterates over all patched fonts directories
|
|
# to generate release archives of the patched font(s)
|
|
#
|
|
# Example run with pattern matching:
|
|
# ./archive-fonts heavydata
|
|
# Example with same font names for different paths
|
|
# ./archive-fonts gohu
|
|
|
|
set -e
|
|
|
|
LINE_PREFIX="# [Nerd Fonts] "
|
|
root_dir="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." >/dev/null 2>&1 || exit && pwd -P)"
|
|
outputdir=${root_dir}/archives
|
|
|
|
mkdir -p "$outputdir"
|
|
|
|
cd "${root_dir}/patched-fonts/" || {
|
|
echo >&2 "$LINE_PREFIX Could not find patched fonts directory"
|
|
exit 1
|
|
}
|
|
|
|
# limit archiving to given pattern (first script param) or entire root folder if no param given:
|
|
if [ $# -eq 1 ]; then
|
|
pattern=$1
|
|
search_pattern=$1
|
|
echo "$LINE_PREFIX Limiting archive to pattern '$pattern'"
|
|
else
|
|
pattern=".*"
|
|
search_pattern=""
|
|
echo "$LINE_PREFIX No limiting pattern given, will search entire folder"
|
|
fi
|
|
|
|
# create a mini readme with basic info on Nerd Fonts project
|
|
touch "$outputdir/readme.md"
|
|
mini_readme="$outputdir/readme.md"
|
|
cat "$root_dir/src/archive-readme.md" >> "$mini_readme"
|
|
|
|
# clear out the directory
|
|
find "${outputdir:?}" -maxdepth 1 \( -name "${search_pattern}.zip" -o -name "${search_pattern}.tar.xz" \) -type f -print -delete
|
|
|
|
find . -maxdepth 1 -iregex "\./$pattern" -type d | sort |
|
|
while read -r filename; do
|
|
basename=$(basename "$filename")
|
|
searchdir=$filename
|
|
|
|
[[ -d "$outputdir" ]] || mkdir -p "$outputdir"
|
|
|
|
rm -f "${outputdir}/${basename}.tar"
|
|
expected=$(find "${searchdir}" -iname "*.[ot]tf" -exec echo "+" \; | wc -l)
|
|
echo "${LINE_PREFIX} Packing ${basename}.tar.xz (${expected} fonts)"
|
|
# This finds all files, uniq on the filename (ignoring path):
|
|
while IFS= read -d $'\0' -r descriptor; do
|
|
path=$(echo ${descriptor} | sed 's/|.*//')
|
|
file=$(echo ${descriptor} | sed 's/.*|//')
|
|
if $(echo ${file} | grep -qi '.[ot]tf'); then
|
|
expected=$((expected - 1))
|
|
fi
|
|
# Need to cd to the file because we want to archive 'flat' (without subdirs):
|
|
x=$(cd "$path" && tar rf "$outputdir/$basename.tar" --no-recursion "$file")
|
|
done < <(find "${searchdir}" -type f -exec bash -c 'printf "%s\000" "{}" | sed "s!\(.*\)/!\1|!"' \; | sort -z -u '-t|' -k2,2 | sort -z)
|
|
|
|
if [ $expected -ne 0 ]; then
|
|
# Should never happen, but who knows
|
|
echo "${LINE_PREFIX} Did not pack expected number of font files! Likely same font names for different paths."
|
|
exit 1
|
|
fi
|
|
x=$(cd "${outputdir}" && tar rf "${outputdir}/${basename}.tar" "readme.md")
|
|
xz -f -9 -T0 "${outputdir}/${basename}.tar"
|
|
|
|
# ZIP stuff:
|
|
# add font files:
|
|
# -ic (ignore case not working)
|
|
echo "${LINE_PREFIX} Packing ${basename}.zip"
|
|
zip -9 "$outputdir/$basename" -rj "$searchdir" -i '*.[ot]tf' -i '*.[OT]TF' -q
|
|
zipStatus=$?
|
|
if [ "$zipStatus" != "0" ]; then
|
|
echo "$LINE_PREFIX Could not create archive with the path junked (-j option) - likely same font names for different paths, zip status: $zipStatus"
|
|
echo "$LINE_PREFIX Retrying with full path"
|
|
# add font files and license files as full paths:
|
|
zip -9 "$outputdir/$basename" -r "$searchdir" -i '*.[ot]tf' -i '*.[OT]TF' -i '*[Ll]icen[sc]e*' -i '*LICEN[SC]E*' -i 'OFL*' -i 'ofl*' -q
|
|
else
|
|
# we can copy the font files without full paths but not necessarily the license files:
|
|
# add license files separately:
|
|
# zip -9 "$outputdir/$basename" -rj "$searchdir" -i '*license*' -i '*LICENSE*'
|
|
# work around to copy duplicate license files (only the last duplicate found)
|
|
# so we don't have to copy entire paths and can still use the junk option (-j)
|
|
find "$searchdir" -type f -iname "*licen[sc]e*" -o -iname 'ofl*' | awk -F/ '{a[$NF]=$0}END{for(i in a)print a[i]}' | zip -9 -j "$outputdir/$basename" -@
|
|
fi;
|
|
|
|
# add mini readme file
|
|
zip -9 "$outputdir/$basename" -rj "$mini_readme" -q
|
|
done
|
|
|
|
rm -f "$mini_readme"
|
|
ls -al "$outputdir"
|