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