1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224
|
#! /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: mono, mcs, or dotnet8.
# Note: This test fails when a GNU gettext version < 0.17 is installed with
# the same --prefix as mcs. mcs apparently searches ${prefix}/lib before
# searching the directory specified on the command line:
# $ mcs -out:program.exe -lib:../../gettext-runtime/intl-csharp -reference:GNU.Gettext program.cs
# program.cs(17,45): error CS0117: `GNU.Gettext.GettextResourceManager' does not contain a definition for `GetParticularPluralString'
# /usr/local/lib/GNU.Gettext.dll (Location of the symbol related to previous error)
# program.cs(18,45): error CS0117: `GNU.Gettext.GettextResourceManager' does not contain a definition for `GetParticularString'
# /usr/local/lib/GNU.Gettext.dll (Location of the symbol related to previous error)
# Compilation failed: 2 error(s), 0 warnings
# The workaround is to install GNU gettext with the same --prefix, despite
# the test failure, and run "make check" afterwards.
# Test whether we can build and test C# programs.
test "${CSHARP_CHOICE}" != no || {
echo "Skipping test: configured with --disable-csharp"
Exit 77
}
test "${BUILDCSHARP}" = yes || {
echo "Skipping test: C# compiler not found"
Exit 77
}
test "${TESTCSHARP}" = yes || {
echo "Skipping test: C# engine not found"
Exit 77
}
cat <<\EOF > program.cs
using System; /* Console */
using System.IO; /* StreamWriter */
using System.Text; /* UTF8Encoding */
using System.Runtime.InteropServices; /* RuntimeInformation, OSPlatform */
using GNU.Gettext; /* GettextResourceManager */
class Program {
static void Main (String[] args) {
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
{
// Change the Console to produce UTF-8 output with Unix end-of-lines.
Console.SetOut(
new StreamWriter(Console.OpenStandardOutput(),
new UTF8Encoding(false)) {
NewLine = "\n",
AutoFlush = true
});
}
#if __MonoCS__
if (true)
#else
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
#endif
{
// Some systems don't set CurrentCulture and CurrentUICulture as
// specified by LC_ALL. So set it by hand.
System.Threading.Thread.CurrentThread.CurrentCulture =
System.Threading.Thread.CurrentThread.CurrentUICulture =
new System.Globalization.CultureInfo("fr-FR");
}
int n = Int32.Parse(args[0]);
GettextResourceManager catalog = new GettextResourceManager("prog");
Console.WriteLine(catalog.GetString("'Your command, please?', asked the waiter."));
Console.WriteLine(String.Format(catalog.GetPluralString("a piece of cake","{0} pieces of cake",n), n));
Console.WriteLine(String.Format(catalog.GetString("{0} is replaced by {1}."), "FF", "EUR"));
Console.WriteLine(String.Format(catalog.GetParticularPluralString("++","a piece of cake","{0} pieces of cake",n), n));
Console.WriteLine(String.Format(catalog.GetParticularString("++","{0} is replaced by {1}."), "FF", "EUR"));
}
}
EOF
: ${CSHARPCOMP="/bin/sh ../../csharpcomp.sh"}
${CSHARPCOMP} -o program.exe -L ../../../gettext-runtime/intl-csharp -l GNU.Gettext program.cs || Exit 1
: ${XGETTEXT=xgettext}
${XGETTEXT} -o prog.tmp --omit-header --no-location program.cs || 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 ""
#, csharp-format
msgid "a piece of cake"
msgid_plural "{0} pieces of cake"
msgstr[0] ""
msgstr[1] ""
#, csharp-format
msgid "{0} is replaced by {1}."
msgstr ""
#, csharp-format
msgctxt "++"
msgid "a piece of cake"
msgid_plural "{0} pieces of cake"
msgstr[0] ""
msgstr[1] ""
#, csharp-format
msgctxt "++"
msgid "{0} is replaced by {1}."
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 garon."
# Les gateaux allemands sont les meilleurs du monde.
#, csharp-format
msgid "a piece of cake"
msgid_plural "{0} pieces of cake"
msgstr[0] "un morceau de gateau"
msgstr[1] "{0} morceaux de gateau"
# Reverse the arguments.
#, csharp-format
msgid "{0} is replaced by {1}."
msgstr "{1} remplace {0}."
# Euphemistic formulation.
#, csharp-format
msgctxt "++"
msgid "a piece of cake"
msgid_plural "{0} pieces of cake"
msgstr[0] "un morceau de gateau succulent"
msgstr[1] "{0} morceaux de gateau succulent"
# Euphemistic formulation.
#, csharp-format
msgctxt "++"
msgid "{0} is replaced by {1}."
msgstr "Le nouveau {1} remplace le vieux {0}."
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
: ${MSGFMT=msgfmt}
GETTEXTCSHARPLIBDIR=../../../gettext-runtime/intl-csharp \
${MSGFMT} --csharp -d . -r prog -l fr fr.po || Exit 1
# Test which of the fr_FR locales are installed.
: ${LOCALE_FR=fr_FR}
: ${LOCALE_FR_UTF8=fr_FR.UTF-8}
if test $LOCALE_FR != none; then
LC_ALL=$LOCALE_FR ../testlocale
case $? in
0) ;;
77) LOCALE_FR=none;;
*) Exit 1;;
esac
fi
if test $LOCALE_FR_UTF8 != none; then
LC_ALL=$LOCALE_FR_UTF8 ../testlocale
case $? in
0) ;;
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
: ${DIFF=diff}
cat <<\EOF > prog.ok
Votre commande, s'il vous plait, dit le garon.
2 morceaux de gateau
EUR remplace FF.
2 morceaux de gateau succulent
Le nouveau EUR remplace le vieux FF.
EOF
cat <<\EOF > prog.oku
«Votre commande, s'il vous plait», dit le garçon.
2 morceaux de gateau
EUR remplace FF.
2 morceaux de gateau succulent
Le nouveau EUR remplace le vieux FF.
EOF
: ${LOCALE_FR=fr_FR}
: ${LOCALE_FR_UTF8=fr_FR.UTF-8}
: ${CSHARPEXEC="/bin/sh ../../csharpexec.sh"}
if test $LOCALE_FR != none; then
# On Mac OS X, with mono 4.2.3, this test would fail, because the Console's
# output encoding is System.Text.Encoding.Default, and this is UTF-8 even
# in the fr_FR.ISO8859-1 locale. System.Text.Encoding.Default is defined
# through InternalCodePage(), which uses g_get_charset(), which uses either
# locale_charset() or nl_langinfo(CODESET) [which is "ISO8859-1" in this case]
# or "UTF-8" - depending on platform or build configuration. So, allow the
# expected result in UTF-8 encoding here too.
prepare_locale_ fr $LOCALE_FR
LANGUAGE= LC_ALL=$LOCALE_FR ${CSHARPEXEC} -L ../../../gettext-runtime/intl-csharp program.exe 2 > prog.out || Exit 1
${DIFF} prog.oku prog.out >/dev/null || ${DIFF} prog.ok prog.out || Exit 1
fi
if test $LOCALE_FR_UTF8 != none; then
prepare_locale_ fr $LOCALE_FR_UTF8
LANGUAGE= LC_ALL=$LOCALE_FR_UTF8 ${CSHARPEXEC} -L ../../../gettext-runtime/intl-csharp program.exe 2 > prog.out || Exit 1
${DIFF} prog.oku prog.out || Exit 1
fi
Exit 0
|