[libc] wcscspn implementation (#146158)
Implemented wcscspn and tests. --------- Co-authored-by: Sriya Pratipati <sriyap@google.com>
This commit is contained in:
@@ -376,6 +376,7 @@ set(TARGET_LIBC_ENTRYPOINTS
|
|||||||
libc.src.wchar.wcspbrk
|
libc.src.wchar.wcspbrk
|
||||||
libc.src.wchar.wcsrchr
|
libc.src.wchar.wcsrchr
|
||||||
libc.src.wchar.wcsspn
|
libc.src.wchar.wcsspn
|
||||||
|
libc.src.wchar.wcscspn
|
||||||
libc.src.wchar.wmemcmp
|
libc.src.wchar.wmemcmp
|
||||||
libc.src.wchar.wmempcpy
|
libc.src.wchar.wmempcpy
|
||||||
libc.src.wchar.wmemcpy
|
libc.src.wchar.wmemcpy
|
||||||
|
|||||||
@@ -104,6 +104,13 @@ functions:
|
|||||||
arguments:
|
arguments:
|
||||||
- type: const wchar_t *
|
- type: const wchar_t *
|
||||||
- type: const wchar_t *
|
- type: const wchar_t *
|
||||||
|
- name: wcscspn
|
||||||
|
standards:
|
||||||
|
- stdc
|
||||||
|
return_type: size_t
|
||||||
|
arguments:
|
||||||
|
- type: const wchar_t *
|
||||||
|
- type: const wchar_t *
|
||||||
- name: wmemcmp
|
- name: wmemcmp
|
||||||
standards:
|
standards:
|
||||||
- stdc
|
- stdc
|
||||||
|
|||||||
@@ -213,6 +213,17 @@ add_entrypoint_object(
|
|||||||
libc.hdr.types.size_t
|
libc.hdr.types.size_t
|
||||||
)
|
)
|
||||||
|
|
||||||
|
add_entrypoint_object(
|
||||||
|
wcscspn
|
||||||
|
SRCS
|
||||||
|
wcscspn.cpp
|
||||||
|
HDRS
|
||||||
|
wcscspn.h
|
||||||
|
DEPENDS
|
||||||
|
libc.hdr.wchar_macros
|
||||||
|
libc.hdr.types.size_t
|
||||||
|
)
|
||||||
|
|
||||||
add_entrypoint_object(
|
add_entrypoint_object(
|
||||||
wmemcmp
|
wmemcmp
|
||||||
SRCS
|
SRCS
|
||||||
|
|||||||
34
libc/src/wchar/wcscspn.cpp
Normal file
34
libc/src/wchar/wcscspn.cpp
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
//===-- Implementation of wcscspn -----------------------------------------===//
|
||||||
|
//
|
||||||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "src/wchar/wcscspn.h"
|
||||||
|
|
||||||
|
#include "hdr/types/size_t.h"
|
||||||
|
#include "hdr/types/wchar_t.h"
|
||||||
|
#include "src/__support/common.h"
|
||||||
|
#include "src/__support/macros/config.h"
|
||||||
|
|
||||||
|
namespace LIBC_NAMESPACE_DECL {
|
||||||
|
|
||||||
|
bool check(wchar_t c, const wchar_t *s2) {
|
||||||
|
for (int n = 0; s2[n]; ++n) {
|
||||||
|
if (s2[n] == c)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
LLVM_LIBC_FUNCTION(size_t, wcscspn, (const wchar_t *s1, const wchar_t *s2)) {
|
||||||
|
size_t i = 0;
|
||||||
|
for (; s1[i]; ++i) {
|
||||||
|
if (!check(s1[i], s2))
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace LIBC_NAMESPACE_DECL
|
||||||
22
libc/src/wchar/wcscspn.h
Normal file
22
libc/src/wchar/wcscspn.h
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
//===-- Implementation header for wcscspn ---------------------------------===//
|
||||||
|
//
|
||||||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef LLVM_LIBC_SRC_WCHAR_WCSCSPN_H
|
||||||
|
#define LLVM_LIBC_SRC_WCHAR_WCSCSPN_H
|
||||||
|
|
||||||
|
#include "hdr/types/size_t.h"
|
||||||
|
#include "hdr/types/wchar_t.h"
|
||||||
|
#include "src/__support/macros/config.h"
|
||||||
|
|
||||||
|
namespace LIBC_NAMESPACE_DECL {
|
||||||
|
|
||||||
|
size_t wcscspn(const wchar_t *s1, const wchar_t *s2);
|
||||||
|
|
||||||
|
} // namespace LIBC_NAMESPACE_DECL
|
||||||
|
|
||||||
|
#endif // LLVM_LIBC_SRC_WCHAR_WCSCSPN_H
|
||||||
@@ -183,6 +183,16 @@ add_libc_test(
|
|||||||
libc.src.wchar.wcsspn
|
libc.src.wchar.wcsspn
|
||||||
)
|
)
|
||||||
|
|
||||||
|
add_libc_test(
|
||||||
|
wcscspn_test
|
||||||
|
SUITE
|
||||||
|
libc_wchar_unittests
|
||||||
|
SRCS
|
||||||
|
wcscspn_test.cpp
|
||||||
|
DEPENDS
|
||||||
|
libc.src.wchar.wcscspn
|
||||||
|
)
|
||||||
|
|
||||||
add_libc_test(
|
add_libc_test(
|
||||||
wmemchr_test
|
wmemchr_test
|
||||||
SUITE
|
SUITE
|
||||||
|
|||||||
67
libc/test/src/wchar/wcscspn_test.cpp
Normal file
67
libc/test/src/wchar/wcscspn_test.cpp
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
//===-- Unittests for wcscspn ---------------------------------------------===//
|
||||||
|
//
|
||||||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "hdr/types/size_t.h"
|
||||||
|
#include "hdr/types/wchar_t.h"
|
||||||
|
#include "src/wchar/wcscspn.h"
|
||||||
|
#include "test/UnitTest/Test.h"
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, EmptyStringShouldReturnZeroLengthSpan) {
|
||||||
|
// The search should not include the null terminator.
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"", L""), size_t(0));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"_", L""), size_t(1));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"", L"_"), size_t(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, ShouldNotSpanAnythingAfterNullTerminator) {
|
||||||
|
const wchar_t src[4] = {L'a', L'b', L'\0', L'c'};
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"de"), size_t(2));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"c"), size_t(2));
|
||||||
|
|
||||||
|
// Same goes for the segment to be searched for.
|
||||||
|
const wchar_t segment[4] = {L'1', L'2', L'\0', L'3'};
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"3", segment), size_t(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, SpanEachIndividualCharacter) {
|
||||||
|
const wchar_t *src = L"12345";
|
||||||
|
// These are all in the segment.
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"1"), size_t(0));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"2"), size_t(1));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"3"), size_t(2));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"4"), size_t(3));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"5"), size_t(4));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, UnmatchedCharacterShouldReturnLength) {
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"a", L"b"), size_t(1));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"abcdef", L"1"), size_t(6));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"123", L"4"), size_t(3));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, NonSequentialCharactersShouldNotSpan) {
|
||||||
|
const wchar_t *src = L"abc456789";
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"_1_abc_2_def_3_"), size_t(0));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(src, L"67__34xyz12"), size_t(3));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, ReverseCharacters) {
|
||||||
|
// These are all in the string.
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"12345", L"54321"), size_t(0));
|
||||||
|
// 1 is not in the span.
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"12345", L"432"), size_t(1));
|
||||||
|
// 1 is in the span.
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"12345", L"51"), size_t(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(LlvmLibcWCSCSpnTest, DuplicatedCharactersToBeSearchedForShouldStillMatch) {
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"a", L"aa"), size_t(0));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"aa", L"aa"), size_t(0));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"aaa", L"bb"), size_t(3));
|
||||||
|
EXPECT_EQ(LIBC_NAMESPACE::wcscspn(L"aaaa", L"bb"), size_t(4));
|
||||||
|
}
|
||||||
@@ -5815,6 +5815,18 @@ libc_function(
|
|||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
libc_function(
|
||||||
|
name = "wcscspn",
|
||||||
|
srcs = ["src/wchar/wcscspn.cpp"],
|
||||||
|
hdrs = ["src/wchar/wcscspn.h"],
|
||||||
|
deps = [
|
||||||
|
":__support_common",
|
||||||
|
":__support_macros_config",
|
||||||
|
":types_size_t",
|
||||||
|
":types_wchar_t",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
libc_function(
|
libc_function(
|
||||||
name = "wcslen",
|
name = "wcslen",
|
||||||
srcs = ["src/wchar/wcslen.cpp"],
|
srcs = ["src/wchar/wcslen.cpp"],
|
||||||
|
|||||||
@@ -73,6 +73,16 @@ libc_test(
|
|||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
libc_test(
|
||||||
|
name = "wcscspn_test",
|
||||||
|
srcs = ["wcscspn_test.cpp"],
|
||||||
|
deps = [
|
||||||
|
"//libc:types_size_t",
|
||||||
|
"//libc:types_wchar_t",
|
||||||
|
"//libc:wcscspn",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
libc_test(
|
libc_test(
|
||||||
name = "wcslen_test",
|
name = "wcslen_test",
|
||||||
srcs = ["wcslen_test.cpp"],
|
srcs = ["wcslen_test.cpp"],
|
||||||
|
|||||||
Reference in New Issue
Block a user