diff options
author | Bruno Haible <bruno@clisp.org> | 2003-02-14 14:35:47 +0000 |
---|---|---|
committer | Bruno Haible <bruno@clisp.org> | 2009-06-23 12:09:43 +0200 |
commit | 2279100e37eb8526c501f0d044d097626bb8a500 (patch) | |
tree | ebd5e10095ba1d63d48f329cf53cb5695cccfa40 /gettext-tools/tests/format-librep-2 | |
parent | 72c5b054015fcc4beee9abbd85bc27475db36319 (diff) | |
download | external_gettext-2279100e37eb8526c501f0d044d097626bb8a500.zip external_gettext-2279100e37eb8526c501f0d044d097626bb8a500.tar.gz external_gettext-2279100e37eb8526c501f0d044d097626bb8a500.tar.bz2 |
Move tests/format-librep-2 to gettext-tools/tests/format-librep-2.
Diffstat (limited to 'gettext-tools/tests/format-librep-2')
-rwxr-xr-x | gettext-tools/tests/format-librep-2 | 151 |
1 files changed, 151 insertions, 0 deletions
diff --git a/gettext-tools/tests/format-librep-2 b/gettext-tools/tests/format-librep-2 new file mode 100755 index 0000000..05d26ab --- /dev/null +++ b/gettext-tools/tests/format-librep-2 @@ -0,0 +1,151 @@ +#! /bin/sh + +# Test checking of librep format strings. + +tmpfiles="" +trap 'rm -fr $tmpfiles' 1 2 3 15 + +tmpfiles="$tmpfiles f-lr-2.data" +cat <<\EOF > f-lr-2.data +# Valid: %% doesn't count +msgid "abc%%def" +msgstr "xyz" +# Invalid: invalid msgstr +msgid "abc%%def" +msgstr "xyz%" +# Valid: same arguments +msgid "abc%s%xdef" +msgstr "xyz%s%x" +# Valid: same arguments, with different widths +msgid "abc%2sdef" +msgstr "xyz%3s" +# Valid: same arguments but in numbered syntax +msgid "abc%s%xdef" +msgstr "xyz%1$s%2$x" +# Valid: permutation +msgid "abc%s%x%cdef" +msgstr "xyz%3$c%2$x%1$s" +# Invalid: too few arguments +msgid "abc%2$xdef%1$s" +msgstr "xyz%1$s" +# Invalid: too few arguments +msgid "abc%sdef%x" +msgstr "xyz%s" +# Invalid: too many arguments +msgid "abc%xdef" +msgstr "xyz%xvw%c" +# Valid: same numbered arguments, with different widths +msgid "abc%2$5s%1$4s" +msgstr "xyz%2$4s%1$5s" +# Invalid: missing argument +msgid "abc%2$sdef%1$x" +msgstr "xyz%1$x" +# Invalid: missing argument +msgid "abc%1$sdef%2$x" +msgstr "xyz%2$x" +# Invalid: added argument +msgid "abc%1$xdef" +msgstr "xyz%1$xvw%2$c" +# Valid: type compatibility +msgid "abc%d" +msgstr "xyz%x" +# Valid: type compatibility +msgid "abc%d" +msgstr "xyz%X" +# Valid: type compatibility +msgid "abc%d" +msgstr "xyz%o" +# Valid: type compatibility +msgid "abc%x" +msgstr "xyz%X" +# Valid: type compatibility +msgid "abc%x" +msgstr "xyz%o" +# Valid: type compatibility +msgid "abc%X" +msgstr "xyz%o" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%d" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%x" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%X" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%o" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%s" +# Invalid: type incompatibility +msgid "abc%c" +msgstr "xyz%S" +# Invalid: type incompatibility +msgid "abc%d" +msgstr "xyz%s" +# Invalid: type incompatibility +msgid "abc%d" +msgstr "xyz%S" +# Invalid: type incompatibility +msgid "abc%x" +msgstr "xyz%s" +# Invalid: type incompatibility +msgid "abc%x" +msgstr "xyz%S" +# Invalid: type incompatibility +msgid "abc%X" +msgstr "xyz%s" +# Invalid: type incompatibility +msgid "abc%X" +msgstr "xyz%S" +# Invalid: type incompatibility +msgid "abc%o" +msgstr "xyz%s" +# Invalid: type incompatibility +msgid "abc%o" +msgstr "xyz%S" +# Invalid: type incompatibility +msgid "abc%s" +msgstr "xyz%S" +EOF + +: ${MSGFMT=msgfmt} +n=0 +while read comment; do + read msgid_line + read msgstr_line + n=`expr $n + 1` + tmpfiles="$tmpfiles f-lr-2-$n.po f-lr-2-$n.mo" + cat <<EOF > f-lr-2-$n.po +#, librep-format +${msgid_line} +${msgstr_line} +EOF + fail= + if echo "$comment" | grep 'Valid:' > /dev/null; then + if ${MSGFMT} --check-format -o f-lr-2-$n.mo f-lr-2-$n.po; then + : + else + fail=yes + fi + else + ${MSGFMT} --check-format -o f-lr-2-$n.mo f-lr-2-$n.po 2> /dev/null + if test $? = 1; then + : + else + fail=yes + fi + fi + if test -n "$fail"; then + echo "Format string checking error:" 1>&2 + cat f-lr-2-$n.po 1>&2 + exit 1 + fi + rm -f f-lr-2-$n.po f-lr-2-$n.mo +done < f-lr-2.data + +rm -fr $tmpfiles + +exit 0 |