From 46d2ce085ea47f7f9b86ec74858c6cc1317b04a6 Mon Sep 17 00:00:00 2001 From: Pierre-Yves Rollo Date: Tue, 19 Dec 2017 21:52:49 +0100 Subject: Multiple fonts and UTF chars support --- font_lib/tools/make_font_lua.sh | 48 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100755 font_lib/tools/make_font_lua.sh (limited to 'font_lib/tools') diff --git a/font_lib/tools/make_font_lua.sh b/font_lib/tools/make_font_lua.sh new file mode 100755 index 0000000..b751612 --- /dev/null +++ b/font_lib/tools/make_font_lua.sh @@ -0,0 +1,48 @@ +#!/bin/bash + +scriptname=$0 +identify="identify" + +font_name=default + +for f in textures/font_${font_name}_????.png +do + if [[ $f =~ textures/font_${font_name}_([0-9a-fA-F]{4}).png ]] + then + code=$((16#${BASH_REMATCH[1]})) + size=$(identify $f | cut -d " " -f 3) + w=$(echo $size | cut -d "x" -f 1) + h=$(echo $size | cut -d "x" -f 2) + + if [ -z "$font_height" ] + then + font_height=$h + else + if [ $font_height -ne $h ] + then + echo "Error : $f as height of $h pixels, previous textures have a height of $font_height pixels. All textures should have the same height." + fi + fi + + if [ -z "$font_widths" ] + then + font_widths="[$code]=$w" + else + font_widths="$font_widths, [$code]=$w" + fi + fi +done + +echo "--[[ + +$luafile generated by $scriptname $(date) + +--]] + +font_lib.register_font( + '$font_name', + $font_height, + { $font_widths } +); +" > font_$font_name.lua + -- cgit v1.2.3