15a83710eSEric Fiselier //===----------------------------------------------------------------------===// 25a83710eSEric Fiselier // 357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information. 557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 65a83710eSEric Fiselier // 75a83710eSEric Fiselier //===----------------------------------------------------------------------===// 85a83710eSEric Fiselier 95a83710eSEric Fiselier // <string> 105a83710eSEric Fiselier 11*425620ccSNikolas Klauser // void shrink_to_fit(); // constexpr since C++20 125a83710eSEric Fiselier 135a83710eSEric Fiselier #include <string> 145a83710eSEric Fiselier #include <cassert> 155a83710eSEric Fiselier 161f4231f8SEric Fiselier #include "test_macros.h" 175a83710eSEric Fiselier #include "min_allocator.h" 185a83710eSEric Fiselier 195a83710eSEric Fiselier template <class S> 2085e9b268SNikolas Klauser TEST_CONSTEXPR_CXX20 void test(S s)215a83710eSEric Fiseliertest(S s) 225a83710eSEric Fiselier { 235a83710eSEric Fiselier typename S::size_type old_cap = s.capacity(); 245a83710eSEric Fiselier S s0 = s; 255a83710eSEric Fiselier s.shrink_to_fit(); 261f4231f8SEric Fiselier LIBCPP_ASSERT(s.__invariants()); 275a83710eSEric Fiselier assert(s == s0); 285a83710eSEric Fiselier assert(s.capacity() <= old_cap); 295a83710eSEric Fiselier assert(s.capacity() >= s.size()); 305a83710eSEric Fiselier } 315a83710eSEric Fiselier test()32*425620ccSNikolas KlauserTEST_CONSTEXPR_CXX20 bool test() { 335a83710eSEric Fiselier { 345a83710eSEric Fiselier typedef std::string S; 355a83710eSEric Fiselier S s; 365a83710eSEric Fiselier test(s); 375a83710eSEric Fiselier 385a83710eSEric Fiselier s.assign(10, 'a'); 395a83710eSEric Fiselier s.erase(5); 405a83710eSEric Fiselier test(s); 415a83710eSEric Fiselier 425a83710eSEric Fiselier s.assign(100, 'a'); 435a83710eSEric Fiselier s.erase(50); 445a83710eSEric Fiselier test(s); 455a83710eSEric Fiselier } 461f4231f8SEric Fiselier #if TEST_STD_VER >= 11 475a83710eSEric Fiselier { 485a83710eSEric Fiselier typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S; 495a83710eSEric Fiselier S s; 505a83710eSEric Fiselier test(s); 515a83710eSEric Fiselier 525a83710eSEric Fiselier s.assign(10, 'a'); 535a83710eSEric Fiselier s.erase(5); 545a83710eSEric Fiselier test(s); 555a83710eSEric Fiselier 565a83710eSEric Fiselier s.assign(100, 'a'); 575a83710eSEric Fiselier s.erase(50); 585a83710eSEric Fiselier test(s); 595a83710eSEric Fiselier } 605a83710eSEric Fiselier #endif 612df59c50SJF Bastien 62e85018b7SNikolas Klauser return true; 63e85018b7SNikolas Klauser } 64e85018b7SNikolas Klauser main(int,char **)65e85018b7SNikolas Klauserint main(int, char**) 66e85018b7SNikolas Klauser { 67e85018b7SNikolas Klauser test(); 68e85018b7SNikolas Klauser #if TEST_STD_VER > 17 69*425620ccSNikolas Klauser static_assert(test()); 70e85018b7SNikolas Klauser #endif 71e85018b7SNikolas Klauser 722df59c50SJF Bastien return 0; 735a83710eSEric Fiselier } 74