summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2004-09-01 17:39:27 +0000
committerJeremy Allison <jra@samba.org>2004-09-01 17:39:27 +0000
commit824760f4e2cc7e18d7f1ec009eb80da63aff4461 (patch)
treec490aef26330dca5fee06554f8476a77e9299ea5
parent861c1cf97f0d1c05e9da96ddb920d647466cb789 (diff)
downloadsamba-824760f4e2cc7e18d7f1ec009eb80da63aff4461.tar.gz
samba-824760f4e2cc7e18d7f1ec009eb80da63aff4461.tar.xz
samba-824760f4e2cc7e18d7f1ec009eb80da63aff4461.zip
r2175: Fix for #1546 from fumiya@samba.gr.jp. Preserve errno in MB strupper_m/strlower_m.
Jeremy.
-rw-r--r--source/lib/util_str.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/source/lib/util_str.c b/source/lib/util_str.c
index 250d6ed6a06..6eee62c14aa 100644
--- a/source/lib/util_str.c
+++ b/source/lib/util_str.c
@@ -1391,6 +1391,7 @@ char *strstr_m(const char *src, const char *findstr)
void strlower_m(char *s)
{
size_t len;
+ int errno_save;
/* this is quite a common operation, so we want it to be
fast. We optimise for the ascii case, knowing that all our
@@ -1408,11 +1409,13 @@ void strlower_m(char *s)
/* I assume that lowercased string takes the same number of bytes
* as source string even in UTF-8 encoding. (VIV) */
len = strlen(s) + 1;
+ errno_save = errno;
errno = 0;
unix_strlower(s,len,s,len);
/* Catch mb conversion errors that may not terminate. */
if (errno)
s[len-1] = '\0';
+ errno = errno_save;
}
/**
@@ -1422,6 +1425,7 @@ void strlower_m(char *s)
void strupper_m(char *s)
{
size_t len;
+ int errno_save;
/* this is quite a common operation, so we want it to be
fast. We optimise for the ascii case, knowing that all our
@@ -1439,11 +1443,13 @@ void strupper_m(char *s)
/* I assume that lowercased string takes the same number of bytes
* as source string even in multibyte encoding. (VIV) */
len = strlen(s) + 1;
+ errno_save = errno;
errno = 0;
unix_strupper(s,len,s,len);
/* Catch mb conversion errors that may not terminate. */
if (errno)
s[len-1] = '\0';
+ errno = errno_save;
}
/**