diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2014-12-24 07:38:37 +0000 |
---|---|---|
committer | <> | 2015-02-02 12:02:29 +0000 |
commit | 482840e61f86ca321838a91e902c41d40c098bbb (patch) | |
tree | 01ea2e242fd2792d19fe192476601587901db794 /gettext-tools/tests/lang-c++ | |
download | gettext-tarball-482840e61f86ca321838a91e902c41d40c098bbb.tar.gz |
Imported from /home/lorry/working-area/delta_gettext-tarball/gettext-0.19.4.tar.xz.gettext-0.19.4
Diffstat (limited to 'gettext-tools/tests/lang-c++')
-rwxr-xr-x | gettext-tools/tests/lang-c++ | 174 |
1 files changed, 174 insertions, 0 deletions
diff --git a/gettext-tools/tests/lang-c++ b/gettext-tools/tests/lang-c++ new file mode 100755 index 0000000..65a8a28 --- /dev/null +++ b/gettext-tools/tests/lang-c++ @@ -0,0 +1,174 @@ +#! /bin/sh +. "${srcdir=.}/init.sh"; path_prepend_ . ../src + +# Test of gettext facilities in the C++ language. +# Assumes an fr_FR locale is installed. +# Assumes the following packages are installed: gcc g++. + +# Test whether a C++ compiler is found and libasprintf is built. +test "${CXX}" != "no" || { + echo "Skipping test: no C++ compiler found" + exit 77 +} +test "${TESTLIBASPRINTF}" = yes || { + echo "Skipping test: configured with --disable-libasprintf" + exit 77 +} + +cat <<\EOF > prog.cc +#include "config.h" + +/* Avoid deprecation warnings from g++ 3.1 or newer. */ +#if defined __GNUG__ && defined __DEPRECATED +# include <iostream> +using namespace std; +#else +# include <iostream.h> +#endif + +#include <libintl.h> +#include <locale.h> +#include <stdio.h> +#include <stdlib.h> +#include "xsetenv.h" +#include "autosprintf.h" +using gnu::autosprintf; +#define _(string) gettext (string) + +int main (int argc, char *argv[]) +{ + int n = atoi (argv[2]); + + xsetenv ("LC_ALL", argv[1], 1); + if (setlocale (LC_ALL, "") == NULL) + // Couldn't set locale. + exit (77); + + textdomain ("prog"); + bindtextdomain ("prog", "."); + + cout << _("'Your command, please?', asked the waiter.") << endl; + + cout << autosprintf (ngettext ("a piece of cake", "%d pieces of cake", n), n) + << endl; + + cout << autosprintf (_("%s is replaced by %s."), "FF", "EUR") << endl; +} +EOF + +# Compile in two steps from .cc to .o and from .o to 'prog'. This way, +# relinking is faster because doesn't need to redo the first step. +# Put the -I flags before ${CXXFLAGS} ${CPPFLAGS}, to make sure that libintl.h +# is found in the build directory, regardless of -I options present in +# ${CXXFLAGS} or ${CPPFLAGS}. +${CXX} -I../.. -I../../../gettext-runtime/libasprintf -I"$abs_top_srcdir"/gnulib-lib -I../../intl ${CXXFLAGS} ${CPPFLAGS} -c prog.cc \ + || exit 1 +# Remove the -Wl,--disable-auto-import option here that is added by +# woe32-dll.m4. Cygwin 1.7.2 does not support it in C++ mode: It gives +# a link error about 'std::cout'. +: ${CONFIG_SHELL=${SHELL-/bin/sh}} +${CONFIG_SHELL} "$top_builddir"/libtool --quiet --tag=CXX --mode=link \ + ${CXX} ${CXXFLAGS} `echo "X ${LDFLAGS} " | sed -e 's/^X//' -e 's/ -Wl,--disable-auto-import / /'` -o prog prog.${OBJEXT} \ + ../../../gettext-runtime/libasprintf/libasprintf.la \ + ../../gnulib-lib/libgettextlib.la ${LTLIBINTL} \ + || exit 1 + +: ${XGETTEXT=xgettext} +${XGETTEXT} -o prog.tmp --omit-header --no-location -k_ prog.cc || exit 1 +LC_ALL=C tr -d '\r' < prog.tmp > prog.pot || exit 1 + +cat <<EOF > prog.ok +msgid "'Your command, please?', asked the waiter." +msgstr "" + +#, c-format +msgid "a piece of cake" +msgid_plural "%d pieces of cake" +msgstr[0] "" +msgstr[1] "" + +#, c-format +msgid "%s is replaced by %s." +msgstr "" +EOF + +: ${DIFF=diff} +${DIFF} prog.ok prog.pot || exit 1 + +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." + +# Les gateaux allemands sont les meilleurs du monde. +#, c-format +msgid "a piece of cake" +msgid_plural "%d pieces of cake" +msgstr[0] "un morceau de gateau" +msgstr[1] "%d morceaux de gateau" + +# Reverse the arguments. +#, c-format +msgid "%s is replaced by %s." +msgstr "%2$s remplace %1$s." +EOF + +: ${MSGMERGE=msgmerge} +${MSGMERGE} -q -o fr.po.tmp fr.po prog.pot || exit 1 +LC_ALL=C tr -d '\r' < fr.po.tmp > fr.po.new || exit 1 + +: ${DIFF=diff} +${DIFF} fr.po fr.po.new || exit 1 + +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 + +: ${DIFF=diff} +cat <<\EOF > prog.ok +«Votre commande, s'il vous plait», dit le garçon. +2 morceaux de gateau +EUR remplace FF. +EOF +cat <<\EOF > prog.oku +«Votre commande, s'il vous plait», dit le garçon. +2 morceaux de gateau +EUR remplace FF. +EOF + +: ${LOCALE_FR=fr_FR} +: ${LOCALE_FR_UTF8=fr_FR.UTF-8} +if test $LOCALE_FR != none; then + prepare_locale_ fr $LOCALE_FR + LANGUAGE= ./prog $LOCALE_FR 2 > prog.out + case $? in + 0) ${DIFF} prog.ok prog.out || exit 1;; + 77) LOCALE_FR=none;; + *) exit 1;; + esac +fi +if test $LOCALE_FR_UTF8 != none; then + prepare_locale_ fr $LOCALE_FR_UTF8 + LANGUAGE= ./prog $LOCALE_FR_UTF8 2 > prog.out + case $? in + 0) ${DIFF} prog.oku prog.out || exit 1;; + 77) LOCALE_FR_UTF8=none;; + *) exit 1;; + esac +fi +if test $LOCALE_FR = none && test $LOCALE_FR_UTF8 = none; then + if test -f /usr/bin/localedef; then + echo "Skipping test: no french locale is installed" + else + echo "Skipping test: no french locale is supported" + fi + exit 77 +fi + +exit 0 |