summaryrefslogtreecommitdiffstats
path: root/gettext-tools/tests/lang-python-1
diff options
context:
space:
mode:
authorBruno Haible <bruno@clisp.org>2003-02-24 10:46:33 +0000
committerBruno Haible <bruno@clisp.org>2009-06-23 12:10:14 +0200
commit5c394fdf836f8368d17399f03e3d9a89a19e786d (patch)
tree71160eb6aa077fb73ca55f88c27b8c4088a10b9f /gettext-tools/tests/lang-python-1
parentbbb04b62b3ddfabd30cf4c489b9ba6bd0b034061 (diff)
downloadexternal_gettext-5c394fdf836f8368d17399f03e3d9a89a19e786d.zip
external_gettext-5c394fdf836f8368d17399f03e3d9a89a19e786d.tar.gz
external_gettext-5c394fdf836f8368d17399f03e3d9a89a19e786d.tar.bz2
Move lang-python to lang-python-1.
Diffstat (limited to 'gettext-tools/tests/lang-python-1')
-rwxr-xr-xgettext-tools/tests/lang-python-187
1 files changed, 87 insertions, 0 deletions
diff --git a/gettext-tools/tests/lang-python-1 b/gettext-tools/tests/lang-python-1
new file mode 100755
index 0000000..460c1ac
--- /dev/null
+++ b/gettext-tools/tests/lang-python-1
@@ -0,0 +1,87 @@
+#! /bin/sh
+
+# Test of gettext facilities in the Python language.
+
+tmpfiles=""
+trap 'rm -fr $tmpfiles' 1 2 3 15
+
+tmpfiles="$tmpfiles prog.py"
+cat <<\EOF > prog.py
+import gettext
+
+gettext.textdomain('prog')
+gettext.bindtextdomain('prog', '.')
+
+print gettext.gettext("'Your command, please?', asked the waiter.")
+print gettext.gettext("%(oldCurrency)s is replaced by %(newCurrency)s.") \
+ % { 'oldCurrency': "FF", 'newCurrency' : "EUR" }
+EOF
+
+tmpfiles="$tmpfiles prog.pot"
+: ${XGETTEXT=xgettext}
+${XGETTEXT} -o prog.pot --omit-header --no-location prog.py
+
+tmpfiles="$tmpfiles prog.ok"
+cat <<EOF > prog.ok
+msgid "'Your command, please?', asked the waiter."
+msgstr ""
+
+#, python-format
+msgid "%(oldCurrency)s is replaced by %(newCurrency)s."
+msgstr ""
+EOF
+
+: ${DIFF=diff}
+${DIFF} prog.ok prog.pot || exit 1
+
+tmpfiles="$tmpfiles fr.po"
+cat <<\EOF > fr.po
+msgid ""
+msgstr ""
+"Content-Type: text/plain; charset=ISO-8859-1\n"
+"Plural-Forms: nplurals=2; plural=(n > 1);\n"
+
+msgid "'Your command, please?', asked the waiter."
+msgstr "«Votre commande, s'il vous plait», dit le garçon."
+
+# Reverse the arguments.
+#, python-format
+msgid "%(oldCurrency)s is replaced by %(newCurrency)s."
+msgstr "%(newCurrency)s remplace %(oldCurrency)s."
+EOF
+
+tmpfiles="$tmpfiles fr.po.new"
+: ${MSGMERGE=msgmerge}
+${MSGMERGE} -q -o fr.po.new fr.po prog.pot
+
+: ${DIFF=diff}
+${DIFF} fr.po fr.po.new || exit 1
+
+tmpfiles="$tmpfiles fr"
+test -d fr || mkdir fr
+test -d fr/LC_MESSAGES || mkdir fr/LC_MESSAGES
+
+: ${MSGFMT=msgfmt}
+${MSGFMT} -o fr/LC_MESSAGES/prog.mo fr.po
+
+# Test for presence of python version 2.0 or newer.
+(python -V) >/dev/null 2>/dev/null \
+ || { rm -fr $tmpfiles; exit 77; }
+case `python -c 'import sys; print sys.hexversion >= 0x20000F0'` in
+ 1) ;;
+ *) rm -fr $tmpfiles; exit 77;;
+esac
+
+tmpfiles="$tmpfiles prog.ok prog.out"
+: ${DIFF=diff}
+cat <<\EOF > prog.ok
+«Votre commande, s'il vous plait», dit le garçon.
+EUR remplace FF.
+EOF
+
+LANGUAGE= LC_ALL=fr_FR python prog.py > prog.out || exit 1
+${DIFF} prog.ok prog.out || exit 1
+
+rm -fr $tmpfiles
+
+exit 0