mirror of
https://github.com/php-win-ext/gettext.git
synced 2026-04-23 16:58:04 +02:00
189 lines
5.2 KiB
Bash
189 lines
5.2 KiB
Bash
#! /bin/sh
|
|
|
|
# Test of gettext facilities in the C++ language.
|
|
# Assumes an fr_FR locale is installed.
|
|
# Assumes the following packages are installed: gcc g++.
|
|
|
|
tmpfiles=""
|
|
trap 'rm -fr $tmpfiles' 1 2 3 15
|
|
|
|
# Test whether a C++ compiler is found and libasprintf is built.
|
|
test "${CXX}" != ":" || {
|
|
echo "Skipping test: no C++ compiler found"
|
|
exit 77
|
|
}
|
|
test "${TESTLIBASPRINTF}" = yes || {
|
|
echo "Skipping test: configured with --disable-libasprintf"
|
|
exit 77
|
|
}
|
|
|
|
tmpfiles="$tmpfiles l-c++-prog.cc"
|
|
cat <<\EOF > l-c++-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", "l-c++");
|
|
|
|
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
|
|
|
|
# Variable needed by LTLIBINTL.
|
|
top_builddir=..
|
|
|
|
tmpfiles="$tmpfiles l-c++-prog.${OBJEXT} l-c++-prog${EXEEXT}"
|
|
# Compile in two steps from .cc to .o and from .o to 'l-c++-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$top_srcdir/gnulib-lib -I../intl ${CXXFLAGS} ${CPPFLAGS} -c l-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'.
|
|
${LIBTOOL} --quiet --mode=link --tag=CXX ${CXX} ${CXXFLAGS} `echo "X ${LDFLAGS} " | sed -e 's/^X//' -e 's/ -Wl,--disable-auto-import / /'` -o l-c++-prog l-c++-prog.${OBJEXT} ../../gettext-runtime/libasprintf/libasprintf.la ../gnulib-lib/libgettextlib.la ${LTLIBINTL} \
|
|
|| exit 1
|
|
|
|
tmpfiles="$tmpfiles l-c++-prog.tmp l-c++-prog.pot"
|
|
: ${XGETTEXT=xgettext}
|
|
${XGETTEXT} -o l-c++-prog.tmp --omit-header --no-location -k_ l-c++-prog.cc
|
|
test $? = 0 || { rm -fr $tmpfiles; exit 1; }
|
|
LC_ALL=C tr -d '\r' < l-c++-prog.tmp > l-c++-prog.pot
|
|
test $? = 0 || { rm -fr $tmpfiles; exit 1; }
|
|
|
|
tmpfiles="$tmpfiles l-c++-prog.ok"
|
|
cat <<EOF > l-c++-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} l-c++-prog.ok l-c++-prog.pot || exit 1
|
|
|
|
tmpfiles="$tmpfiles l-c++-fr.po"
|
|
cat <<\EOF > l-c++-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
|
|
|
|
tmpfiles="$tmpfiles l-c++-fr.po.tmp l-c++-fr.po.new"
|
|
: ${MSGMERGE=msgmerge}
|
|
${MSGMERGE} -q -o l-c++-fr.po.tmp l-c++-fr.po l-c++-prog.pot
|
|
test $? = 0 || { rm -fr $tmpfiles; exit 1; }
|
|
LC_ALL=C tr -d '\r' < l-c++-fr.po.tmp > l-c++-fr.po.new
|
|
test $? = 0 || { rm -fr $tmpfiles; exit 1; }
|
|
|
|
: ${DIFF=diff}
|
|
${DIFF} l-c++-fr.po l-c++-fr.po.new || exit 1
|
|
|
|
tmpfiles="$tmpfiles l-c++"
|
|
test -d l-c++ || mkdir l-c++
|
|
test -d l-c++/fr || mkdir l-c++/fr
|
|
test -d l-c++/fr/LC_MESSAGES || mkdir l-c++/fr/LC_MESSAGES
|
|
|
|
: ${MSGFMT=msgfmt}
|
|
${MSGFMT} -o l-c++/fr/LC_MESSAGES/prog.mo l-c++-fr.po
|
|
|
|
tmpfiles="$tmpfiles l-c++-prog.ok l-c++-prog.oku l-c++-prog.out"
|
|
: ${DIFF=diff}
|
|
cat <<\EOF > l-c++-prog.ok
|
|
«Votre commande, s'il vous plait», dit le garçon.
|
|
2 morceaux de gateau
|
|
EUR remplace FF.
|
|
EOF
|
|
cat <<\EOF > l-c++-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
|
|
LANGUAGE= ./l-c++-prog $LOCALE_FR 2 > l-c++-prog.out
|
|
case $? in
|
|
0) ${DIFF} l-c++-prog.ok l-c++-prog.out || exit 1;;
|
|
77) LOCALE_FR=none;;
|
|
*) exit 1;;
|
|
esac
|
|
fi
|
|
if test $LOCALE_FR_UTF8 != none; then
|
|
LANGUAGE= ./l-c++-prog $LOCALE_FR_UTF8 2 > l-c++-prog.out
|
|
case $? in
|
|
0) ${DIFF} l-c++-prog.oku l-c++-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
|
|
rm -fr $tmpfiles; exit 77
|
|
fi
|
|
|
|
rm -fr $tmpfiles
|
|
|
|
exit 0
|