Merge "Replace our broken wcswcs with the working upstream one."
This commit is contained in:
commit
0fd2e87a0c
@ -246,7 +246,6 @@ libc_upstream_freebsd_src_files := \
|
|||||||
upstream-freebsd/lib/libc/string/wcsnlen.c \
|
upstream-freebsd/lib/libc/string/wcsnlen.c \
|
||||||
upstream-freebsd/lib/libc/string/wcspbrk.c \
|
upstream-freebsd/lib/libc/string/wcspbrk.c \
|
||||||
upstream-freebsd/lib/libc/string/wcsspn.c \
|
upstream-freebsd/lib/libc/string/wcsspn.c \
|
||||||
upstream-freebsd/lib/libc/string/wcsstr.c \
|
|
||||||
upstream-freebsd/lib/libc/string/wcstok.c \
|
upstream-freebsd/lib/libc/string/wcstok.c \
|
||||||
upstream-freebsd/lib/libc/string/wmemchr.c \
|
upstream-freebsd/lib/libc/string/wmemchr.c \
|
||||||
upstream-freebsd/lib/libc/string/wmemcpy.c \
|
upstream-freebsd/lib/libc/string/wmemcpy.c \
|
||||||
@ -419,6 +418,8 @@ libc_upstream_openbsd_src_files := \
|
|||||||
upstream-openbsd/lib/libc/string/strstr.c \
|
upstream-openbsd/lib/libc/string/strstr.c \
|
||||||
upstream-openbsd/lib/libc/string/strtok.c \
|
upstream-openbsd/lib/libc/string/strtok.c \
|
||||||
upstream-openbsd/lib/libc/string/wcslcpy.c \
|
upstream-openbsd/lib/libc/string/wcslcpy.c \
|
||||||
|
upstream-openbsd/lib/libc/string/wcsstr.c \
|
||||||
|
upstream-openbsd/lib/libc/string/wcswcs.c \
|
||||||
upstream-openbsd/lib/libc/string/wcswidth.c \
|
upstream-openbsd/lib/libc/string/wcswidth.c \
|
||||||
|
|
||||||
libc_arch_static_src_files := \
|
libc_arch_static_src_files := \
|
||||||
|
@ -296,12 +296,6 @@ unsigned long int wcstoul(const wchar_t* nptr, wchar_t** endptr, int base) {
|
|||||||
return strtoul(reinterpret_cast<const char*>(nptr), reinterpret_cast<char**>(endptr), base);
|
return strtoul(reinterpret_cast<const char*>(nptr), reinterpret_cast<char**>(endptr), base);
|
||||||
}
|
}
|
||||||
|
|
||||||
wchar_t* wcswcs(const wchar_t* ws1, const wchar_t* ws2) {
|
|
||||||
const char* s1 = reinterpret_cast<const char*>(ws1);
|
|
||||||
const char* s2 = reinterpret_cast<const char*>(ws2);
|
|
||||||
return reinterpret_cast<wchar_t*>(strstr(s1, s2));
|
|
||||||
}
|
|
||||||
|
|
||||||
int wctob(wint_t c) {
|
int wctob(wint_t c) {
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
|
/* $OpenBSD: wcsstr.c,v 1.3 2005/08/08 08:05:37 espie Exp $ */
|
||||||
|
/* $NetBSD: wcsstr.c,v 1.3 2003/03/05 20:18:17 tshiozak Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990, 1993
|
* Copyright (c)1999 Citrus Project,
|
||||||
* The Regents of the University of California. All rights reserved.
|
* All rights reserved.
|
||||||
*
|
|
||||||
* This code is derived from software contributed to Berkeley by
|
|
||||||
* Chris Torek.
|
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -13,14 +13,11 @@
|
|||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
* documentation and/or other materials provided with the distribution.
|
* documentation and/or other materials provided with the distribution.
|
||||||
* 3. Neither the name of the University nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
@ -28,36 +25,46 @@
|
|||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* citrus Id: wcsstr.c,v 1.2 2000/12/21 05:07:25 itojun Exp
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if 0
|
|
||||||
#if defined(LIBC_SCCS) && !defined(lint)
|
|
||||||
static char sccsid[] = "@(#)strstr.c 8.1 (Berkeley) 6/4/93";
|
|
||||||
#endif /* LIBC_SCCS and not lint */
|
|
||||||
#endif
|
|
||||||
#include <sys/cdefs.h>
|
|
||||||
__FBSDID("$FreeBSD$");
|
|
||||||
|
|
||||||
#include <wchar.h>
|
#include <wchar.h>
|
||||||
|
|
||||||
/*
|
|
||||||
* Find the first occurrence of find in s.
|
|
||||||
*/
|
|
||||||
wchar_t *
|
wchar_t *
|
||||||
wcsstr(const wchar_t * __restrict s, const wchar_t * __restrict find)
|
#ifdef WCSWCS
|
||||||
|
wcswcs(const wchar_t *big, const wchar_t *little)
|
||||||
|
#else
|
||||||
|
wcsstr(const wchar_t *big, const wchar_t *little)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
wchar_t c, sc;
|
const wchar_t *p;
|
||||||
size_t len;
|
const wchar_t *q;
|
||||||
|
const wchar_t *r;
|
||||||
|
|
||||||
if ((c = *find++) != L'\0') {
|
if (!*little) {
|
||||||
len = wcslen(find);
|
/* LINTED interface specification */
|
||||||
do {
|
return (wchar_t *)big;
|
||||||
do {
|
|
||||||
if ((sc = *s++) == L'\0')
|
|
||||||
return (NULL);
|
|
||||||
} while (sc != c);
|
|
||||||
} while (wcsncmp(s, find, len) != 0);
|
|
||||||
s--;
|
|
||||||
}
|
}
|
||||||
return ((wchar_t *)s);
|
if (wcslen(big) < wcslen(little))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
p = big;
|
||||||
|
q = little;
|
||||||
|
while (*p) {
|
||||||
|
q = little;
|
||||||
|
r = p;
|
||||||
|
while (*q) {
|
||||||
|
if (*r != *q)
|
||||||
|
break;
|
||||||
|
q++;
|
||||||
|
r++;
|
||||||
|
}
|
||||||
|
if (!*q) {
|
||||||
|
/* LINTED interface specification */
|
||||||
|
return (wchar_t *)p;
|
||||||
|
}
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
}
|
}
|
5
libc/upstream-openbsd/lib/libc/string/wcswcs.c
Normal file
5
libc/upstream-openbsd/lib/libc/string/wcswcs.c
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
/* $OpenBSD: wcswcs.c,v 1.1 2005/04/13 16:35:58 espie Exp $ */
|
||||||
|
/* $NetBSD: wcswcs.c,v 1.1 2003/03/05 20:18:17 tshiozak Exp $ */
|
||||||
|
|
||||||
|
#define WCSWCS
|
||||||
|
#include "wcsstr.c"
|
@ -159,3 +159,18 @@ TEST(wchar, wcstombs_wcrtombs) {
|
|||||||
TEST(wchar, limits) {
|
TEST(wchar, limits) {
|
||||||
ASSERT_LT(WCHAR_MIN, WCHAR_MAX);
|
ASSERT_LT(WCHAR_MIN, WCHAR_MAX);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(wchar, wcsstr_wcswcs) {
|
||||||
|
const wchar_t* haystack = L"matches hello world, not the second hello world";
|
||||||
|
const wchar_t* empty_needle = L"";
|
||||||
|
const wchar_t* good_needle = L"ll";
|
||||||
|
const wchar_t* bad_needle = L"wort";
|
||||||
|
|
||||||
|
ASSERT_EQ(haystack, wcsstr(haystack, empty_needle));
|
||||||
|
ASSERT_EQ(&haystack[10], wcsstr(haystack, good_needle));
|
||||||
|
ASSERT_EQ(NULL, wcsstr(haystack, bad_needle));
|
||||||
|
|
||||||
|
ASSERT_EQ(haystack, wcswcs(haystack, empty_needle));
|
||||||
|
ASSERT_EQ(&haystack[10], wcswcs(haystack, good_needle));
|
||||||
|
ASSERT_EQ(NULL, wcswcs(haystack, bad_needle));
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user