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

commit c53d0910e611bf4cf61f8f8cb44c6ce70d3e9a05
Author:     Corinna Vinschen <[email protected]>
AuthorDate: Fri Mar 24 12:42:34 2023 +0100
Commit:     Corinna Vinschen <[email protected]>
CommitDate: Fri Mar 24 12:50:59 2023 +0100

    Cygwin: locales: set errno to ENOENT if locale is invalid
    
    This allows newlocale to return with a valid errno if the
    locale is invalid.
    
    Fixes: e95a7a795522 ("Cygwin: convert Windows locale handling from LCID to 
ISO5646 strings")
    Signed-off-by: Corinna Vinschen <[email protected]>

Diff:
---
 winsup/cygwin/nlsfuncs.cc | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/winsup/cygwin/nlsfuncs.cc b/winsup/cygwin/nlsfuncs.cc
index 808bf6a87320..a81dff3966d7 100644
--- a/winsup/cygwin/nlsfuncs.cc
+++ b/winsup/cygwin/nlsfuncs.cc
@@ -74,7 +74,10 @@ __get_rfc5646_from_locale (const char *name, wchar_t 
*win_locale)
       if (!wcscmp (locale, L"ber"))
        wcscpy (locale, L"tzm");
       if (ResolveLocaleName (locale, wlocale, ENCODING_LEN + 1) <= 0)
-       return -1;
+       {
+         set_errno (ENOENT);
+         return -1;
+       }
       wcpcpy (win_locale, wlocale);
       return 1;
     }
@@ -114,7 +117,10 @@ __get_rfc5646_from_locale (const char *name, wchar_t 
*win_locale)
     }
   if (!wlocale[0]
       && ResolveLocaleName (locale, wlocale, ENCODING_LEN + 1) <= 1)
-    return -1;
+    {
+      set_errno (ENOENT);
+      return -1;
+    }
 
   /* Check for modifiers changing the script */
   const wchar_t *iso15924_script[] = { L"Latn-", L"Cyrl-", L"Deva-", L"Adlm-" 
};

Reply via email to