Subject: lib/23460: Small improvements for a few wchar functions
To: None <gnats-bugs@gnats.netbsd.org>
From: None <christianbiere@gmx.de>
List: netbsd-bugs
Date: 11/16/2003 19:15:49
>Number:         23460
>Category:       lib
>Synopsis:       Small improvements for a few wchar functions
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    lib-bug-people
>State:          open
>Class:          change-request
>Submitter-Id:   net
>Arrival-Date:   Sun Nov 16 18:16:00 UTC 2003
>Closed-Date:
>Last-Modified:
>Originator:     Christian Biere <christianbiere@gmx.de>
>Release:        NetBSD 1.6ZE
>Organization:
>Environment:
System: NetBSD cyclonus 1.6ZE NetBSD 1.6ZE (STARSCREAM) #5: Sat Nov 15 01:35:55 CET 2003 bin@cyclonus:/usr/build/sys/arch/i386/compile/STARSCREAM i386
Architecture: i386
Machine: i386
>Description:

wcsrchr.c:

The string doesn't have to be scanned backward. I've used the same
solution as strrchr.c. FreeBSD has fixed to the same strategy a
year ago. I've used a more readable (IMHO) implementation.

wcsstr.c:
	
"q = little" was absolutely unnecessary. I've also eliminated the
length comparison which caused some overhead. FreeBSD has changed
it's implementation in a different/better way - at least they
claim it's more efficient. Though, this one has no further function
call overhead [See FreeBSD's Implementation for details.].

Rest:

Instead of counting i up to n, just count n down to zero. Less code
and maybe a little faster.

[I hope the patch survives this.]
 
>How-To-Repeat:
>Fix:

Index: wcsrchr.c
===================================================================
RCS file: /cvsroot/src/lib/libc/string/wcsrchr.c,v
retrieving revision 1.2
diff -u -r1.2 wcsrchr.c
--- wcsrchr.c	2001/01/03 14:29:37	1.2
+++ wcsrchr.c	2003/11/16 07:47:30
@@ -41,19 +41,15 @@
 	const wchar_t *s;
 	wchar_t c;
 {
-	const wchar_t *p;
+	const wchar_t *save = NULL;
 
 	_DIAGASSERT(s != NULL);
 
-	p = s;
-	while (*p)
-		p++;
-	while (s <= p) {
-		if (*p == c) {
-			/* LINTED interface specification */
-			return (wchar_t *)p;
-		}
-		p--;
-	}
-	return NULL;
+	do {
+		if (*s == c)
+			save = s;
+	} while (*s++);
+
+	/* LINTED interface specification */
+	return (wchar_t *)save;
 }
Index: wcsstr.c
===================================================================
RCS file: /cvsroot/src/lib/libc/string/wcsstr.c,v
retrieving revision 1.3
diff -u -r1.3 wcsstr.c
--- wcsstr.c	2003/03/05 20:18:17	1.3
+++ wcsstr.c	2003/11/16 07:47:30
@@ -56,17 +56,18 @@
 		/* LINTED interface specification */
 		return (wchar_t *)big;
 	}
-	if (wcslen(big) < wcslen(little))
-		return NULL;
 
 	p = big;
-	q = little;
 	while (*p) {
 		q = little;
 		r = p;
 		while (*q) {
-			if (*r != *q)
+			if (*r != *q) {
+				if (!*r)
+					return NULL;
 				break;
+			}
+				
 			q++;
 			r++;
 		}
Index: wmemchr.c
===================================================================
RCS file: /cvsroot/src/lib/libc/string/wmemchr.c,v
retrieving revision 1.2
diff -u -r1.2 wmemchr.c
--- wmemchr.c	2001/01/03 14:29:37	1.2
+++ wmemchr.c	2003/11/16 07:47:30
@@ -42,11 +42,10 @@
 	wchar_t c;
 	size_t n;
 {
-	size_t i;
 
 	_DIAGASSERT(s != NULL);
 
-	for (i = 0; i < n; i++) {
+	while (n--) {
 		if (*s == c) {
 			/* LINTED const castaway */
 			return (wchar_t *)s;
Index: wmemcmp.c
===================================================================
RCS file: /cvsroot/src/lib/libc/string/wmemcmp.c,v
retrieving revision 1.3
diff -u -r1.3 wmemcmp.c
--- wmemcmp.c	2003/04/06 18:33:23	1.3
+++ wmemcmp.c	2003/11/16 07:47:30
@@ -43,12 +43,11 @@
 	const wchar_t *s2;
 	size_t n;
 {
-	size_t i;
 
 	_DIAGASSERT(s1 != NULL);
 	_DIAGASSERT(s2 != NULL);
 
-	for (i = 0; i < n; i++) {
+	while (n--) {
 		if (*s1 != *s2) {
 			/* wchar might be unsigned */
 			return *(const __nbrune_t *)s1 >
Index: wmemset.c
===================================================================
RCS file: /cvsroot/src/lib/libc/string/wmemset.c,v
retrieving revision 1.2
diff -u -r1.2 wmemset.c
--- wmemset.c	2001/01/03 14:29:37	1.2
+++ wmemset.c	2003/11/16 07:47:31
@@ -42,15 +42,12 @@
 	wchar_t c;
 	size_t n;
 {
-	size_t i;
 	wchar_t *p;
 
 	_DIAGASSERT(s != NULL);
 
-	p = (wchar_t *)s;
-	for (i = 0; i < n; i++) {
+	for (p = (wchar_t *)s; n--; p++)
 		*p = c;
-		p++;
-	}
+
 	return s;
 }
>Release-Note:
>Audit-Trail:
>Unformatted: