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 Klauser TEST_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 Klauser int 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