diff options
author | Bruno Haible <bruno@clisp.org> | 2023-12-12 09:45:16 +0100 |
---|---|---|
committer | Florian Weimer <fweimer@redhat.com> | 2023-12-12 10:08:07 +0100 |
commit | d0aefec49941cf6d97e2244d6aa20bafc26d5942 (patch) | |
tree | 564b5193cbe036929f80c8779bee53983ba8528b /intl | |
parent | fc039ce8502d236f11074eb58468be24b4fa8cc7 (diff) | |
download | glibc-d0aefec49941cf6d97e2244d6aa20bafc26d5942.zip glibc-d0aefec49941cf6d97e2244d6aa20bafc26d5942.tar.gz glibc-d0aefec49941cf6d97e2244d6aa20bafc26d5942.tar.bz2 |
intl: Treat C.UTF-8 locale like C locale, part 2 (BZ# 16621)
The previous commit was incomplete: gettext() still returns a translation
if the file /usr/share/locale/C/LC_MESSAGES/<domain>.mo exists. This patch
prohibits the translation also in this case.
* gettext-runtime/intl/dcigettext.c (DCIGETTEXT): Treat C.<encoding> locale
like the C locale.
Reviewed-by: Florian Weimer <fweimer@redhat.com>
Diffstat (limited to 'intl')
-rw-r--r-- | intl/dcigettext.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/intl/dcigettext.c b/intl/dcigettext.c index 2706388..fb69bbf 100644 --- a/intl/dcigettext.c +++ b/intl/dcigettext.c @@ -691,9 +691,10 @@ DCIGETTEXT (const char *domainname, const char *msgid1, const char *msgid2, continue; } - /* If the current locale value is C (or POSIX) we don't load a - domain. Return the MSGID. */ - if (strcmp (single_locale, "C") == 0 + /* If the current locale value is "C" or "C.<encoding>" or "POSIX", + we don't load a domain. Return the MSGID. */ + if ((single_locale[0] == 'C' + && (single_locale[1] == '\0' || single_locale[1] == '.')) || strcmp (single_locale, "POSIX") == 0) break; |