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 // const_reference operator[](size_type pos) const; // constexpr since C++20 12*425620ccSNikolas Klauser // reference operator[](size_type pos); // constexpr since C++20 135a83710eSEric Fiselier 145a83710eSEric Fiselier #include <string> 155a83710eSEric Fiselier #include <cassert> 165a83710eSEric Fiselier 177fc6a556SMarshall Clow #include "test_macros.h" 185a83710eSEric Fiselier #include "min_allocator.h" 195a83710eSEric Fiselier test()20*425620ccSNikolas KlauserTEST_CONSTEXPR_CXX20 bool test() { 215a83710eSEric Fiselier { 225a83710eSEric Fiselier typedef std::string S; 235a83710eSEric Fiselier S s("0123456789"); 245a83710eSEric Fiselier const S& cs = s; 259ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 269ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 279ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 289ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 295a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 305a83710eSEric Fiselier { 31e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 325a83710eSEric Fiselier assert(cs[i] == s[i]); 335a83710eSEric Fiselier } 345a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 355a83710eSEric Fiselier const S s2 = S(); 365a83710eSEric Fiselier assert(s2[0] == '\0'); 375a83710eSEric Fiselier } 38f2f2a639SEric Fiselier #if TEST_STD_VER >= 11 395a83710eSEric Fiselier { 405a83710eSEric Fiselier typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S; 415a83710eSEric Fiselier S s("0123456789"); 425a83710eSEric Fiselier const S& cs = s; 439ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 449ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 459ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 469ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 475a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 485a83710eSEric Fiselier { 49e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 505a83710eSEric Fiselier assert(cs[i] == s[i]); 515a83710eSEric Fiselier } 525a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 535a83710eSEric Fiselier const S s2 = S(); 545a83710eSEric Fiselier assert(s2[0] == '\0'); 555a83710eSEric Fiselier } 565a83710eSEric Fiselier #endif 572df59c50SJF Bastien 58e85018b7SNikolas Klauser return true; 59e85018b7SNikolas Klauser } 60e85018b7SNikolas Klauser main(int,char **)61e85018b7SNikolas Klauserint main(int, char**) 62e85018b7SNikolas Klauser { 63e85018b7SNikolas Klauser test(); 64e85018b7SNikolas Klauser #if TEST_STD_VER > 17 65*425620ccSNikolas Klauser static_assert(test()); 66e85018b7SNikolas Klauser #endif 67e85018b7SNikolas Klauser 682df59c50SJF Bastien return 0; 695a83710eSEric Fiselier } 70