779c8d0a78
Not create community languages with `lang-build.sh all` the `lang-community.sh` will call it. Add templates for future community languages
150 lines
4.4 KiB
Bash
Executable File
150 lines
4.4 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# lang-build.sh - multi-language support script
|
|
# generate lang_xx.bin (language binary file)
|
|
#
|
|
# Input files:
|
|
# lang_en.txt or lang_en_xx.txt
|
|
#
|
|
# Output files:
|
|
# lang_xx.bin
|
|
#
|
|
# Temporary files:
|
|
# lang_xx.tmp
|
|
# lang_xx.dat
|
|
#
|
|
|
|
#awk code to format ui16 variables for dd
|
|
awk_ui16='{ h=int($1/256); printf("\\x%02x\\x%02x\n", int($1-256*h), h); }'
|
|
|
|
#startup message
|
|
echo "lang-build.sh started" >&2
|
|
|
|
#exiting function
|
|
finish()
|
|
{
|
|
if [ $1 -eq 0 ]; then
|
|
echo "lang-build.sh finished with success" >&2
|
|
else
|
|
echo "lang-build.sh finished with errors!" >&2
|
|
fi
|
|
exit $1
|
|
}
|
|
|
|
#returns hexadecial data for lang code
|
|
lang_code_hex_data()
|
|
# $1 - language code ('en', 'cz'...)
|
|
{
|
|
case "$1" in
|
|
*en*) echo '\x6e\x65' ;;
|
|
*cz*) echo '\x73\x63' ;;
|
|
*de*) echo '\x65\x64' ;;
|
|
*es*) echo '\x73\x65' ;;
|
|
*fr*) echo '\x72\x66' ;;
|
|
*it*) echo '\x74\x69' ;;
|
|
*pl*) echo '\x6c\x70' ;;
|
|
#Community language support
|
|
#Dutch
|
|
*nl*) echo '\x6c\x6e' ;;
|
|
#Use the 2 lines below as a template and replace 'qr' and `\x71\x72`
|
|
##New language
|
|
# *qr*) echo '\x71\x72' ;;
|
|
esac
|
|
echo '??'
|
|
}
|
|
|
|
write_header()
|
|
# $1 - lang
|
|
# $2 - size
|
|
# $3 - count
|
|
# $4 - checksum
|
|
# $5 - signature
|
|
{
|
|
/bin/echo -n -e "\xa5\x5a\xb4\x4b" |\
|
|
dd of=lang_$1.bin bs=1 count=4 seek=0 conv=notrunc 2>/dev/null
|
|
/bin/echo -n -e $(echo -n "$(($2))" | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=4 conv=notrunc 2>/dev/null
|
|
/bin/echo -n -e $(echo -n "$(($3))" | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=6 conv=notrunc 2>/dev/null
|
|
/bin/echo -n -e $(echo -n "$(($4))" | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=8 conv=notrunc 2>/dev/null
|
|
/bin/echo -n -e "$(lang_code_hex_data $1)" |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=10 conv=notrunc 2>/dev/null
|
|
sig_h=$(($5 / 65536))
|
|
/bin/echo -n -e $(echo -n "$sig_h" | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=14 conv=notrunc 2>/dev/null
|
|
sig_l=$(($5 - $sig_h * 65536))
|
|
/bin/echo -n -e $(echo -n "$sig_l" | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=12 conv=notrunc 2>/dev/null
|
|
}
|
|
|
|
generate_binary()
|
|
# $1 - language code ('en', 'cz'...)
|
|
{
|
|
echo "lang="$1 >&2
|
|
#remove output and temporary files
|
|
rm -f lang_$1.bin
|
|
rm -f lang_$1.tmp
|
|
rm -f lang_$1.dat
|
|
LNG=$1
|
|
#check lang dictionary
|
|
./lang-check.py $1 --no-warning
|
|
#create lang_xx.tmp - different processing for 'en' language
|
|
if [ "$1" = "en" ]; then
|
|
#remove comments and empty lines
|
|
cat lang_en.txt | sed '/^$/d;/^#/d'
|
|
else
|
|
#remove comments and empty lines, print lines with translated text only
|
|
cat lang_en_$1.txt | sed '/^$/d;/^#/d' | sed -n 'n;p'
|
|
fi | sed 's/^\"\\x00\"$/\"\"/' > lang_$1.tmp
|
|
#create lang_xx.dat (binary text data file)
|
|
# cat lang_$1.tmp | sed 's/^\"/\/bin\/echo -e \"/;s/"$/\\x00\"/' > lang_$1.shx
|
|
cat lang_$1.tmp | sed 's/^\"/\/bin\/echo -e -n \"/;s/"$/\\x00\"/' | sh >lang_$1.dat
|
|
#calculate number of strings
|
|
count=$(grep -c '^"' lang_$1.tmp)
|
|
echo "count="$count >&2
|
|
#calculate text data offset
|
|
offs=$((16 + 2 * $count))
|
|
echo "offs="$offs >&2
|
|
#calculate text data size
|
|
size=$(($offs + $(wc -c lang_$1.dat | cut -f1 -d' ')))
|
|
echo "size="$size >&2
|
|
#write header with empty signature and checksum
|
|
write_header $1 $size $count 0x0000 0x00000000
|
|
#write offset table
|
|
offs_hex=$(cat lang_$1.tmp | sed 's/^\"//;s/\"$//' |\
|
|
sed 's/\\x[0-9a-f][0-9a-f]/\./g;s/\\[0-7][0-7][0-7]/\./g;s/\ /\./g' |\
|
|
awk 'BEGIN { o='$offs';} { h=int(o/256); printf("\\x%02x\\x%02x",int(o-256*h), h); o+=(length($0)+1); }')
|
|
/bin/echo -n -e "$offs_hex" | dd of=./lang_$1.bin bs=1 seek=16 conv=notrunc 2>/dev/null
|
|
#write binary text data
|
|
dd if=./lang_$1.dat of=./lang_$1.bin bs=1 seek=$offs conv=notrunc 2>/dev/null
|
|
#write signature
|
|
if [ "$1" != "en" ]; then
|
|
dd if=lang_en.bin of=lang_$1.bin bs=1 count=4 skip=6 seek=12 conv=notrunc 2>/dev/null
|
|
fi
|
|
#calculate and update checksum
|
|
chsum=$(cat lang_$1.bin | xxd | cut -c11-49 | tr ' ' "\n" | sed '/^$/d' | awk 'BEGIN { sum = 0; } { sum += strtonum("0x"$1); if (sum > 0xffff) sum -= 0x10000; } END { printf("%x\n", sum); }')
|
|
/bin/echo -n -e $(echo -n $((0x$chsum)) | awk "$awk_ui16") |\
|
|
dd of=lang_$1.bin bs=1 count=2 seek=8 conv=notrunc 2>/dev/null
|
|
#remove temporary files
|
|
# rm -f lang_$1.tmp
|
|
# rm -f lang_$1.dat
|
|
}
|
|
|
|
if [ -z "$1" ]; then set 'all'; fi
|
|
|
|
if [ "$1" = "all" ]; then
|
|
generate_binary 'en'
|
|
generate_binary 'cz'
|
|
generate_binary 'de'
|
|
generate_binary 'es'
|
|
generate_binary 'fr'
|
|
generate_binary 'it'
|
|
generate_binary 'pl'
|
|
#DO NOT add Community languages here
|
|
else
|
|
generate_binary $1
|
|
fi
|
|
|
|
finish 0
|