Fix overload sets of strchr, strpbrk, strrchr, memchr and strstr from
<string.h> and wcschr, wcspbrk, wcsrchr, wmemchr, and wcsstr from <wchar.h> to provide a const-correct overload set even when the underlying C library does not. This change adds a new macro, _LIBCPP_PREFERRED_OVERLOAD, which (if defined) specifies that a given overload is a better match than an otherwise equally good function declaration without the overload. This is implemented in modern versions of Clang via __attribute__((enable_if)), and not elsewhere. We use this new macro to define overloads in the global namespace for these functions that displace the overloads provided by the C library, unless we believe the C library is already providing the correct signatures. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@260337 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -47,4 +47,15 @@ int main()
|
||||
static_assert((std::is_same<decltype(memset(vp, 0, s)), void*>::value), "");
|
||||
static_assert((std::is_same<decltype(strerror(0)), char*>::value), "");
|
||||
static_assert((std::is_same<decltype(strlen(cpc)), size_t>::value), "");
|
||||
|
||||
// These tests fail on systems whose C library doesn't provide a correct overload
|
||||
// set for strchr, strpbrk, strrchr, strstr, and memchr, unless the compiler is
|
||||
// a suitably recent version of Clang.
|
||||
#if !defined(__APPLE__) || defined(_LIBCPP_PREFERRED_OVERLOAD)
|
||||
static_assert((std::is_same<decltype(strchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(strpbrk(cpc, cpc)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(strrchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(strstr(cpc, cpc)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(memchr(vpc, 0, s)), const void*>::value), "");
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -9,7 +9,6 @@
|
||||
|
||||
// <wchar.h>
|
||||
|
||||
|
||||
#include <wchar.h>
|
||||
#include <type_traits>
|
||||
|
||||
@@ -82,19 +81,14 @@ int main()
|
||||
static_assert((std::is_same<decltype(wcscoll(L"", L"")), int>::value), "");
|
||||
static_assert((std::is_same<decltype(wcsncmp(L"", L"", s)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(wcsxfrm(ws, L"", s)), size_t>::value), "");
|
||||
// const wchar_t* wcschr((const wchar_t*)0, L' ') - See below
|
||||
static_assert((std::is_same<decltype(wcschr((wchar_t*)0, L' ')), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wcscspn(L"", L"")), size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(wcslen(L"")), size_t>::value), "");
|
||||
// const wchar_t* wcspbrk((const wchar_t*)0, L"") - See below
|
||||
static_assert((std::is_same<decltype(wcspbrk((wchar_t*)0, L"")), wchar_t*>::value), "");
|
||||
// const wchar_t* wcsrchr((const wchar_t*)0, L' ') - See below
|
||||
static_assert((std::is_same<decltype(wcsrchr((wchar_t*)0, L' ')), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wcsspn(L"", L"")), size_t>::value), "");
|
||||
// const wchar_t* wcsstr((const wchar_t*)0, L"") - See below
|
||||
static_assert((std::is_same<decltype(wcsstr((wchar_t*)0, L"")), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wcstok(ws, L"", (wchar_t**)0)), wchar_t*>::value), "");
|
||||
// const wchar_t* wmemchr((const wchar_t*)0, L' ', s) - See below
|
||||
static_assert((std::is_same<decltype(wmemchr((wchar_t*)0, L' ', s)), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wmemcmp(L"", L"", s)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(wmemcpy(ws, L"", s)), wchar_t*>::value), "");
|
||||
@@ -110,10 +104,10 @@ int main()
|
||||
static_assert((std::is_same<decltype(mbsrtowcs(ws, (const char**)0, s, &mb)), size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(wcsrtombs(ns, (const wchar_t**)0, s, &mb)), size_t>::value), "");
|
||||
|
||||
// This test fails on systems whose C library doesn't provide a correct overload
|
||||
// set for wcschr, wcspbrk, wcsrchr, wcsstr, and wmemchr. There's no way for
|
||||
// libc++ to fix that on the C library's behalf.
|
||||
#ifndef __APPLE__
|
||||
// These tests fail on systems whose C library doesn't provide a correct overload
|
||||
// set for wcschr, wcspbrk, wcsrchr, wcsstr, and wmemchr, unless the compiler is
|
||||
// a suitably recent version of Clang.
|
||||
#if !defined(__APPLE__) || defined(_LIBCPP_PREFERRED_OVERLOAD)
|
||||
static_assert((std::is_same<decltype(wcschr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wcspbrk((const wchar_t*)0, L"")), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(wcsrchr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
|
||||
@@ -34,17 +34,12 @@ int main()
|
||||
static_assert((std::is_same<decltype(std::strncmp(cpc, cpc, s)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strcoll(cpc, cpc)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strxfrm(cp, cpc, s)), std::size_t>::value), "");
|
||||
// static_assert((std::is_same<decltype(std::memchr(vpc, 0, s)), const void*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::memchr(vp, 0, s)), void*>::value), "");
|
||||
// static_assert((std::is_same<decltype(std::strchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strchr(cp, 0)), char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strcspn(cpc, cpc)), std::size_t>::value), "");
|
||||
// static_assert((std::is_same<decltype(std::strpbrk(cpc, cpc)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strpbrk(cp, cpc)), char*>::value), "");
|
||||
// static_assert((std::is_same<decltype(std::strrchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strrchr(cp, 0)), char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strspn(cpc, cpc)), std::size_t>::value), "");
|
||||
// static_assert((std::is_same<decltype(std::strstr(cpc, cpc)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strstr(cp, cpc)), char*>::value), "");
|
||||
#ifndef _LIBCPP_HAS_NO_THREAD_UNSAFE_C_FUNCTIONS
|
||||
static_assert((std::is_same<decltype(std::strtok(cp, cpc)), char*>::value), "");
|
||||
@@ -52,4 +47,15 @@ int main()
|
||||
static_assert((std::is_same<decltype(std::memset(vp, 0, s)), void*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strerror(0)), char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strlen(cpc)), std::size_t>::value), "");
|
||||
|
||||
// These tests fail on systems whose C library doesn't provide a correct overload
|
||||
// set for strchr, strpbrk, strrchr, strstr, and memchr, unless the compiler is
|
||||
// a suitably recent version of Clang.
|
||||
#if !defined(__APPLE__) || defined(_LIBCPP_PREFERRED_OVERLOAD)
|
||||
static_assert((std::is_same<decltype(std::memchr(vpc, 0, s)), const void*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strpbrk(cpc, cpc)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strrchr(cpc, 0)), const char*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::strstr(cpc, cpc)), const char*>::value), "");
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -73,19 +73,14 @@ int main()
|
||||
static_assert((std::is_same<decltype(std::wcscoll(L"", L"")), int>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsncmp(L"", L"", s)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsxfrm(ws, L"", s)), std::size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcschr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcschr((wchar_t*)0, L' ')), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcscspn(L"", L"")), std::size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcslen(L"")), std::size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcspbrk((const wchar_t*)0, L"")), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcspbrk((wchar_t*)0, L"")), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsrchr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsrchr((wchar_t*)0, L' ')), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsspn(L"", L"")), std::size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsstr((const wchar_t*)0, L"")), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsstr((wchar_t*)0, L"")), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcstok(ws, L"", (wchar_t**)0)), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wmemchr((const wchar_t*)0, L' ', s)), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wmemchr((wchar_t*)0, L' ', s)), wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wmemcmp(L"", L"", s)), int>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wmemcpy(ws, L"", s)), wchar_t*>::value), "");
|
||||
@@ -101,6 +96,17 @@ int main()
|
||||
static_assert((std::is_same<decltype(std::mbsrtowcs(ws, (const char**)0, s, &mb)), std::size_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsrtombs(ns, (const wchar_t**)0, s, &mb)), std::size_t>::value), "");
|
||||
|
||||
// These tests fail on systems whose C library doesn't provide a correct overload
|
||||
// set for wcschr, wcspbrk, wcsrchr, wcsstr, and wmemchr, unless the compiler is
|
||||
// a suitably recent version of Clang.
|
||||
#if !defined(__APPLE__) || defined(_LIBCPP_PREFERRED_OVERLOAD)
|
||||
static_assert((std::is_same<decltype(std::wcschr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcspbrk((const wchar_t*)0, L"")), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsrchr((const wchar_t*)0, L' ')), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wcsstr((const wchar_t*)0, L"")), const wchar_t*>::value), "");
|
||||
static_assert((std::is_same<decltype(std::wmemchr((const wchar_t*)0, L' ', s)), const wchar_t*>::value), "");
|
||||
#endif
|
||||
|
||||
#ifndef _LIBCPP_HAS_NO_STDIN
|
||||
static_assert((std::is_same<decltype(std::getwchar()), std::wint_t>::value), "");
|
||||
static_assert((std::is_same<decltype(std::vwscanf(L"", va)), int>::value), "");
|
||||
|
||||
Reference in New Issue
Block a user