123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- #!/usr/bin/env bash
- langname() {
- case "$1" in
- an ) echo "Aragonese" ;; bg ) echo "Bulgarian" ;;
- ca ) echo "Catalan" ;; cz ) echo "Czech" ;;
- da ) echo "Danish" ;; de ) echo "German" ;;
- el ) echo "Greek" ;; el_CY ) echo "Greek (Cyprus)" ;;
- el_gr) echo "Greek (Greece)" ;; en ) echo "English" ;;
- es ) echo "Spanish" ;; eu ) echo "Basque-Euskera" ;;
- fi ) echo "Finnish" ;; fr ) echo "French" ;;
- fr_na) echo "French (no accent)" ;; gl ) echo "Galician" ;;
- hr ) echo "Croatian (Hrvatski)" ;; hu ) echo "Hungarian / Magyar" ;;
- it ) echo "Italian" ;; jp_kana) echo "Japanese (Kana)" ;;
- ko_KR) echo "Korean" ;; nl ) echo "Dutch" ;;
- pl ) echo "Polish" ;; pt ) echo "Portuguese" ;;
- pt_br) echo "Portuguese (Brazil)" ;; ro ) echo "Romanian" ;;
- ru ) echo "Russian" ;; sk ) echo "Slovak" ;;
- sv ) echo "Swedish" ;; tr ) echo "Turkish" ;;
- uk ) echo "Ukrainian" ;; vi ) echo "Vietnamese" ;;
- zh_CN) echo "Simplified Chinese" ;; zh_TW ) echo "Traditional Chinese" ;;
- * ) echo "<unknown>" ;;
- esac
- }
- LANGHOME="Marlin/src/lcd/language"
- [ -d $LANGHOME ] && cd $LANGHOME
- FILES=$(ls language_*.h | grep -v -E "(_en|_test)\.h" | sed -E 's/language_([^\.]+)\.h/\1/' | tr '\n' ' ')
- TEST_LANGS=""
- if [[ -n $@ ]]; then
- for K in "$@"; do
- for F in $FILES; do
- [[ $F == $K ]] && TEST_LANGS+="$F "
- done
- done
- [[ -z $TEST_LANGS ]] && { echo "No languages matching $@." ; exit 0 ; }
- else
- TEST_LANGS=$FILES
- fi
- echo "Finding all missing strings for $TEST_LANGS..."
- WORD_LINES=()
- ALL_MISSING=()
- WORD_COUNT=0
- for WORD in $(awk '/LSTR/{print $2}' language_en.h); do
-
- [[ $WORD == "MSG_MARLIN" ]] && break
- ((WORD_COUNT++))
-
- LANG_MISSING=" "
- for LANG in $TEST_LANGS; do
- if [[ $(grep -c -E "^ *LSTR +$WORD\b" language_${LANG}.h) -eq 0 ]]; then
- INHERIT=$(awk '/using namespace/{print $3}' language_${LANG}.h | sed -E 's/Language_([a-zA-Z_]+)\s*;/\1/')
- if [[ -z $INHERIT || $INHERIT == "en" ]]; then
- LANG_MISSING+="$LANG "
- elif [[ $(grep -c -E "^ *LSTR +$WORD\b" language_${INHERIT}.h) -eq 0 ]]; then
- LANG_MISSING+="$LANG "
- fi
- fi
- done
-
- if [[ $LANG_MISSING != " " ]]; then
- WORD_LINES+=("$(grep -m 1 -E "$WORD\b" language_en.h)")
- ALL_MISSING+=("$LANG_MISSING")
-
- fi
- done
- echo
- echo "${#WORD_LINES[@]} out of $WORD_COUNT LCD strings need translation"
- for LANG in $TEST_LANGS; do
- HED=0 ; IND=0
- for WORDLANGS in "${ALL_MISSING[@]}"; do
-
- if [[ $WORDLANGS =~ " $LANG " ]]; then
- [[ $HED == 0 ]] && { echo ; echo "Missing strings for language_$LANG.h ($(langname $LANG)):" ; HED=1 ; }
- echo "${WORD_LINES[$IND]}"
- fi
- ((IND++))
- done
- done
|