X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=util%2Frun_xgettext.sh;h=8ecfec9446d70df9f6f83a1e848a5f307da5f431;hb=3ccff0c77f563e09efdb705cdbe1d513f4d105a4;hp=6ea603c83c312ae4433e341eb1d08437be7a219a;hpb=aaf5a81365b4cbcb3d1b9537b5544aeb5de66f4b;p=friendica.git diff --git a/util/run_xgettext.sh b/util/run_xgettext.sh old mode 100644 new mode 100755 index 6ea603c83c..8ecfec9446 --- a/util/run_xgettext.sh +++ b/util/run_xgettext.sh @@ -1,37 +1,101 @@ #!/bin/bash - FULLPATH=$(dirname $(readlink -f "$0")) -cd "$FULLPATH/../view/en/" -F9KVERSION=$(sed -n "s/.*'FRIENDICA_VERSION'.*'\([0-9.]*\)'.*/\1/p" ../../boot.php); +if [ "$1" == "--help" -o "$1" == "-h" ] +then + echo "$(basename $(readlink -f "$0")) [options]" + echo + echo "-a | --addon extract strings from addon 'name'" + echo "-s | --single single addon mode: extract string from current folder" + exit +fi -echo "Friendica version $F9KVERSION" +MODE='default' +ADDONNAME= +if [ "$1" == "--addon" -o "$1" == "-a" ] +then + MODE='addon' + if [ -z $2 ]; then echo -e "ERROR: missing addon name\n\nrun_xgettext.sh -a "; exit 1; fi + ADDONNAME=$2 + if [ ! -d "$FULLPATH/../addon/$ADDONNAME" ]; then echo "ERROR: addon '$ADDONNAME' not found"; exit 2; fi +fi -OPTS= -OUTFILE="$FULLPATH/messages.po" -if [ "" != "$1" ] +if [ "$1" == "--single" -o "$1" == "-s" ] then - OUTFILE="$(readlink -f ${FULLPATH}/$1)" - if [ -e "$OUTFILE" ] - then - echo "join extracted strings" - OPTS="-j" - fi + MODE='single' fi + +case "$MODE" in + 'addon') + cd "$FULLPATH/../addon/$ADDONNAME" + mkdir -p "$FULLPATH/../addon/$ADDONNAME/lang/C" + OUTFILE="$FULLPATH/../addon/$ADDONNAME/lang/C/messages.po" + FINDSTARTDIR="." + FINDOPTS= + ;; + 'single') + FULLPATH=$PWD + ADDONNAME=$(basename $FULLPATH) + mkdir -p "$FULLPATH/lang/C" + OUTFILE="$FULLPATH/lang/C/messages.po" + FINDSTARTDIR="." + FINDOPTS= + echo "Extract strings for single addon '$ADDONNAME'" + ;; + 'default') + cd "$FULLPATH/.." + OUTFILE="$FULLPATH/messages.po" + FINDSTARTDIR="." + # skip addon folder + FINDOPTS="( -wholename */addon -or -wholename */smarty3 ) -prune -o" + + F9KVERSION=$(sed -n "s/.*'FRIENDICA_VERSION'.*'\([0-9.]*\)'.*/\1/p" ./boot.php); + echo "Friendica version $F9KVERSION" + ;; +esac + + KEYWORDS="-k -kt -ktt:1,2" echo "extract strings to $OUTFILE.." -find ../../ -name "*.php" | xargs xgettext $KEYWORDS $OPTS -o "$OUTFILE" --from-code=UTF-8 +rm "$OUTFILE"; touch "$OUTFILE" +for f in $(find "$FINDSTARTDIR" $FINDOPTS -name "*.php" -type f) +do + if [ ! -d "$f" ] + then + xgettext $KEYWORDS -j -o "$OUTFILE" --from-code=UTF-8 "$f" + sed -i "s/CHARSET/UTF-8/g" "$OUTFILE" + fi +done echo "setup base info.." -sed -i "s/SOME DESCRIPTIVE TITLE./FRIENDICA Distributed Social Network/g" "$OUTFILE" -sed -i "s/YEAR THE PACKAGE'S COPYRIGHT HOLDER/2010, 2011 the Friendica Project/g" "$OUTFILE" -sed -i "s/FIRST AUTHOR , YEAR./Mike Macgirvin, 2010/g" "$OUTFILE" -sed -i "s/PACKAGE VERSION/$F9KVERSION/g" "$OUTFILE" -sed -i "s/PACKAGE/Friendica/g" "$OUTFILE" -sed -i "s/CHARSET/UTF-8/g" "$OUTFILE" -sed -i "s/^\"Plural-Forms/#\"Plural-Forms/g" "$OUTFILE" +case "$MODE" in + 'addon'|'single') + sed -i "s/SOME DESCRIPTIVE TITLE./ADDON $ADDONNAME/g" "$OUTFILE" + sed -i "s/YEAR THE PACKAGE'S COPYRIGHT HOLDER//g" "$OUTFILE" + sed -i "s/FIRST AUTHOR , YEAR.//g" "$OUTFILE" + sed -i "s/PACKAGE VERSION//g" "$OUTFILE" + sed -i "s/PACKAGE/Friendica $ADDONNAME addon/g" "$OUTFILE" + sed -i "s/CHARSET/UTF-8/g" "$OUTFILE" + sed -i "s/^\"Plural-Forms.*$//g" "$OUTFILE" + ;; + 'default') + sed -i "s/SOME DESCRIPTIVE TITLE./FRIENDICA Distributed Social Network/g" "$OUTFILE" + sed -i "s/YEAR THE PACKAGE'S COPYRIGHT HOLDER/2010, 2011, 2012, 2013 the Friendica Project/g" "$OUTFILE" + sed -i "s/FIRST AUTHOR , YEAR./Mike Macgirvin, 2010/g" "$OUTFILE" + sed -i "s/PACKAGE VERSION/$F9KVERSION/g" "$OUTFILE" + sed -i "s/PACKAGE/Friendica/g" "$OUTFILE" + sed -i "s/CHARSET/UTF-8/g" "$OUTFILE" + sed -i "s/^\"Plural-Forms.*$//g" "$OUTFILE" + ;; +esac +if [ "" != "$1" -a "$MODE" == "default" ] +then + UPDATEFILE="$(readlink -f ${FULLPATH}/$1)" + echo "merging new strings to $UPDATEFILE.." + msgmerge -U $OUTFILE $UPDATEFILE +fi echo "done."