X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/xfonts-traditional/blobdiff_plain/15fc3ba19faec7f483788f208af4df66579104f9..fe6a7d791ffe20cb0cf74a22e2c024dc6319574e:/mkrules diff --git a/mkrules b/mkrules index 734e2a2..b55b397 100755 --- a/mkrules +++ b/mkrules @@ -6,12 +6,26 @@ rm -f rules/*.rules rules/foundries.new chars () { for c in $rest; do - ord=`perl -e 'print ord($ARGV[0]),"\n" or die $!' "$c"` + case " $c " in + " "?" ") + ord=`perl -e 'print ord($ARGV[0]),"\n" or die $!' "$c"` + ;; + " "d?*" ") + ord="${c#d}" + c=`perl -e 'printf "%c", $ARGV[0]' "$ord"` + ;; + *) + echo >&2 "??? $c" + exit 1 + ;; + esac ./printrule >&3 "$bad" "$good" $height \ "^ENCODING $ord$" $partial "$c" done } +seenrules=/ + while read keyword rest; do case "$keyword" in '#'|'') continue ;; @@ -41,13 +55,21 @@ while read keyword rest; do exit; ' <$good` printf "%s %s" "$oldfoundry" "$newfoundry" >>rules/foundries.new - exec 3>rules/$newfoundry,$key.rules - echo >&3 '# -*- perl -*-' - echo >&3 '# autogenerated by mkrules' - echo >&3 'sub {' + case "$seenrules" in + */"$newfoundry,$key"/*) + exec 3>>rules/$newfoundry,$key.rules + ;; + *) + exec 3>rules/$newfoundry,$key.rules + echo >&3 '# -*- perl -*-' + echo >&3 '# autogenerated by mkrules' + echo >&3 'sub {' + seenrules=$seenrules$newfoundry,$key/ + ;; + esac + echo >&3 " # $pcf" ;; endrules) - echo >&3 '}' exec 3&3 " $rest" + ;; *) echo >&2 "??? $keyword" exit 1 @@ -65,4 +90,12 @@ while read keyword rest; do esac done +while :; do + case "$seenrules" in /) break ;; esac + seenrules=${seenrules#/} + rulefile=${seenrules%%/*} + seenrules=/${seenrules#*/} + echo "}" >>rules/$rulefile.rules +done + mv rules/foundries.new rules/foundries