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