Hi, Friedrich Beckmann wrote: > I noticed a problem when using pgettext on debian testing. When > I compile the following small test program > > #define ENABLE_NLS 1 > #include "lib/gettext.h" > > int test(){ > if (pgettext ("This is", "a bug") == "I guess") > return 1; > } > > I get the following error: > > fritz@debian:~/pspp/gnulib$ gcc -c test.c > In file included from test.c:2: > test.c: In function ‘test’: > lib/gettext.h:123:67: error: ‘LC_MESSAGES’ undeclared (first use in this > function) > 123 | pgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, > LC_MESSAGES) > | > ^~~~~~~~~~~ > test.c:5:7: note: in expansion of macro ‘pgettext’ > 5 | if (pgettext ("This is", "a bug") == "I guess") > | ^~~~~~~~
Thanks for the report. Fixed through the following change: 2024-11-24 Bruno Haible <br...@clisp.org> gettext: Fix compilation error when pgettext is used. Reported by Friedrich Beckmann <friedrich.beckm...@posteo.de> in <https://lists.gnu.org/archive/html/bug-gnulib/2024-11/msg00189.html>. * lib/gettext.h: Include <locale.h>. diff --git a/lib/gettext.h b/lib/gettext.h index 39d5ae4daa..ba595e03be 100644 --- a/lib/gettext.h +++ b/lib/gettext.h @@ -18,6 +18,7 @@ #ifndef _LIBGETTEXT_H #define _LIBGETTEXT_H 1 + /* NLS can be disabled through the configure --disable-nls option or through "#define ENABLE NLS 0" before including this file. */ #if defined ENABLE_NLS && ENABLE_NLS @@ -45,19 +46,19 @@ as well because people using "gettext.h" will not include <libintl.h>, and also including <libintl.h> would fail on SunOS 4, whereas <locale.h> is OK. */ -#if defined(__sun) -# include <locale.h> -#endif +# if defined(__sun) +# include <locale.h> +# endif /* Many header files from the libstdc++ coming with g++ 3.3 or newer include <libintl.h>, which chokes if dcgettext is defined as a macro. So include it now, to make later inclusions of <libintl.h> a NOP. */ -#if defined(__cplusplus) && defined(__GNUG__) && (__GNUC__ >= 3) -# include <cstdlib> -# if (__GLIBC__ >= 2 && !defined __UCLIBC__) || _GLIBCXX_HAVE_LIBINTL_H -# include <libintl.h> +# if defined(__cplusplus) && defined(__GNUG__) && (__GNUC__ >= 3) +# include <cstdlib> +# if (__GLIBC__ >= 2 && !defined __UCLIBC__) || _GLIBCXX_HAVE_LIBINTL_H +# include <libintl.h> +# endif # endif -#endif /* Disabled NLS. The casts to 'const char *' serve the purpose of producing warnings @@ -93,12 +94,14 @@ #endif + /* Prefer gnulib's setlocale override over libintl's setlocale override. */ #ifdef GNULIB_defined_setlocale # undef setlocale # define setlocale rpl_setlocale #endif + /* A pseudo function call that serves as a marker for the automated extraction of messages, but does not call gettext(). The run-time translation is done at a different place in the code. @@ -108,6 +111,7 @@ initializer for static 'char[]' or 'const char[]' variables. */ #define gettext_noop(String) String + /* The separator between msgctxt and msgid in a .mo file. */ #define GETTEXT_CONTEXT_GLUE "\004" @@ -115,6 +119,9 @@ MSGID. MSGCTXT and MSGID must be string literals. MSGCTXT should be short and rarely need to change. The letter 'p' stands for 'particular' or 'special'. */ + +#include <locale.h> /* for LC_MESSAGES */ + #ifdef DEFAULT_TEXT_DOMAIN # define pgettext(Msgctxt, Msgid) \ pgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) @@ -178,11 +185,12 @@ npgettext_aux (const char *domain, return translation; } + /* The same thing extended for non-constant arguments. Here MSGCTXT and MSGID can be arbitrary expressions. But for string literals these macros are less efficient than those above. */ -#include <string.h> +#include <string.h> /* for memcpy */ /* GNULIB_NO_VLA can be defined to disable use of VLAs even if supported. This relates to the -Wvla and -Wvla-larger-than warnings, enabled in @@ -199,7 +207,7 @@ npgettext_aux (const char *domain, #endif #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS -#include <stdlib.h> +# include <stdlib.h> /* for malloc, free */ #endif #define pgettext_expr(Msgctxt, Msgid) \ @@ -297,4 +305,5 @@ dcnpgettext_expr (const char *domain, return (n == 1 ? msgid : msgid_plural); } + #endif /* _LIBGETTEXT_H */