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 215a83710eSEric Fiselier #include "min_allocator.h" 225a83710eSEric Fiselier 232df59c50SJF Bastien int main(int, char**) 245a83710eSEric Fiselier { 255a83710eSEric Fiselier { 265a83710eSEric Fiselier typedef std::string S; 275a83710eSEric Fiselier S s("0123456789"); 285a83710eSEric Fiselier const S& cs = s; 29*9ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 30*9ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 31*9ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 32*9ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 335a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 345a83710eSEric Fiselier { 35e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 365a83710eSEric Fiselier assert(cs[i] == s[i]); 375a83710eSEric Fiselier } 385a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 395a83710eSEric Fiselier const S s2 = S(); 405a83710eSEric Fiselier assert(s2[0] == '\0'); 415a83710eSEric Fiselier } 42f2f2a639SEric Fiselier #if TEST_STD_VER >= 11 435a83710eSEric Fiselier { 445a83710eSEric Fiselier typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S; 455a83710eSEric Fiselier S s("0123456789"); 465a83710eSEric Fiselier const S& cs = s; 47*9ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype( s[0]), typename S::reference); 48*9ea0e473SMarshall Clow ASSERT_SAME_TYPE(decltype(cs[0]), typename S::const_reference); 49*9ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( s[0]); 50*9ea0e473SMarshall Clow LIBCPP_ASSERT_NOEXCEPT( cs[0]); 515a83710eSEric Fiselier for (S::size_type i = 0; i < cs.size(); ++i) 525a83710eSEric Fiselier { 53e9c72889SStephan T. Lavavej assert(s[i] == static_cast<char>('0' + i)); 545a83710eSEric Fiselier assert(cs[i] == s[i]); 555a83710eSEric Fiselier } 565a83710eSEric Fiselier assert(cs[cs.size()] == '\0'); 575a83710eSEric Fiselier const S s2 = S(); 585a83710eSEric Fiselier assert(s2[0] == '\0'); 595a83710eSEric Fiselier } 605a83710eSEric Fiselier #endif 615a83710eSEric Fiselier #ifdef _LIBCPP_DEBUG 625a83710eSEric Fiselier { 635a83710eSEric Fiselier std::string s; 645a83710eSEric Fiselier char c = s[0]; 655a83710eSEric Fiselier assert(c == '\0'); 665a83710eSEric Fiselier c = s[1]; 675a83710eSEric Fiselier assert(false); 685a83710eSEric Fiselier } 695a83710eSEric Fiselier #endif 702df59c50SJF Bastien 712df59c50SJF Bastien return 0; 725a83710eSEric Fiselier } 73