10b57cec5SDimitry Andric// -*- C++ -*- 20b57cec5SDimitry Andric//===------------------------ string_view ---------------------------------===// 30b57cec5SDimitry Andric// 40b57cec5SDimitry Andric// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 50b57cec5SDimitry Andric// See https://llvm.org/LICENSE.txt for license information. 60b57cec5SDimitry Andric// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 70b57cec5SDimitry Andric// 80b57cec5SDimitry Andric//===----------------------------------------------------------------------===// 90b57cec5SDimitry Andric 100b57cec5SDimitry Andric#ifndef _LIBCPP_STRING_VIEW 110b57cec5SDimitry Andric#define _LIBCPP_STRING_VIEW 120b57cec5SDimitry Andric 130b57cec5SDimitry Andric/* 140b57cec5SDimitry Andricstring_view synopsis 150b57cec5SDimitry Andric 160b57cec5SDimitry Andricnamespace std { 170b57cec5SDimitry Andric 180b57cec5SDimitry Andric // 7.2, Class template basic_string_view 190b57cec5SDimitry Andric template<class charT, class traits = char_traits<charT>> 200b57cec5SDimitry Andric class basic_string_view; 210b57cec5SDimitry Andric 220b57cec5SDimitry Andric // 7.9, basic_string_view non-member comparison functions 230b57cec5SDimitry Andric template<class charT, class traits> 240b57cec5SDimitry Andric constexpr bool operator==(basic_string_view<charT, traits> x, 250b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 260b57cec5SDimitry Andric template<class charT, class traits> 270b57cec5SDimitry Andric constexpr bool operator!=(basic_string_view<charT, traits> x, 280b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 290b57cec5SDimitry Andric template<class charT, class traits> 300b57cec5SDimitry Andric constexpr bool operator< (basic_string_view<charT, traits> x, 310b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 320b57cec5SDimitry Andric template<class charT, class traits> 330b57cec5SDimitry Andric constexpr bool operator> (basic_string_view<charT, traits> x, 340b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 350b57cec5SDimitry Andric template<class charT, class traits> 360b57cec5SDimitry Andric constexpr bool operator<=(basic_string_view<charT, traits> x, 370b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 380b57cec5SDimitry Andric template<class charT, class traits> 390b57cec5SDimitry Andric constexpr bool operator>=(basic_string_view<charT, traits> x, 400b57cec5SDimitry Andric basic_string_view<charT, traits> y) noexcept; 410b57cec5SDimitry Andric // see below, sufficient additional overloads of comparison functions 420b57cec5SDimitry Andric 430b57cec5SDimitry Andric // 7.10, Inserters and extractors 440b57cec5SDimitry Andric template<class charT, class traits> 450b57cec5SDimitry Andric basic_ostream<charT, traits>& 460b57cec5SDimitry Andric operator<<(basic_ostream<charT, traits>& os, 470b57cec5SDimitry Andric basic_string_view<charT, traits> str); 480b57cec5SDimitry Andric 490b57cec5SDimitry Andric // basic_string_view typedef names 500b57cec5SDimitry Andric typedef basic_string_view<char> string_view; 510b57cec5SDimitry Andric typedef basic_string_view<char16_t> u16string_view; 520b57cec5SDimitry Andric typedef basic_string_view<char32_t> u32string_view; 530b57cec5SDimitry Andric typedef basic_string_view<wchar_t> wstring_view; 540b57cec5SDimitry Andric 550b57cec5SDimitry Andric template<class charT, class traits = char_traits<charT>> 560b57cec5SDimitry Andric class basic_string_view { 570b57cec5SDimitry Andric public: 580b57cec5SDimitry Andric // types 590b57cec5SDimitry Andric typedef traits traits_type; 600b57cec5SDimitry Andric typedef charT value_type; 610b57cec5SDimitry Andric typedef charT* pointer; 620b57cec5SDimitry Andric typedef const charT* const_pointer; 630b57cec5SDimitry Andric typedef charT& reference; 640b57cec5SDimitry Andric typedef const charT& const_reference; 650b57cec5SDimitry Andric typedef implementation-defined const_iterator; 660b57cec5SDimitry Andric typedef const_iterator iterator; 670b57cec5SDimitry Andric typedef reverse_iterator<const_iterator> const_reverse_iterator; 680b57cec5SDimitry Andric typedef const_reverse_iterator reverse_iterator; 690b57cec5SDimitry Andric typedef size_t size_type; 700b57cec5SDimitry Andric typedef ptrdiff_t difference_type; 710b57cec5SDimitry Andric static constexpr size_type npos = size_type(-1); 720b57cec5SDimitry Andric 730b57cec5SDimitry Andric // 7.3, basic_string_view constructors and assignment operators 740b57cec5SDimitry Andric constexpr basic_string_view() noexcept; 750b57cec5SDimitry Andric constexpr basic_string_view(const basic_string_view&) noexcept = default; 760b57cec5SDimitry Andric basic_string_view& operator=(const basic_string_view&) noexcept = default; 770b57cec5SDimitry Andric template<class Allocator> 780b57cec5SDimitry Andric constexpr basic_string_view(const charT* str); 790b57cec5SDimitry Andric constexpr basic_string_view(const charT* str, size_type len); 800b57cec5SDimitry Andric 810b57cec5SDimitry Andric // 7.4, basic_string_view iterator support 820b57cec5SDimitry Andric constexpr const_iterator begin() const noexcept; 830b57cec5SDimitry Andric constexpr const_iterator end() const noexcept; 840b57cec5SDimitry Andric constexpr const_iterator cbegin() const noexcept; 850b57cec5SDimitry Andric constexpr const_iterator cend() const noexcept; 860b57cec5SDimitry Andric const_reverse_iterator rbegin() const noexcept; 870b57cec5SDimitry Andric const_reverse_iterator rend() const noexcept; 880b57cec5SDimitry Andric const_reverse_iterator crbegin() const noexcept; 890b57cec5SDimitry Andric const_reverse_iterator crend() const noexcept; 900b57cec5SDimitry Andric 910b57cec5SDimitry Andric // 7.5, basic_string_view capacity 920b57cec5SDimitry Andric constexpr size_type size() const noexcept; 930b57cec5SDimitry Andric constexpr size_type length() const noexcept; 940b57cec5SDimitry Andric constexpr size_type max_size() const noexcept; 950b57cec5SDimitry Andric constexpr bool empty() const noexcept; 960b57cec5SDimitry Andric 970b57cec5SDimitry Andric // 7.6, basic_string_view element access 980b57cec5SDimitry Andric constexpr const_reference operator[](size_type pos) const; 990b57cec5SDimitry Andric constexpr const_reference at(size_type pos) const; 1000b57cec5SDimitry Andric constexpr const_reference front() const; 1010b57cec5SDimitry Andric constexpr const_reference back() const; 1020b57cec5SDimitry Andric constexpr const_pointer data() const noexcept; 1030b57cec5SDimitry Andric 1040b57cec5SDimitry Andric // 7.7, basic_string_view modifiers 1050b57cec5SDimitry Andric constexpr void remove_prefix(size_type n); 1060b57cec5SDimitry Andric constexpr void remove_suffix(size_type n); 1070b57cec5SDimitry Andric constexpr void swap(basic_string_view& s) noexcept; 1080b57cec5SDimitry Andric 1090b57cec5SDimitry Andric size_type copy(charT* s, size_type n, size_type pos = 0) const; 1100b57cec5SDimitry Andric 1110b57cec5SDimitry Andric constexpr basic_string_view substr(size_type pos = 0, size_type n = npos) const; 1120b57cec5SDimitry Andric constexpr int compare(basic_string_view s) const noexcept; 1130b57cec5SDimitry Andric constexpr int compare(size_type pos1, size_type n1, basic_string_view s) const; 1140b57cec5SDimitry Andric constexpr int compare(size_type pos1, size_type n1, 1150b57cec5SDimitry Andric basic_string_view s, size_type pos2, size_type n2) const; 1160b57cec5SDimitry Andric constexpr int compare(const charT* s) const; 1170b57cec5SDimitry Andric constexpr int compare(size_type pos1, size_type n1, const charT* s) const; 1180b57cec5SDimitry Andric constexpr int compare(size_type pos1, size_type n1, 1190b57cec5SDimitry Andric const charT* s, size_type n2) const; 1200b57cec5SDimitry Andric constexpr size_type find(basic_string_view s, size_type pos = 0) const noexcept; 1210b57cec5SDimitry Andric constexpr size_type find(charT c, size_type pos = 0) const noexcept; 1220b57cec5SDimitry Andric constexpr size_type find(const charT* s, size_type pos, size_type n) const; 1230b57cec5SDimitry Andric constexpr size_type find(const charT* s, size_type pos = 0) const; 1240b57cec5SDimitry Andric constexpr size_type rfind(basic_string_view s, size_type pos = npos) const noexcept; 1250b57cec5SDimitry Andric constexpr size_type rfind(charT c, size_type pos = npos) const noexcept; 1260b57cec5SDimitry Andric constexpr size_type rfind(const charT* s, size_type pos, size_type n) const; 1270b57cec5SDimitry Andric constexpr size_type rfind(const charT* s, size_type pos = npos) const; 1280b57cec5SDimitry Andric constexpr size_type find_first_of(basic_string_view s, size_type pos = 0) const noexcept; 1290b57cec5SDimitry Andric constexpr size_type find_first_of(charT c, size_type pos = 0) const noexcept; 1300b57cec5SDimitry Andric constexpr size_type find_first_of(const charT* s, size_type pos, size_type n) const; 1310b57cec5SDimitry Andric constexpr size_type find_first_of(const charT* s, size_type pos = 0) const; 1320b57cec5SDimitry Andric constexpr size_type find_last_of(basic_string_view s, size_type pos = npos) const noexcept; 1330b57cec5SDimitry Andric constexpr size_type find_last_of(charT c, size_type pos = npos) const noexcept; 1340b57cec5SDimitry Andric constexpr size_type find_last_of(const charT* s, size_type pos, size_type n) const; 1350b57cec5SDimitry Andric constexpr size_type find_last_of(const charT* s, size_type pos = npos) const; 1360b57cec5SDimitry Andric constexpr size_type find_first_not_of(basic_string_view s, size_type pos = 0) const noexcept; 1370b57cec5SDimitry Andric constexpr size_type find_first_not_of(charT c, size_type pos = 0) const noexcept; 1380b57cec5SDimitry Andric constexpr size_type find_first_not_of(const charT* s, size_type pos, size_type n) const; 1390b57cec5SDimitry Andric constexpr size_type find_first_not_of(const charT* s, size_type pos = 0) const; 1400b57cec5SDimitry Andric constexpr size_type find_last_not_of(basic_string_view s, size_type pos = npos) const noexcept; 1410b57cec5SDimitry Andric constexpr size_type find_last_not_of(charT c, size_type pos = npos) const noexcept; 1420b57cec5SDimitry Andric constexpr size_type find_last_not_of(const charT* s, size_type pos, size_type n) const; 1430b57cec5SDimitry Andric constexpr size_type find_last_not_of(const charT* s, size_type pos = npos) const; 1440b57cec5SDimitry Andric 1450b57cec5SDimitry Andric constexpr bool starts_with(basic_string_view s) const noexcept; // C++2a 1460b57cec5SDimitry Andric constexpr bool starts_with(charT c) const noexcept; // C++2a 1470b57cec5SDimitry Andric constexpr bool starts_with(const charT* s) const; // C++2a 1480b57cec5SDimitry Andric constexpr bool ends_with(basic_string_view s) const noexcept; // C++2a 1490b57cec5SDimitry Andric constexpr bool ends_with(charT c) const noexcept; // C++2a 1500b57cec5SDimitry Andric constexpr bool ends_with(const charT* s) const; // C++2a 1510b57cec5SDimitry Andric 1520b57cec5SDimitry Andric private: 1530b57cec5SDimitry Andric const_pointer data_; // exposition only 1540b57cec5SDimitry Andric size_type size_; // exposition only 1550b57cec5SDimitry Andric }; 1560b57cec5SDimitry Andric 1570b57cec5SDimitry Andric // 7.11, Hash support 1580b57cec5SDimitry Andric template <class T> struct hash; 1590b57cec5SDimitry Andric template <> struct hash<string_view>; 1600b57cec5SDimitry Andric template <> struct hash<u16string_view>; 1610b57cec5SDimitry Andric template <> struct hash<u32string_view>; 1620b57cec5SDimitry Andric template <> struct hash<wstring_view>; 1630b57cec5SDimitry Andric 1640b57cec5SDimitry Andric constexpr basic_string_view<char> operator "" sv( const char *str, size_t len ) noexcept; 1650b57cec5SDimitry Andric constexpr basic_string_view<wchar_t> operator "" sv( const wchar_t *str, size_t len ) noexcept; 1660b57cec5SDimitry Andric constexpr basic_string_view<char16_t> operator "" sv( const char16_t *str, size_t len ) noexcept; 1670b57cec5SDimitry Andric constexpr basic_string_view<char32_t> operator "" sv( const char32_t *str, size_t len ) noexcept; 1680b57cec5SDimitry Andric 1690b57cec5SDimitry Andric} // namespace std 1700b57cec5SDimitry Andric 1710b57cec5SDimitry Andric 1720b57cec5SDimitry Andric*/ 1730b57cec5SDimitry Andric 1740b57cec5SDimitry Andric#include <__config> 1750b57cec5SDimitry Andric#include <__string> 176*e40139ffSDimitry Andric#include <iosfwd> 1770b57cec5SDimitry Andric#include <algorithm> 1780b57cec5SDimitry Andric#include <iterator> 1790b57cec5SDimitry Andric#include <limits> 1800b57cec5SDimitry Andric#include <stdexcept> 1810b57cec5SDimitry Andric#include <version> 1820b57cec5SDimitry Andric#include <__debug> 1830b57cec5SDimitry Andric 1840b57cec5SDimitry Andric#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 1850b57cec5SDimitry Andric#pragma GCC system_header 1860b57cec5SDimitry Andric#endif 1870b57cec5SDimitry Andric 1880b57cec5SDimitry Andric_LIBCPP_PUSH_MACROS 1890b57cec5SDimitry Andric#include <__undef_macros> 1900b57cec5SDimitry Andric 1910b57cec5SDimitry Andric 1920b57cec5SDimitry Andric_LIBCPP_BEGIN_NAMESPACE_STD 1930b57cec5SDimitry Andric 1940b57cec5SDimitry Andrictemplate<class _CharT, class _Traits = char_traits<_CharT> > 1950b57cec5SDimitry Andricclass _LIBCPP_TEMPLATE_VIS basic_string_view { 1960b57cec5SDimitry Andricpublic: 1970b57cec5SDimitry Andric // types 1980b57cec5SDimitry Andric typedef _Traits traits_type; 1990b57cec5SDimitry Andric typedef _CharT value_type; 2000b57cec5SDimitry Andric typedef _CharT* pointer; 2010b57cec5SDimitry Andric typedef const _CharT* const_pointer; 2020b57cec5SDimitry Andric typedef _CharT& reference; 2030b57cec5SDimitry Andric typedef const _CharT& const_reference; 2040b57cec5SDimitry Andric typedef const_pointer const_iterator; // See [string.view.iterators] 2050b57cec5SDimitry Andric typedef const_iterator iterator; 2060b57cec5SDimitry Andric typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator; 2070b57cec5SDimitry Andric typedef const_reverse_iterator reverse_iterator; 2080b57cec5SDimitry Andric typedef size_t size_type; 2090b57cec5SDimitry Andric typedef ptrdiff_t difference_type; 2100b57cec5SDimitry Andric static _LIBCPP_CONSTEXPR const size_type npos = -1; // size_type(-1); 2110b57cec5SDimitry Andric 2120b57cec5SDimitry Andric static_assert((!is_array<value_type>::value), "Character type of basic_string_view must not be an array"); 2130b57cec5SDimitry Andric static_assert(( is_standard_layout<value_type>::value), "Character type of basic_string_view must be standard-layout"); 2140b57cec5SDimitry Andric static_assert(( is_trivial<value_type>::value), "Character type of basic_string_view must be trivial"); 2150b57cec5SDimitry Andric static_assert((is_same<_CharT, typename traits_type::char_type>::value), 2160b57cec5SDimitry Andric "traits_type::char_type must be the same type as CharT"); 2170b57cec5SDimitry Andric 2180b57cec5SDimitry Andric // [string.view.cons], construct/copy 2190b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2200b57cec5SDimitry Andric basic_string_view() _NOEXCEPT : __data (nullptr), __size(0) {} 2210b57cec5SDimitry Andric 2220b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2230b57cec5SDimitry Andric basic_string_view(const basic_string_view&) _NOEXCEPT = default; 2240b57cec5SDimitry Andric 2250b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 2260b57cec5SDimitry Andric basic_string_view& operator=(const basic_string_view&) _NOEXCEPT = default; 2270b57cec5SDimitry Andric 2280b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2290b57cec5SDimitry Andric basic_string_view(const _CharT* __s, size_type __len) _NOEXCEPT 2300b57cec5SDimitry Andric : __data(__s), __size(__len) 2310b57cec5SDimitry Andric { 2320b57cec5SDimitry Andric#if _LIBCPP_STD_VER > 11 2330b57cec5SDimitry Andric _LIBCPP_ASSERT(__len == 0 || __s != nullptr, "string_view::string_view(_CharT *, size_t): received nullptr"); 2340b57cec5SDimitry Andric#endif 2350b57cec5SDimitry Andric } 2360b57cec5SDimitry Andric 2370b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2380b57cec5SDimitry Andric basic_string_view(const _CharT* __s) 239*e40139ffSDimitry Andric : __data(__s), __size(std::__char_traits_length_checked<_Traits>(__s)) {} 2400b57cec5SDimitry Andric 2410b57cec5SDimitry Andric // [string.view.iterators], iterators 2420b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2430b57cec5SDimitry Andric const_iterator begin() const _NOEXCEPT { return cbegin(); } 2440b57cec5SDimitry Andric 2450b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2460b57cec5SDimitry Andric const_iterator end() const _NOEXCEPT { return cend(); } 2470b57cec5SDimitry Andric 2480b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2490b57cec5SDimitry Andric const_iterator cbegin() const _NOEXCEPT { return __data; } 2500b57cec5SDimitry Andric 2510b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2520b57cec5SDimitry Andric const_iterator cend() const _NOEXCEPT { return __data + __size; } 2530b57cec5SDimitry Andric 2540b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX14 _LIBCPP_INLINE_VISIBILITY 2550b57cec5SDimitry Andric const_reverse_iterator rbegin() const _NOEXCEPT { return const_reverse_iterator(cend()); } 2560b57cec5SDimitry Andric 2570b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX14 _LIBCPP_INLINE_VISIBILITY 2580b57cec5SDimitry Andric const_reverse_iterator rend() const _NOEXCEPT { return const_reverse_iterator(cbegin()); } 2590b57cec5SDimitry Andric 2600b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX14 _LIBCPP_INLINE_VISIBILITY 2610b57cec5SDimitry Andric const_reverse_iterator crbegin() const _NOEXCEPT { return const_reverse_iterator(cend()); } 2620b57cec5SDimitry Andric 2630b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX14 _LIBCPP_INLINE_VISIBILITY 2640b57cec5SDimitry Andric const_reverse_iterator crend() const _NOEXCEPT { return const_reverse_iterator(cbegin()); } 2650b57cec5SDimitry Andric 2660b57cec5SDimitry Andric // [string.view.capacity], capacity 2670b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2680b57cec5SDimitry Andric size_type size() const _NOEXCEPT { return __size; } 2690b57cec5SDimitry Andric 2700b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2710b57cec5SDimitry Andric size_type length() const _NOEXCEPT { return __size; } 2720b57cec5SDimitry Andric 2730b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2740b57cec5SDimitry Andric size_type max_size() const _NOEXCEPT { return numeric_limits<size_type>::max(); } 2750b57cec5SDimitry Andric 2760b57cec5SDimitry Andric _LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 2770b57cec5SDimitry Andric bool empty() const _NOEXCEPT { return __size == 0; } 2780b57cec5SDimitry Andric 2790b57cec5SDimitry Andric // [string.view.access], element access 2800b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2810b57cec5SDimitry Andric const_reference operator[](size_type __pos) const _NOEXCEPT { return __data[__pos]; } 2820b57cec5SDimitry Andric 2830b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2840b57cec5SDimitry Andric const_reference at(size_type __pos) const 2850b57cec5SDimitry Andric { 2860b57cec5SDimitry Andric return __pos >= size() 2870b57cec5SDimitry Andric ? (__throw_out_of_range("string_view::at"), __data[0]) 2880b57cec5SDimitry Andric : __data[__pos]; 2890b57cec5SDimitry Andric } 2900b57cec5SDimitry Andric 2910b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2920b57cec5SDimitry Andric const_reference front() const _NOEXCEPT 2930b57cec5SDimitry Andric { 2940b57cec5SDimitry Andric return _LIBCPP_ASSERT(!empty(), "string_view::front(): string is empty"), __data[0]; 2950b57cec5SDimitry Andric } 2960b57cec5SDimitry Andric 2970b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 2980b57cec5SDimitry Andric const_reference back() const _NOEXCEPT 2990b57cec5SDimitry Andric { 3000b57cec5SDimitry Andric return _LIBCPP_ASSERT(!empty(), "string_view::back(): string is empty"), __data[__size-1]; 3010b57cec5SDimitry Andric } 3020b57cec5SDimitry Andric 3030b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 3040b57cec5SDimitry Andric const_pointer data() const _NOEXCEPT { return __data; } 3050b57cec5SDimitry Andric 3060b57cec5SDimitry Andric // [string.view.modifiers], modifiers: 3070b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3080b57cec5SDimitry Andric void remove_prefix(size_type __n) _NOEXCEPT 3090b57cec5SDimitry Andric { 3100b57cec5SDimitry Andric _LIBCPP_ASSERT(__n <= size(), "remove_prefix() can't remove more than size()"); 3110b57cec5SDimitry Andric __data += __n; 3120b57cec5SDimitry Andric __size -= __n; 3130b57cec5SDimitry Andric } 3140b57cec5SDimitry Andric 3150b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3160b57cec5SDimitry Andric void remove_suffix(size_type __n) _NOEXCEPT 3170b57cec5SDimitry Andric { 3180b57cec5SDimitry Andric _LIBCPP_ASSERT(__n <= size(), "remove_suffix() can't remove more than size()"); 3190b57cec5SDimitry Andric __size -= __n; 3200b57cec5SDimitry Andric } 3210b57cec5SDimitry Andric 3220b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3230b57cec5SDimitry Andric void swap(basic_string_view& __other) _NOEXCEPT 3240b57cec5SDimitry Andric { 3250b57cec5SDimitry Andric const value_type *__p = __data; 3260b57cec5SDimitry Andric __data = __other.__data; 3270b57cec5SDimitry Andric __other.__data = __p; 3280b57cec5SDimitry Andric 3290b57cec5SDimitry Andric size_type __sz = __size; 3300b57cec5SDimitry Andric __size = __other.__size; 3310b57cec5SDimitry Andric __other.__size = __sz; 3320b57cec5SDimitry Andric } 3330b57cec5SDimitry Andric 3340b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 3350b57cec5SDimitry Andric size_type copy(_CharT* __s, size_type __n, size_type __pos = 0) const 3360b57cec5SDimitry Andric { 3370b57cec5SDimitry Andric if (__pos > size()) 3380b57cec5SDimitry Andric __throw_out_of_range("string_view::copy"); 3390b57cec5SDimitry Andric size_type __rlen = _VSTD::min(__n, size() - __pos); 3400b57cec5SDimitry Andric _Traits::copy(__s, data() + __pos, __rlen); 3410b57cec5SDimitry Andric return __rlen; 3420b57cec5SDimitry Andric } 3430b57cec5SDimitry Andric 3440b57cec5SDimitry Andric _LIBCPP_CONSTEXPR _LIBCPP_INLINE_VISIBILITY 3450b57cec5SDimitry Andric basic_string_view substr(size_type __pos = 0, size_type __n = npos) const 3460b57cec5SDimitry Andric { 3470b57cec5SDimitry Andric return __pos > size() 3480b57cec5SDimitry Andric ? (__throw_out_of_range("string_view::substr"), basic_string_view()) 3490b57cec5SDimitry Andric : basic_string_view(data() + __pos, _VSTD::min(__n, size() - __pos)); 3500b57cec5SDimitry Andric } 3510b57cec5SDimitry Andric 3520b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 int compare(basic_string_view __sv) const _NOEXCEPT 3530b57cec5SDimitry Andric { 3540b57cec5SDimitry Andric size_type __rlen = _VSTD::min( size(), __sv.size()); 3550b57cec5SDimitry Andric int __retval = _Traits::compare(data(), __sv.data(), __rlen); 3560b57cec5SDimitry Andric if ( __retval == 0 ) // first __rlen chars matched 3570b57cec5SDimitry Andric __retval = size() == __sv.size() ? 0 : ( size() < __sv.size() ? -1 : 1 ); 3580b57cec5SDimitry Andric return __retval; 3590b57cec5SDimitry Andric } 3600b57cec5SDimitry Andric 3610b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3620b57cec5SDimitry Andric int compare(size_type __pos1, size_type __n1, basic_string_view __sv) const 3630b57cec5SDimitry Andric { 3640b57cec5SDimitry Andric return substr(__pos1, __n1).compare(__sv); 3650b57cec5SDimitry Andric } 3660b57cec5SDimitry Andric 3670b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3680b57cec5SDimitry Andric int compare( size_type __pos1, size_type __n1, 3690b57cec5SDimitry Andric basic_string_view __sv, size_type __pos2, size_type __n2) const 3700b57cec5SDimitry Andric { 3710b57cec5SDimitry Andric return substr(__pos1, __n1).compare(__sv.substr(__pos2, __n2)); 3720b57cec5SDimitry Andric } 3730b57cec5SDimitry Andric 3740b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3750b57cec5SDimitry Andric int compare(const _CharT* __s) const _NOEXCEPT 3760b57cec5SDimitry Andric { 3770b57cec5SDimitry Andric return compare(basic_string_view(__s)); 3780b57cec5SDimitry Andric } 3790b57cec5SDimitry Andric 3800b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3810b57cec5SDimitry Andric int compare(size_type __pos1, size_type __n1, const _CharT* __s) const 3820b57cec5SDimitry Andric { 3830b57cec5SDimitry Andric return substr(__pos1, __n1).compare(basic_string_view(__s)); 3840b57cec5SDimitry Andric } 3850b57cec5SDimitry Andric 3860b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3870b57cec5SDimitry Andric int compare(size_type __pos1, size_type __n1, const _CharT* __s, size_type __n2) const 3880b57cec5SDimitry Andric { 3890b57cec5SDimitry Andric return substr(__pos1, __n1).compare(basic_string_view(__s, __n2)); 3900b57cec5SDimitry Andric } 3910b57cec5SDimitry Andric 3920b57cec5SDimitry Andric // find 3930b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 3940b57cec5SDimitry Andric size_type find(basic_string_view __s, size_type __pos = 0) const _NOEXCEPT 3950b57cec5SDimitry Andric { 3960b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find(): received nullptr"); 3970b57cec5SDimitry Andric return __str_find<value_type, size_type, traits_type, npos> 3980b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 3990b57cec5SDimitry Andric } 4000b57cec5SDimitry Andric 4010b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4020b57cec5SDimitry Andric size_type find(_CharT __c, size_type __pos = 0) const _NOEXCEPT 4030b57cec5SDimitry Andric { 4040b57cec5SDimitry Andric return __str_find<value_type, size_type, traits_type, npos> 4050b57cec5SDimitry Andric (data(), size(), __c, __pos); 4060b57cec5SDimitry Andric } 4070b57cec5SDimitry Andric 4080b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4090b57cec5SDimitry Andric size_type find(const _CharT* __s, size_type __pos, size_type __n) const 4100b57cec5SDimitry Andric { 4110b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::find(): received nullptr"); 4120b57cec5SDimitry Andric return __str_find<value_type, size_type, traits_type, npos> 4130b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 4140b57cec5SDimitry Andric } 4150b57cec5SDimitry Andric 4160b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4170b57cec5SDimitry Andric size_type find(const _CharT* __s, size_type __pos = 0) const 4180b57cec5SDimitry Andric { 4190b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::find(): received nullptr"); 4200b57cec5SDimitry Andric return __str_find<value_type, size_type, traits_type, npos> 4210b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 4220b57cec5SDimitry Andric } 4230b57cec5SDimitry Andric 4240b57cec5SDimitry Andric // rfind 4250b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4260b57cec5SDimitry Andric size_type rfind(basic_string_view __s, size_type __pos = npos) const _NOEXCEPT 4270b57cec5SDimitry Andric { 4280b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find(): received nullptr"); 4290b57cec5SDimitry Andric return __str_rfind<value_type, size_type, traits_type, npos> 4300b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 4310b57cec5SDimitry Andric } 4320b57cec5SDimitry Andric 4330b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4340b57cec5SDimitry Andric size_type rfind(_CharT __c, size_type __pos = npos) const _NOEXCEPT 4350b57cec5SDimitry Andric { 4360b57cec5SDimitry Andric return __str_rfind<value_type, size_type, traits_type, npos> 4370b57cec5SDimitry Andric (data(), size(), __c, __pos); 4380b57cec5SDimitry Andric } 4390b57cec5SDimitry Andric 4400b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4410b57cec5SDimitry Andric size_type rfind(const _CharT* __s, size_type __pos, size_type __n) const 4420b57cec5SDimitry Andric { 4430b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::rfind(): received nullptr"); 4440b57cec5SDimitry Andric return __str_rfind<value_type, size_type, traits_type, npos> 4450b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 4460b57cec5SDimitry Andric } 4470b57cec5SDimitry Andric 4480b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4490b57cec5SDimitry Andric size_type rfind(const _CharT* __s, size_type __pos=npos) const 4500b57cec5SDimitry Andric { 4510b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::rfind(): received nullptr"); 4520b57cec5SDimitry Andric return __str_rfind<value_type, size_type, traits_type, npos> 4530b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 4540b57cec5SDimitry Andric } 4550b57cec5SDimitry Andric 4560b57cec5SDimitry Andric // find_first_of 4570b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4580b57cec5SDimitry Andric size_type find_first_of(basic_string_view __s, size_type __pos = 0) const _NOEXCEPT 4590b57cec5SDimitry Andric { 4600b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find_first_of(): received nullptr"); 4610b57cec5SDimitry Andric return __str_find_first_of<value_type, size_type, traits_type, npos> 4620b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 4630b57cec5SDimitry Andric } 4640b57cec5SDimitry Andric 4650b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4660b57cec5SDimitry Andric size_type find_first_of(_CharT __c, size_type __pos = 0) const _NOEXCEPT 4670b57cec5SDimitry Andric { return find(__c, __pos); } 4680b57cec5SDimitry Andric 4690b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4700b57cec5SDimitry Andric size_type find_first_of(const _CharT* __s, size_type __pos, size_type __n) const 4710b57cec5SDimitry Andric { 4720b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::find_first_of(): received nullptr"); 4730b57cec5SDimitry Andric return __str_find_first_of<value_type, size_type, traits_type, npos> 4740b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 4750b57cec5SDimitry Andric } 4760b57cec5SDimitry Andric 4770b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4780b57cec5SDimitry Andric size_type find_first_of(const _CharT* __s, size_type __pos=0) const 4790b57cec5SDimitry Andric { 4800b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::find_first_of(): received nullptr"); 4810b57cec5SDimitry Andric return __str_find_first_of<value_type, size_type, traits_type, npos> 4820b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 4830b57cec5SDimitry Andric } 4840b57cec5SDimitry Andric 4850b57cec5SDimitry Andric // find_last_of 4860b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4870b57cec5SDimitry Andric size_type find_last_of(basic_string_view __s, size_type __pos=npos) const _NOEXCEPT 4880b57cec5SDimitry Andric { 4890b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find_last_of(): received nullptr"); 4900b57cec5SDimitry Andric return __str_find_last_of<value_type, size_type, traits_type, npos> 4910b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 4920b57cec5SDimitry Andric } 4930b57cec5SDimitry Andric 4940b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4950b57cec5SDimitry Andric size_type find_last_of(_CharT __c, size_type __pos = npos) const _NOEXCEPT 4960b57cec5SDimitry Andric { return rfind(__c, __pos); } 4970b57cec5SDimitry Andric 4980b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 4990b57cec5SDimitry Andric size_type find_last_of(const _CharT* __s, size_type __pos, size_type __n) const 5000b57cec5SDimitry Andric { 5010b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::find_last_of(): received nullptr"); 5020b57cec5SDimitry Andric return __str_find_last_of<value_type, size_type, traits_type, npos> 5030b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 5040b57cec5SDimitry Andric } 5050b57cec5SDimitry Andric 5060b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5070b57cec5SDimitry Andric size_type find_last_of(const _CharT* __s, size_type __pos=npos) const 5080b57cec5SDimitry Andric { 5090b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::find_last_of(): received nullptr"); 5100b57cec5SDimitry Andric return __str_find_last_of<value_type, size_type, traits_type, npos> 5110b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 5120b57cec5SDimitry Andric } 5130b57cec5SDimitry Andric 5140b57cec5SDimitry Andric // find_first_not_of 5150b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5160b57cec5SDimitry Andric size_type find_first_not_of(basic_string_view __s, size_type __pos=0) const _NOEXCEPT 5170b57cec5SDimitry Andric { 5180b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find_first_not_of(): received nullptr"); 5190b57cec5SDimitry Andric return __str_find_first_not_of<value_type, size_type, traits_type, npos> 5200b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 5210b57cec5SDimitry Andric } 5220b57cec5SDimitry Andric 5230b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5240b57cec5SDimitry Andric size_type find_first_not_of(_CharT __c, size_type __pos=0) const _NOEXCEPT 5250b57cec5SDimitry Andric { 5260b57cec5SDimitry Andric return __str_find_first_not_of<value_type, size_type, traits_type, npos> 5270b57cec5SDimitry Andric (data(), size(), __c, __pos); 5280b57cec5SDimitry Andric } 5290b57cec5SDimitry Andric 5300b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5310b57cec5SDimitry Andric size_type find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const 5320b57cec5SDimitry Andric { 5330b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::find_first_not_of(): received nullptr"); 5340b57cec5SDimitry Andric return __str_find_first_not_of<value_type, size_type, traits_type, npos> 5350b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 5360b57cec5SDimitry Andric } 5370b57cec5SDimitry Andric 5380b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5390b57cec5SDimitry Andric size_type find_first_not_of(const _CharT* __s, size_type __pos=0) const 5400b57cec5SDimitry Andric { 5410b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::find_first_not_of(): received nullptr"); 5420b57cec5SDimitry Andric return __str_find_first_not_of<value_type, size_type, traits_type, npos> 5430b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 5440b57cec5SDimitry Andric } 5450b57cec5SDimitry Andric 5460b57cec5SDimitry Andric // find_last_not_of 5470b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5480b57cec5SDimitry Andric size_type find_last_not_of(basic_string_view __s, size_type __pos=npos) const _NOEXCEPT 5490b57cec5SDimitry Andric { 5500b57cec5SDimitry Andric _LIBCPP_ASSERT(__s.size() == 0 || __s.data() != nullptr, "string_view::find_last_not_of(): received nullptr"); 5510b57cec5SDimitry Andric return __str_find_last_not_of<value_type, size_type, traits_type, npos> 5520b57cec5SDimitry Andric (data(), size(), __s.data(), __pos, __s.size()); 5530b57cec5SDimitry Andric } 5540b57cec5SDimitry Andric 5550b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5560b57cec5SDimitry Andric size_type find_last_not_of(_CharT __c, size_type __pos=npos) const _NOEXCEPT 5570b57cec5SDimitry Andric { 5580b57cec5SDimitry Andric return __str_find_last_not_of<value_type, size_type, traits_type, npos> 5590b57cec5SDimitry Andric (data(), size(), __c, __pos); 5600b57cec5SDimitry Andric } 5610b57cec5SDimitry Andric 5620b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5630b57cec5SDimitry Andric size_type find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const 5640b57cec5SDimitry Andric { 5650b57cec5SDimitry Andric _LIBCPP_ASSERT(__n == 0 || __s != nullptr, "string_view::find_last_not_of(): received nullptr"); 5660b57cec5SDimitry Andric return __str_find_last_not_of<value_type, size_type, traits_type, npos> 5670b57cec5SDimitry Andric (data(), size(), __s, __pos, __n); 5680b57cec5SDimitry Andric } 5690b57cec5SDimitry Andric 5700b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5710b57cec5SDimitry Andric size_type find_last_not_of(const _CharT* __s, size_type __pos=npos) const 5720b57cec5SDimitry Andric { 5730b57cec5SDimitry Andric _LIBCPP_ASSERT(__s != nullptr, "string_view::find_last_not_of(): received nullptr"); 5740b57cec5SDimitry Andric return __str_find_last_not_of<value_type, size_type, traits_type, npos> 5750b57cec5SDimitry Andric (data(), size(), __s, __pos, traits_type::length(__s)); 5760b57cec5SDimitry Andric } 5770b57cec5SDimitry Andric 5780b57cec5SDimitry Andric#if _LIBCPP_STD_VER > 17 5790b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5800b57cec5SDimitry Andric bool starts_with(basic_string_view __s) const _NOEXCEPT 5810b57cec5SDimitry Andric { return size() >= __s.size() && compare(0, __s.size(), __s) == 0; } 5820b57cec5SDimitry Andric 5830b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5840b57cec5SDimitry Andric bool starts_with(value_type __c) const _NOEXCEPT 5850b57cec5SDimitry Andric { return !empty() && _Traits::eq(front(), __c); } 5860b57cec5SDimitry Andric 5870b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5880b57cec5SDimitry Andric bool starts_with(const value_type* __s) const _NOEXCEPT 5890b57cec5SDimitry Andric { return starts_with(basic_string_view(__s)); } 5900b57cec5SDimitry Andric 5910b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5920b57cec5SDimitry Andric bool ends_with(basic_string_view __s) const _NOEXCEPT 5930b57cec5SDimitry Andric { return size() >= __s.size() && compare(size() - __s.size(), npos, __s) == 0; } 5940b57cec5SDimitry Andric 5950b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 5960b57cec5SDimitry Andric bool ends_with(value_type __c) const _NOEXCEPT 5970b57cec5SDimitry Andric { return !empty() && _Traits::eq(back(), __c); } 5980b57cec5SDimitry Andric 5990b57cec5SDimitry Andric _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6000b57cec5SDimitry Andric bool ends_with(const value_type* __s) const _NOEXCEPT 6010b57cec5SDimitry Andric { return ends_with(basic_string_view(__s)); } 6020b57cec5SDimitry Andric#endif 6030b57cec5SDimitry Andric 6040b57cec5SDimitry Andricprivate: 6050b57cec5SDimitry Andric const value_type* __data; 6060b57cec5SDimitry Andric size_type __size; 6070b57cec5SDimitry Andric}; 6080b57cec5SDimitry Andric 6090b57cec5SDimitry Andric 6100b57cec5SDimitry Andric// [string.view.comparison] 6110b57cec5SDimitry Andric// operator == 6120b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6130b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6140b57cec5SDimitry Andricbool operator==(basic_string_view<_CharT, _Traits> __lhs, 6150b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6160b57cec5SDimitry Andric{ 6170b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) return false; 6180b57cec5SDimitry Andric return __lhs.compare(__rhs) == 0; 6190b57cec5SDimitry Andric} 6200b57cec5SDimitry Andric 6210b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6220b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6230b57cec5SDimitry Andricbool operator==(basic_string_view<_CharT, _Traits> __lhs, 6240b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 6250b57cec5SDimitry Andric{ 6260b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) return false; 6270b57cec5SDimitry Andric return __lhs.compare(__rhs) == 0; 6280b57cec5SDimitry Andric} 6290b57cec5SDimitry Andric 6300b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6310b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6320b57cec5SDimitry Andricbool operator==(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 6330b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6340b57cec5SDimitry Andric{ 6350b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) return false; 6360b57cec5SDimitry Andric return __lhs.compare(__rhs) == 0; 6370b57cec5SDimitry Andric} 6380b57cec5SDimitry Andric 6390b57cec5SDimitry Andric 6400b57cec5SDimitry Andric// operator != 6410b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6420b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6430b57cec5SDimitry Andricbool operator!=(basic_string_view<_CharT, _Traits> __lhs, basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6440b57cec5SDimitry Andric{ 6450b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) 6460b57cec5SDimitry Andric return true; 6470b57cec5SDimitry Andric return __lhs.compare(__rhs) != 0; 6480b57cec5SDimitry Andric} 6490b57cec5SDimitry Andric 6500b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6510b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6520b57cec5SDimitry Andricbool operator!=(basic_string_view<_CharT, _Traits> __lhs, 6530b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 6540b57cec5SDimitry Andric{ 6550b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) 6560b57cec5SDimitry Andric return true; 6570b57cec5SDimitry Andric return __lhs.compare(__rhs) != 0; 6580b57cec5SDimitry Andric} 6590b57cec5SDimitry Andric 6600b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6610b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6620b57cec5SDimitry Andricbool operator!=(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 6630b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6640b57cec5SDimitry Andric{ 6650b57cec5SDimitry Andric if ( __lhs.size() != __rhs.size()) 6660b57cec5SDimitry Andric return true; 6670b57cec5SDimitry Andric return __lhs.compare(__rhs) != 0; 6680b57cec5SDimitry Andric} 6690b57cec5SDimitry Andric 6700b57cec5SDimitry Andric 6710b57cec5SDimitry Andric// operator < 6720b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6730b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6740b57cec5SDimitry Andricbool operator<(basic_string_view<_CharT, _Traits> __lhs, basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6750b57cec5SDimitry Andric{ 6760b57cec5SDimitry Andric return __lhs.compare(__rhs) < 0; 6770b57cec5SDimitry Andric} 6780b57cec5SDimitry Andric 6790b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6800b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6810b57cec5SDimitry Andricbool operator<(basic_string_view<_CharT, _Traits> __lhs, 6820b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 6830b57cec5SDimitry Andric{ 6840b57cec5SDimitry Andric return __lhs.compare(__rhs) < 0; 6850b57cec5SDimitry Andric} 6860b57cec5SDimitry Andric 6870b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6880b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6890b57cec5SDimitry Andricbool operator<(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 6900b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 6910b57cec5SDimitry Andric{ 6920b57cec5SDimitry Andric return __lhs.compare(__rhs) < 0; 6930b57cec5SDimitry Andric} 6940b57cec5SDimitry Andric 6950b57cec5SDimitry Andric 6960b57cec5SDimitry Andric// operator > 6970b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 6980b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 6990b57cec5SDimitry Andricbool operator> (basic_string_view<_CharT, _Traits> __lhs, basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7000b57cec5SDimitry Andric{ 7010b57cec5SDimitry Andric return __lhs.compare(__rhs) > 0; 7020b57cec5SDimitry Andric} 7030b57cec5SDimitry Andric 7040b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7050b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7060b57cec5SDimitry Andricbool operator>(basic_string_view<_CharT, _Traits> __lhs, 7070b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 7080b57cec5SDimitry Andric{ 7090b57cec5SDimitry Andric return __lhs.compare(__rhs) > 0; 7100b57cec5SDimitry Andric} 7110b57cec5SDimitry Andric 7120b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7130b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7140b57cec5SDimitry Andricbool operator>(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 7150b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7160b57cec5SDimitry Andric{ 7170b57cec5SDimitry Andric return __lhs.compare(__rhs) > 0; 7180b57cec5SDimitry Andric} 7190b57cec5SDimitry Andric 7200b57cec5SDimitry Andric 7210b57cec5SDimitry Andric// operator <= 7220b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7230b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7240b57cec5SDimitry Andricbool operator<=(basic_string_view<_CharT, _Traits> __lhs, basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7250b57cec5SDimitry Andric{ 7260b57cec5SDimitry Andric return __lhs.compare(__rhs) <= 0; 7270b57cec5SDimitry Andric} 7280b57cec5SDimitry Andric 7290b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7300b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7310b57cec5SDimitry Andricbool operator<=(basic_string_view<_CharT, _Traits> __lhs, 7320b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 7330b57cec5SDimitry Andric{ 7340b57cec5SDimitry Andric return __lhs.compare(__rhs) <= 0; 7350b57cec5SDimitry Andric} 7360b57cec5SDimitry Andric 7370b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7380b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7390b57cec5SDimitry Andricbool operator<=(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 7400b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7410b57cec5SDimitry Andric{ 7420b57cec5SDimitry Andric return __lhs.compare(__rhs) <= 0; 7430b57cec5SDimitry Andric} 7440b57cec5SDimitry Andric 7450b57cec5SDimitry Andric 7460b57cec5SDimitry Andric// operator >= 7470b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7480b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7490b57cec5SDimitry Andricbool operator>=(basic_string_view<_CharT, _Traits> __lhs, basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7500b57cec5SDimitry Andric{ 7510b57cec5SDimitry Andric return __lhs.compare(__rhs) >= 0; 7520b57cec5SDimitry Andric} 7530b57cec5SDimitry Andric 7540b57cec5SDimitry Andric 7550b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7560b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7570b57cec5SDimitry Andricbool operator>=(basic_string_view<_CharT, _Traits> __lhs, 7580b57cec5SDimitry Andric typename common_type<basic_string_view<_CharT, _Traits> >::type __rhs) _NOEXCEPT 7590b57cec5SDimitry Andric{ 7600b57cec5SDimitry Andric return __lhs.compare(__rhs) >= 0; 7610b57cec5SDimitry Andric} 7620b57cec5SDimitry Andric 7630b57cec5SDimitry Andrictemplate<class _CharT, class _Traits> 7640b57cec5SDimitry Andric_LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY 7650b57cec5SDimitry Andricbool operator>=(typename common_type<basic_string_view<_CharT, _Traits> >::type __lhs, 7660b57cec5SDimitry Andric basic_string_view<_CharT, _Traits> __rhs) _NOEXCEPT 7670b57cec5SDimitry Andric{ 7680b57cec5SDimitry Andric return __lhs.compare(__rhs) >= 0; 7690b57cec5SDimitry Andric} 7700b57cec5SDimitry Andric 771*e40139ffSDimitry Andric 772*e40139ffSDimitry Andrictemplate<class _CharT, class _Traits> 773*e40139ffSDimitry Andricbasic_ostream<_CharT, _Traits>& 774*e40139ffSDimitry Andricoperator<<(basic_ostream<_CharT, _Traits>& __os, 775*e40139ffSDimitry Andric basic_string_view<_CharT, _Traits> __str); 776*e40139ffSDimitry Andric 7770b57cec5SDimitry Andrictypedef basic_string_view<char> string_view; 7780b57cec5SDimitry Andric#ifndef _LIBCPP_NO_HAS_CHAR8_T 7790b57cec5SDimitry Andrictypedef basic_string_view<char8_t> u8string_view; 7800b57cec5SDimitry Andric#endif 7810b57cec5SDimitry Andrictypedef basic_string_view<char16_t> u16string_view; 7820b57cec5SDimitry Andrictypedef basic_string_view<char32_t> u32string_view; 7830b57cec5SDimitry Andrictypedef basic_string_view<wchar_t> wstring_view; 7840b57cec5SDimitry Andric 7850b57cec5SDimitry Andric// [string.view.hash] 7860b57cec5SDimitry Andrictemplate<class _CharT> 7870b57cec5SDimitry Andricstruct _LIBCPP_TEMPLATE_VIS hash<basic_string_view<_CharT, char_traits<_CharT> > > 7880b57cec5SDimitry Andric : public unary_function<basic_string_view<_CharT, char_traits<_CharT> >, size_t> 7890b57cec5SDimitry Andric{ 7900b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7910b57cec5SDimitry Andric size_t operator()(const basic_string_view<_CharT, char_traits<_CharT> > __val) const _NOEXCEPT { 7920b57cec5SDimitry Andric return __do_string_hash(__val.data(), __val.data() + __val.size()); 7930b57cec5SDimitry Andric } 7940b57cec5SDimitry Andric}; 7950b57cec5SDimitry Andric 7960b57cec5SDimitry Andric 7970b57cec5SDimitry Andric#if _LIBCPP_STD_VER > 11 7980b57cec5SDimitry Andricinline namespace literals 7990b57cec5SDimitry Andric{ 8000b57cec5SDimitry Andric inline namespace string_view_literals 8010b57cec5SDimitry Andric { 8020b57cec5SDimitry Andric inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 8030b57cec5SDimitry Andric basic_string_view<char> operator "" sv(const char *__str, size_t __len) _NOEXCEPT 8040b57cec5SDimitry Andric { 8050b57cec5SDimitry Andric return basic_string_view<char> (__str, __len); 8060b57cec5SDimitry Andric } 8070b57cec5SDimitry Andric 8080b57cec5SDimitry Andric inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 8090b57cec5SDimitry Andric basic_string_view<wchar_t> operator "" sv(const wchar_t *__str, size_t __len) _NOEXCEPT 8100b57cec5SDimitry Andric { 8110b57cec5SDimitry Andric return basic_string_view<wchar_t> (__str, __len); 8120b57cec5SDimitry Andric } 8130b57cec5SDimitry Andric 8140b57cec5SDimitry Andric#ifndef _LIBCPP_NO_HAS_CHAR8_T 8150b57cec5SDimitry Andric inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 8160b57cec5SDimitry Andric basic_string_view<char8_t> operator "" sv(const char8_t *__str, size_t __len) _NOEXCEPT 8170b57cec5SDimitry Andric { 8180b57cec5SDimitry Andric return basic_string_view<char8_t> (__str, __len); 8190b57cec5SDimitry Andric } 8200b57cec5SDimitry Andric#endif 8210b57cec5SDimitry Andric 8220b57cec5SDimitry Andric inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 8230b57cec5SDimitry Andric basic_string_view<char16_t> operator "" sv(const char16_t *__str, size_t __len) _NOEXCEPT 8240b57cec5SDimitry Andric { 8250b57cec5SDimitry Andric return basic_string_view<char16_t> (__str, __len); 8260b57cec5SDimitry Andric } 8270b57cec5SDimitry Andric 8280b57cec5SDimitry Andric inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 8290b57cec5SDimitry Andric basic_string_view<char32_t> operator "" sv(const char32_t *__str, size_t __len) _NOEXCEPT 8300b57cec5SDimitry Andric { 8310b57cec5SDimitry Andric return basic_string_view<char32_t> (__str, __len); 8320b57cec5SDimitry Andric } 8330b57cec5SDimitry Andric } 8340b57cec5SDimitry Andric} 8350b57cec5SDimitry Andric#endif 8360b57cec5SDimitry Andric_LIBCPP_END_NAMESPACE_STD 8370b57cec5SDimitry Andric 8380b57cec5SDimitry Andric_LIBCPP_POP_MACROS 8390b57cec5SDimitry Andric 8400b57cec5SDimitry Andric#endif // _LIBCPP_STRING_VIEW 841