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 
115a83710eSEric Fiselier // const_reference operator[](size_type pos) const;
125a83710eSEric Fiselier //       reference operator[](size_type pos);
135a83710eSEric Fiselier 
145a83710eSEric Fiselier #ifdef _LIBCPP_DEBUG
155a83710eSEric Fiselier #define _LIBCPP_ASSERT(x, m) ((x) ? (void)0 : std::exit(0))
165a83710eSEric Fiselier #endif
175a83710eSEric Fiselier 
185a83710eSEric Fiselier #include <string>
195a83710eSEric Fiselier #include <cassert>
205a83710eSEric Fiselier 
21*7fc6a556SMarshall Clow #include "test_macros.h"
225a83710eSEric Fiselier #include "min_allocator.h"
235a83710eSEric Fiselier 
242df59c50SJF Bastien int main(int, char**)
255a83710eSEric Fiselier {
265a83710eSEric Fiselier     {
275a83710eSEric Fiselier     typedef std::string S;
285a83710eSEric Fiselier     S s("0123456789");
295a83710eSEric Fiselier     const S& cs = s;
309ea0e473SMarshall Clow     ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference);
319ea0e473SMarshall Clow     ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference);
329ea0e473SMarshall Clow     LIBCPP_ASSERT_NOEXCEPT(    s[0]);
339ea0e473SMarshall Clow     LIBCPP_ASSERT_NOEXCEPT(   cs[0]);
345a83710eSEric Fiselier     for (S::size_type i = 0; i < cs.size(); ++i)
355a83710eSEric Fiselier     {
36e9c72889SStephan T. Lavavej         assert(s[i] == static_cast<char>('0' + i));
375a83710eSEric Fiselier         assert(cs[i] == s[i]);
385a83710eSEric Fiselier     }
395a83710eSEric Fiselier     assert(cs[cs.size()] == '\0');
405a83710eSEric Fiselier     const S s2 = S();
415a83710eSEric Fiselier     assert(s2[0] == '\0');
425a83710eSEric Fiselier     }
43f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
445a83710eSEric Fiselier     {
455a83710eSEric Fiselier     typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S;
465a83710eSEric Fiselier     S s("0123456789");
475a83710eSEric Fiselier     const S& cs = s;
489ea0e473SMarshall Clow     ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference);
499ea0e473SMarshall Clow     ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference);
509ea0e473SMarshall Clow     LIBCPP_ASSERT_NOEXCEPT(    s[0]);
519ea0e473SMarshall Clow     LIBCPP_ASSERT_NOEXCEPT(   cs[0]);
525a83710eSEric Fiselier     for (S::size_type i = 0; i < cs.size(); ++i)
535a83710eSEric Fiselier     {
54e9c72889SStephan T. Lavavej         assert(s[i] == static_cast<char>('0' + i));
555a83710eSEric Fiselier         assert(cs[i] == s[i]);
565a83710eSEric Fiselier     }
575a83710eSEric Fiselier     assert(cs[cs.size()] == '\0');
585a83710eSEric Fiselier     const S s2 = S();
595a83710eSEric Fiselier     assert(s2[0] == '\0');
605a83710eSEric Fiselier     }
615a83710eSEric Fiselier #endif
625a83710eSEric Fiselier #ifdef _LIBCPP_DEBUG
635a83710eSEric Fiselier     {
645a83710eSEric Fiselier         std::string s;
655a83710eSEric Fiselier         char c = s[0];
665a83710eSEric Fiselier         assert(c == '\0');
675a83710eSEric Fiselier         c = s[1];
685a83710eSEric Fiselier         assert(false);
695a83710eSEric Fiselier     }
705a83710eSEric Fiselier #endif
712df59c50SJF Bastien 
722df59c50SJF Bastien   return 0;
735a83710eSEric Fiselier }
74