| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | 
							- #!/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' ;;
 
-  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
 
-  #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 'it'
 
-  generate_binary 'pl'
 
- else
 
-  generate_binary $1
 
- fi
 
- finish 0
 
 
  |