//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // UNSUPPORTED: c++03, c++11, c++14 // template // > // basic_string(basic_string_view, const Allocator& = Allocator()) // -> basic_string; // // The deduction guide shall not participate in overload resolution if Allocator // is a type that does not qualify as an allocator. #include #include #include #include #include #include #include #include "test_macros.h" #include "test_allocator.h" #include "min_allocator.h" template struct CanDeduce : std::false_type {}; template struct CanDeduce(), std::declval()})> : std::true_type {}; struct NotAnAllocator {}; static_assert(CanDeduce>::value); static_assert(!CanDeduce::value); TEST_CONSTEXPR_CXX20 bool test() { { std::string_view sv = "12345678901234"; std::basic_string s1(sv); using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } { std::string_view sv = "12345678901234"; std::basic_string s1{sv, std::allocator{}}; using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } #ifndef TEST_HAS_NO_WIDE_CHARACTERS { std::wstring_view sv = L"12345678901234"; std::basic_string s1{sv, test_allocator{}}; using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } #endif #ifndef TEST_HAS_NO_CHAR8_T { std::u8string_view sv = u8"12345678901234"; std::basic_string s1{sv, min_allocator{}}; using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } #endif { std::u16string_view sv = u"12345678901234"; std::basic_string s1{sv, min_allocator{}}; using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } { std::u32string_view sv = U"12345678901234"; std::basic_string s1{sv, explicit_allocator{}}; using S = decltype(s1); // what type did we get? static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); static_assert(std::is_same_v>, ""); assert(s1.size() == sv.size()); assert(s1.compare(0, s1.size(), sv.data(), s1.size()) == 0); } return true; } int main(int, char**) { test(); #if TEST_STD_VER > 17 static_assert(test()); #endif return 0; }