91 lines
3.3 KiB
Diff
91 lines
3.3 KiB
Diff
--- libiconv-1.17/libcharset/lib/localcharset.c.orig 2020-04-04 14:50:22.000000000 +0200
|
|
+++ libiconv-1.17/libcharset/lib/localcharset.c 2022-06-06 09:21:01.741854500 +0200
|
|
@@ -51,10 +51,6 @@
|
|
# include <locale.h>
|
|
# endif
|
|
# endif
|
|
-# ifdef __CYGWIN__
|
|
-# define WIN32_LEAN_AND_MEAN
|
|
-# include <windows.h>
|
|
-# endif
|
|
#elif defined WINDOWS_NATIVE
|
|
# define WIN32_LEAN_AND_MEAN
|
|
# include <windows.h>
|
|
@@ -843,70 +839,12 @@
|
|
|
|
# if HAVE_LANGINFO_CODESET
|
|
|
|
- /* Most systems support nl_langinfo (CODESET) nowadays. */
|
|
- codeset = nl_langinfo (CODESET);
|
|
-
|
|
-# ifdef __CYGWIN__
|
|
- /* Cygwin < 1.7 does not have locales. nl_langinfo (CODESET) always
|
|
- returns "US-ASCII". Return the suffix of the locale name from the
|
|
- environment variables (if present) or the codepage as a number. */
|
|
- if (codeset != NULL && strcmp (codeset, "US-ASCII") == 0)
|
|
- {
|
|
- const char *locale;
|
|
- static char resultbuf[2 + 10 + 1];
|
|
-
|
|
- locale = getenv ("LC_ALL");
|
|
- if (locale == NULL || locale[0] == '\0')
|
|
- {
|
|
- locale = getenv ("LC_CTYPE");
|
|
- if (locale == NULL || locale[0] == '\0')
|
|
- locale = getenv ("LANG");
|
|
- }
|
|
- if (locale != NULL && locale[0] != '\0')
|
|
- {
|
|
- /* If the locale name contains an encoding after the dot, return
|
|
- it. */
|
|
- const char *dot = strchr (locale, '.');
|
|
-
|
|
- if (dot != NULL)
|
|
- {
|
|
- const char *modifier;
|
|
-
|
|
- dot++;
|
|
- /* Look for the possible @... trailer and remove it, if any. */
|
|
- modifier = strchr (dot, '@');
|
|
- if (modifier == NULL)
|
|
- return dot;
|
|
- if (modifier - dot < sizeof (resultbuf))
|
|
- {
|
|
- /* This way of filling resultbuf is multithread-safe. */
|
|
- memcpy (resultbuf, dot, modifier - dot);
|
|
- resultbuf [modifier - dot] = '\0';
|
|
- return resultbuf;
|
|
- }
|
|
- }
|
|
- }
|
|
-
|
|
- /* The Windows API has a function returning the locale's codepage as a
|
|
- number: GetACP(). This encoding is used by Cygwin, unless the user
|
|
- has set the environment variable CYGWIN=codepage:oem (which very few
|
|
- people do).
|
|
- Output directed to console windows needs to be converted (to
|
|
- GetOEMCP() if the console is using a raster font, or to
|
|
- GetConsoleOutputCP() if it is using a TrueType font). Cygwin does
|
|
- this conversion transparently (see winsup/cygwin/fhandler_console.cc),
|
|
- converting to GetConsoleOutputCP(). This leads to correct results,
|
|
- except when SetConsoleOutputCP has been called and a raster font is
|
|
- in use. */
|
|
- {
|
|
- char buf[2 + 10 + 1];
|
|
-
|
|
- sprintf (buf, "CP%u", GetACP ());
|
|
- strcpy (resultbuf, buf);
|
|
- codeset = resultbuf;
|
|
- }
|
|
- }
|
|
-# endif
|
|
+ /* Most systems support nl_langinfo (CODESET) nowadays.
|
|
+ POSIX allows that the returned pointer may point to a static area that
|
|
+ may be overwritten by subsequent calls to setlocale or nl_langinfo. */
|
|
+ static char codeset_buf[64];
|
|
+ codeset_buf[0] = '\0';
|
|
+ codeset = strncat (codeset_buf, nl_langinfo (CODESET), sizeof (codeset_buf));
|
|
|
|
if (codeset == NULL)
|
|
/* The canonical name cannot be determined. */
|