Add script to pull+squash from weblate. Fixes #140
This commit is contained in:
parent
4fb173e364
commit
7440cf1b74
41
tools/pull-trans.sh
Executable file
41
tools/pull-trans.sh
Executable file
@ -0,0 +1,41 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# This script pulls translations from weblate.
|
||||||
|
#
|
||||||
|
# It squashes all the changes into a single commit. This removes authorship
|
||||||
|
# from the changes, which is given to the Translatebot, so to keep the names
|
||||||
|
# they are grabbed from git log and added to the commit message.
|
||||||
|
#
|
||||||
|
# Note that this will apply changes and commit them! Make sure to not have
|
||||||
|
# uncommited changes when running this script.
|
||||||
|
|
||||||
|
REMOTE="weblate"
|
||||||
|
REMOTE_URL="git://git.weblate.org/f-droid.git"
|
||||||
|
REMOTE_BRANCH="master"
|
||||||
|
|
||||||
|
AUTHOR="F-Droid Translatebot <admin@f-droid.org>"
|
||||||
|
|
||||||
|
if ! git ls-remote --exit-code $REMOTE >/dev/null 2>/dev/null; then
|
||||||
|
echo "Remote doesn't exist! Try the following:"
|
||||||
|
echo " git remote add $REMOTE $REMOTE_URL"
|
||||||
|
echo " git fetch $REMOTE"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
files=$(find . -wholename '*/values-*/strings.xml')
|
||||||
|
|
||||||
|
ref="${REMOTE}/${REMOTE_BRANCH}"
|
||||||
|
diff="HEAD..$ref -- $files"
|
||||||
|
|
||||||
|
authors=$(git log --format="%s %an" $diff | \
|
||||||
|
sed 's/Translated using Weblate (\(.*\)) \(.*\)/\2||\1/' | sort -f -u | column -s '||' -t)
|
||||||
|
|
||||||
|
git diff $diff | git apply
|
||||||
|
|
||||||
|
git add $files
|
||||||
|
|
||||||
|
git commit --author "$AUTHOR" -m "Pull translation updates from weblate
|
||||||
|
|
||||||
|
Translators:
|
||||||
|
|
||||||
|
$authors"
|
Loading…
x
Reference in New Issue
Block a user