//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++98, c++03 // // class path // template // path& operator=(Source const&); // template // path& assign(Source const&); // template // path& assign(InputIterator first, InputIterator last); #include #include #include #include "test_macros.h" #include "test_iterators.h" #include "count_new.hpp" #include "filesystem_test_helper.hpp" #include namespace fs = std::experimental::filesystem; template void RunTestCase(MultiStringType const& MS) { using namespace fs; const char* Expect = MS; const CharT* TestPath = MS; const CharT* TestPathEnd = StrEnd(TestPath); const std::size_t Size = TestPathEnd - TestPath; const std::size_t SSize = StrEnd(Expect) - Expect; assert(Size == SSize); ////////////////////////////////////////////////////////////////////////////// // basic_string { const std::basic_string S(TestPath); path p; PathReserve(p, S.length() + 1); { // string provides a contigious iterator. No allocation needed. DisableAllocationGuard g; path& pref = (p = S); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); assert(p.string() == S); } { const std::basic_string S(TestPath); path p; PathReserve(p, S.length() + 1); { DisableAllocationGuard g; path& pref = p.assign(S); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); assert(p.string() == S); } ////////////////////////////////////////////////////////////////////////////// // Char* pointers { path p; PathReserve(p, Size + 1); { // char* pointers are contigious and can be used with code_cvt directly. // no allocations needed. DisableAllocationGuard g; path& pref = (p = TestPath); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } { path p; PathReserve(p, Size + 1); { DisableAllocationGuard g; path& pref = p.assign(TestPath); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } { path p; PathReserve(p, Size + 1); { DisableAllocationGuard g; path& pref = p.assign(TestPath, TestPathEnd); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } ////////////////////////////////////////////////////////////////////////////// // Iterators { using It = input_iterator; path p; PathReserve(p, Size + 1); It it(TestPath); { // Iterators cannot be used with code_cvt directly. This assignment // may allocate if it's larger than a "short-string". path& pref = (p = it); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } { using It = input_iterator; path p; PathReserve(p, Size + 1); It it(TestPath); { path& pref = p.assign(it); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } { using It = input_iterator; path p; PathReserve(p, Size + 1); It it(TestPath); It e(TestPathEnd); { path& pref = p.assign(it, e); assert(&pref == &p); } assert(p.native() == Expect); assert(p.string() == TestPath); } } int main() { for (auto const& MS : PathList) { RunTestCase(MS); RunTestCase(MS); RunTestCase(MS); RunTestCase(MS); } }