From 27dae84ed92f1ef0300263091972338d12e78348 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Frings-F=C3=BCrst?= Date: Sat, 18 Oct 2025 19:06:52 +0200 Subject: New upstream version 1.4.1 --- tests/test-setlocale-w32utf8.c | 69 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 tests/test-setlocale-w32utf8.c (limited to 'tests/test-setlocale-w32utf8.c') diff --git a/tests/test-setlocale-w32utf8.c b/tests/test-setlocale-w32utf8.c new file mode 100644 index 00000000..51828db1 --- /dev/null +++ b/tests/test-setlocale-w32utf8.c @@ -0,0 +1,69 @@ +/* Test of setting the current locale + on native Windows in the UTF-8 environment. + Copyright (C) 2024-2025 Free Software Foundation, Inc. + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ + +/* Written by Bruno Haible , 2024. */ + +#include + +#include + +#include +#include +#include + +int +main (void) +{ +#ifdef _UCRT + /* Test that setlocale() works as expected in a UTF-8 locale. */ + char *name; + + /* This looks at all LC_*, LANG environment variables, which are all unset + at this point. */ + if (setlocale (LC_ALL, "") == NULL) + return 1; + + name = setlocale (LC_ALL, NULL); + /* With the legacy system settings, expect some mixed locale, due to the + limitations of the native setlocale(). + With the modern system settings, expect some "ll_CC.UTF-8" name. */ + if (!((strlen (name) > 6 && str_endswith (name, ".UTF-8")) + || strcmp (name, "LC_COLLATE=English_United States.65001;" + "LC_CTYPE=English_United States.65001;" + "LC_MONETARY=English_United States.65001;" + "LC_NUMERIC=English_United States.65001;" + "LC_TIME=English_United States.65001;" + "LC_MESSAGES=C.UTF-8") + == 0 + || strcmp (name, "LC_COLLATE=English_United States.utf8;" + "LC_CTYPE=English_United States.utf8;" + "LC_MONETARY=English_United States.utf8;" + "LC_NUMERIC=English_United States.utf8;" + "LC_TIME=English_United States.utf8;" + "LC_MESSAGES=C.UTF-8") + == 0)) + { + fprintf (stderr, "setlocale() returned \"%s\".\n", name); + exit (1); + } + + return 0; +#else + fputs ("Skipping test: not using the UCRT runtime\n", stderr); + return 77; +#endif +} -- cgit v1.2.3 From 5f59a34ab747dde8ede7357f3431bf06bd6002fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Frings-F=C3=BCrst?= Date: Sun, 8 Mar 2026 17:28:33 +0100 Subject: New upstream version 1.4.2 --- tests/test-setlocale-w32utf8.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'tests/test-setlocale-w32utf8.c') diff --git a/tests/test-setlocale-w32utf8.c b/tests/test-setlocale-w32utf8.c index 51828db1..4e17203e 100644 --- a/tests/test-setlocale-w32utf8.c +++ b/tests/test-setlocale-w32utf8.c @@ -1,6 +1,6 @@ /* Test of setting the current locale on native Windows in the UTF-8 environment. - Copyright (C) 2024-2025 Free Software Foundation, Inc. + Copyright (C) 2024-2026 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by -- cgit v1.2.3