X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fxonotic-data.pk3dir.git;a=blobdiff_plain;f=check-translations.sh;h=facee4a7bc8fc4d49fe5d2f2089ed56d4c227037;hp=307c3c2c147822be83d04f39d3b707a0104c4a91;hb=3ae1efa7401791e42e3171f4db2cc2d38adde088;hpb=b7d32c1f333da63877913b30c861230243ce1213 diff --git a/check-translations.sh b/check-translations.sh index 307c3c2c14..facee4a7bc 100755 --- a/check-translations.sh +++ b/check-translations.sh @@ -5,6 +5,10 @@ case "$1" in mode=pot mail=false ;; + txt) + mode=txt + mail=false + ;; po) mode=po mail=true @@ -30,6 +34,46 @@ if [ x"$mode" = x"pot" ]; then } | xgettext -LC -k_ -f- --from-code utf-8 -F -o common.pot >&2 fi +if [ x"$mode" = x"txt" ]; then + { + echo "en English \"English\"" + for X in common.*.po; do + [ -f "$X" ] || continue + if [ -n "$language" ]; then + if [ x"${X#common.}" != x"$language.po" ]; then + continue + fi + else + if [ x"${X#common.}" = x"en.po" ]; then + continue + fi + fi + po=`msgmerge -N "$X" common.pot` + ne=`printf "%s\n" "$po" | msgfmt -o /dev/null --check-format --check-header --use-fuzzy - 2>&1 | grep . | wc -l` + nu=`printf "%s\n" "$po" | msgattrib --untranslated - | grep -c ^#:` + nf=`printf "%s\n" "$po" | msgattrib --fuzzy - | grep -c ^#:` + nt=`printf "%s\n" "$po" | grep -c ^#:` + n=$(($ne + $nu + $nf)) + p=$(( (nt - n) * 100 / nt )) + echo >&2 "TODO for translation $X:" + echo >&2 "Errors: $ne" + echo >&2 "Untranslated: $nu" + echo >&2 "Fuzzy: $nf" + echo >&2 "Total: $nt" + echo >&2 "Percent: $p" + l=${X#common.} + l=${l%.po} + if ! item=`grep "^$l " languages.txt`; then + if [ "$p" -lt 50 ]; then + continue + fi + item="$l $l \"$l (0%)\"" + fi + printf "%s\n" "$item" | sed -e "s/([0-9][0-9]*%)/($p%)/" + done + } | tr '"' '\t' | sort -k3 | tr '\t' '"' +fi + if [ x"$mode" = x"po" ]; then for X in common.*.po; do [ -f "$X" ] || continue