https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=5011c8cc48a22d9ccfc8d11a0f5cbfc0e5db73a6

commit 5011c8cc48a22d9ccfc8d11a0f5cbfc0e5db73a6
Author:     Corinna Vinschen <[email protected]>
AuthorDate: Sun Feb 26 20:14:54 2023 +0100
Commit:     Corinna Vinschen <[email protected]>
CommitDate: Sun Feb 26 20:14:54 2023 +0100

    Cygwin: fetch-lc-def-codesets-from-linux: fix locale name handling
    
    As the former call to `locale -av' has the unwanted side effect
    to shorten the locale name to <= 15 chars, don't use it.  Use
    `locale -a' instead and fetch the codeset from another call to
    `locale' for each locale.
    
    Signed-off-by: Corinna Vinschen <[email protected]>

Diff:
---
 .../fetch-lc-def-codesets-from-linux               | 23 +++++++++++-----------
 1 file changed, 11 insertions(+), 12 deletions(-)

diff --git 
a/winsup/cygwin/linux-locale-helpers/fetch-lc-def-codesets-from-linux 
b/winsup/cygwin/linux-locale-helpers/fetch-lc-def-codesets-from-linux
index 2a6f6cca2a90..9bb0533418ed 100755
--- a/winsup/cygwin/linux-locale-helpers/fetch-lc-def-codesets-from-linux
+++ b/winsup/cygwin/linux-locale-helpers/fetch-lc-def-codesets-from-linux
@@ -10,17 +10,16 @@
        } default_codeset[] =
        {
        EOF
-  locale -av | \
-  awk '/^locale:/{
-                  if ( index ($2, "_") == 0 ) next # No aliases
-                  if ( index ($2, ".") > 0 ) next # No explicit codesets
-                  locale = gensub (/devanagar.*/, "devanagari", 1, $2);
-                }
-       /codeset/ {
-                  if ( length (locale) == 0 ) next
-                  codeset = gensub (/BIG5.*/, "BIG5", 1, $3);
-                  printf "  { \"%s\", \"%s\" },\n", locale, codeset;
-                  locale = "";
-                }'
+  locale -a | \
+  awk '{
+        if ( index ($1, "_") == 0 ) next # No aliases
+        if ( index ($1, ".") > 0 ) next # No explicit codesets
+        locale = $1
+        cmd = "LC_CTYPE=" locale " locale -ck LC_CTYPE | grep charmap"
+        cmd | getline codeset
+        codeset = gensub (/charmap="(.*)"/, "\\1", 1, codeset)
+        codeset = gensub (/BIG5.*/, "BIG5", 1, codeset);
+        printf "  { \"%s\", \"%s\" },\n", locale, codeset;
+       }'
   echo "};"
 ) > lc_def_codesets.h

Reply via email to