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 9*425620ccSNikolas Klauser // XFAIL: LIBCXX-AIX-FIXME 10*425620ccSNikolas Klauser 115a83710eSEric Fiselier // <string> 125a83710eSEric Fiselier 13*425620ccSNikolas Klauser // const_reference operator[](size_type pos) const; // constexpr since C++20 14*425620ccSNikolas Klauser // reference operator[](size_type pos); // constexpr since C++20 155a83710eSEric Fiselier 165a83710eSEric Fiselier #include <string> 175a83710eSEric Fiselier #include <cassert> 185a83710eSEric Fiselier 197fc6a556SMarshall Clow #include "test_macros.h" 205a83710eSEric Fiselier #include "min_allocator.h" 215a83710eSEric Fiselier 22*425620ccSNikolas Klauser TEST_CONSTEXPR_CXX20 bool test() { 235a83710eSEric Fiselier { 245a83710eSEric Fiselier typedef std::string S; 255a83710eSEric Fiselier S s("0123456789"); 265a83710eSEric Fiselier const S& cs = s; 279ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 289ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 299ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 309ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 315a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 325a83710eSEric Fiselier { 33e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 345a83710eSEric Fiselier assert(cs[i] == s[i]); 355a83710eSEric Fiselier } 365a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 375a83710eSEric Fiselier const S s2 = S(); 385a83710eSEric Fiselier assert(s2[0] == '\0'); 395a83710eSEric Fiselier } 40f2f2a639SEric Fiselier #if TEST_STD_VER >= 11 415a83710eSEric Fiselier { 425a83710eSEric Fiselier typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S; 435a83710eSEric Fiselier S s("0123456789"); 445a83710eSEric Fiselier const S& cs = s; 459ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 469ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 479ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 489ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 495a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 505a83710eSEric Fiselier { 51e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 525a83710eSEric Fiselier assert(cs[i] == s[i]); 535a83710eSEric Fiselier } 545a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 555a83710eSEric Fiselier const S s2 = S(); 565a83710eSEric Fiselier assert(s2[0] == '\0'); 575a83710eSEric Fiselier } 585a83710eSEric Fiselier #endif 592df59c50SJF Bastien 60e85018b7SNikolas Klauser return true; 61e85018b7SNikolas Klauser } 62e85018b7SNikolas Klauser 63e85018b7SNikolas Klauser int main(int, char**) 64e85018b7SNikolas Klauser { 65e85018b7SNikolas Klauser test(); 66e85018b7SNikolas Klauser #if TEST_STD_VER > 17 67*425620ccSNikolas Klauser static_assert(test()); 68e85018b7SNikolas Klauser #endif 69e85018b7SNikolas Klauser 702df59c50SJF Bastien return 0; 715a83710eSEric Fiselier } 72