#!/bin/bash
-tx pull $* &&
-git add po/*.po && (
+tx pull -a $* > /dev/null &&
+for po in po/*.po; do
+ basename "${po%.po}"
+done | sort > po/LINGUAS &&
+git add po/*.po po/LINGUAS && (
translators=$(while read mode pofile; do
- translator=$(git diff --cached -- ${pofile} | perl -le 'while (<>) { if (/^\+(?:#|.*?:) *(.*?)(<[^@>]+@[^>]+>)/p) { $xltrs{$2} = $1 unless $xltrs{$2}; } last if /^\+"Last-Translator: /; }; push(@out, $n.$e) while (($e, $n) = each %xltrs); print(join(", ", @out));')
+ translator=$(git diff --cached -- ${pofile} | perl -le '
+ while (<>) {
+ if (/^(?:\+(?:#|.*?:)|[ +]"Last-Translator:) *(.*?)(<[^@>]+@[^>]+>)/p) {
+ $xltrs{$2} = $1 unless $xltrs{$2};
+ last if $& =~ /Last-Translator:/;
+ }
+ }
+ push(@out, $n.$e) while (($e, $n) = each %xltrs);
+ print(join(", ", @out));
+ ')
lang=${pofile%.po}
lang=${lang#po/}
echo " - ${lang}: ${translator}"
git commit -em "Update translations from Transifex
+ $(for i in po/*.po; do
+ msgfmt --statistics $i
+ done |&
+ perl -ne '/([0-9]+) translated/ and $translated+=$1;
+ END { printf("%d translated messages", $translated); }'
+ )
+
Many thanks to:
-${translators}" po/*.po
+${translators}"
)