<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">From 1b421e4978440234fb73117c8505dad1ccc68d46 Mon Sep 17 00:00:00 2001
From: Jun-ichi Takimoto &lt;takimoto-j@kba.biglobe.ne.jp&gt;
Date: Mon, 26 Sep 2022 10:52:50 +0900
Subject: [PATCH] 50658 + test: Enable to switch between C/UTF-8 locales in
 PCRE

---
 ChangeLog          |  5 +++++
 Src/Modules/pcre.c | 10 ++--------
 Test/V07pcre.ztst  | 11 +++++++++++
 3 files changed, 18 insertions(+), 8 deletions(-)

# diff --git a/ChangeLog b/ChangeLog
# index 48c65d01b..77345c050 100644
# --- a/ChangeLog
# +++ b/ChangeLog
# @@ -1,3 +1,8 @@
# +2022-09-26  Jun-ichi Takimoto  &lt;takimoto-j@kba.biglobe.ne.jp&gt;
# +
# +	* 50658 + test: Src/Modules/pcre.c, Test/V07pcre.ztst: Enable to
# +	switch between C/UTF-8 locales in PCRE
# +
#  2022-09-25  Peter Stephenson  &lt;p.w.stephenson@ntlworld.com&gt;
 
#  	* 50648: Functions/Misc/zcalc: Julian Prein: Use ZCALC_HISTFILE
--- a/Src/Modules/pcre.c
+++ b/Src/Modules/pcre.c
@@ -47,8 +47,6 @@ zpcre_utf8_enabled(void)
 #if defined(MULTIBYTE_SUPPORT) &amp;&amp; defined(HAVE_NL_LANGINFO) &amp;&amp; defined(CODESET)
     static int have_utf8_pcre = -1;
 
-    /* value can toggle based on MULTIBYTE, so don't
-     * be too eager with caching */
     if (have_utf8_pcre &lt; -1)
 	return 0;
 
@@ -56,15 +54,11 @@ zpcre_utf8_enabled(void)
 	return 0;
 
     if ((have_utf8_pcre == -1) &amp;&amp;
-        (!strcmp(nl_langinfo(CODESET), "UTF-8"))) {
-
-	if (pcre_config(PCRE_CONFIG_UTF8, &amp;have_utf8_pcre))
+	(pcre_config(PCRE_CONFIG_UTF8, &amp;have_utf8_pcre))) {
 	    have_utf8_pcre = -2; /* erk, failed to ask */
     }
 
-    if (have_utf8_pcre &lt; 0)
-	return 0;
-    return have_utf8_pcre;
+    return (have_utf8_pcre == 1) &amp;&amp; (!strcmp(nl_langinfo(CODESET), "UTF-8"));
 
 #else
     return 0;
--- a/Test/V07pcre.ztst
+++ b/Test/V07pcre.ztst
@@ -174,3 +174,14 @@
     echo $match[2] )
 0:regression for segmentation fault, workers/38307
 &gt;test
+
+  LANG_SAVE=$LANG
+  [[ Ã© =~ '^.\z' ]]; echo $?
+  LANG=C
+  [[ Ã© =~ '^..\z' ]]; echo $?
+  LANG=$LANG_SAVE
+  [[ Ã© =~ '^.\z' ]]; echo $?
+0:swich between C/UTF-8 locales
+&gt;0
+&gt;0
+&gt;0
</pre></body></html>