blob: 7fdf0d890614eb18a41dfdd3ab0ecddd5160079f [file] [log] [blame]
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001// -*- C++ -*-
2//===--------------------------- string -----------------------------------===//
3//
Howard Hinnantf5256e12010-05-11 21:36:01 +00004// The LLVM Compiler Infrastructure
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00005//
6// This file is distributed under the University of Illinois Open Source
7// License. See LICENSE.TXT for details.
8//
9//===----------------------------------------------------------------------===//
10
11#ifndef _LIBCPP_STRING
12#define _LIBCPP_STRING
13
14/*
15 string synopsis
16
17namespace std
18{
19
20template <class stateT>
21class fpos
22{
23private:
24 stateT st;
25public:
26 fpos(streamoff = streamoff());
27
28 operator streamoff() const;
29
30 stateT state() const;
31 void state(stateT);
32
33 fpos& operator+=(streamoff);
34 fpos operator+ (streamoff) const;
35 fpos& operator-=(streamoff);
36 fpos operator- (streamoff) const;
37};
38
39template <class stateT> streamoff operator-(const fpos<stateT>& x, const fpos<stateT>& y);
40
41template <class stateT> bool operator==(const fpos<stateT>& x, const fpos<stateT>& y);
42template <class stateT> bool operator!=(const fpos<stateT>& x, const fpos<stateT>& y);
43
44template <class charT>
45struct char_traits
46{
47 typedef charT char_type;
48 typedef ... int_type;
49 typedef streamoff off_type;
50 typedef streampos pos_type;
51 typedef mbstate_t state_type;
52
Howard Hinnanta6119a82011-05-29 19:57:12 +000053 static void assign(char_type& c1, const char_type& c2) noexcept;
54 static bool eq(char_type c1, char_type c2) noexcept;
55 static bool lt(char_type c1, char_type c2) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000056
57 static int compare(const char_type* s1, const char_type* s2, size_t n);
58 static size_t length(const char_type* s);
59 static const char_type* find(const char_type* s, size_t n, const char_type& a);
60 static char_type* move(char_type* s1, const char_type* s2, size_t n);
61 static char_type* copy(char_type* s1, const char_type* s2, size_t n);
62 static char_type* assign(char_type* s, size_t n, char_type a);
63
Howard Hinnanta6119a82011-05-29 19:57:12 +000064 static int_type not_eof(int_type c) noexcept;
65 static char_type to_char_type(int_type c) noexcept;
66 static int_type to_int_type(char_type c) noexcept;
67 static bool eq_int_type(int_type c1, int_type c2) noexcept;
68 static int_type eof() noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000069};
70
71template <> struct char_traits<char>;
72template <> struct char_traits<wchar_t>;
73
Howard Hinnant324bb032010-08-22 00:02:43 +000074template<class charT, class traits = char_traits<charT>, class Allocator = allocator<charT> >
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000075class basic_string
76{
Howard Hinnant324bb032010-08-22 00:02:43 +000077public:
78// types:
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000079 typedef traits traits_type;
80 typedef typename traits_type::char_type value_type;
81 typedef Allocator allocator_type;
82 typedef typename allocator_type::size_type size_type;
83 typedef typename allocator_type::difference_type difference_type;
84 typedef typename allocator_type::reference reference;
85 typedef typename allocator_type::const_reference const_reference;
86 typedef typename allocator_type::pointer pointer;
87 typedef typename allocator_type::const_pointer const_pointer;
88 typedef implementation-defined iterator;
89 typedef implementation-defined const_iterator;
90 typedef std::reverse_iterator<iterator> reverse_iterator;
91 typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
92
93 static const size_type npos = -1;
94
Howard Hinnant53f7d4c2011-06-03 18:40:47 +000095 basic_string()
96 noexcept(is_nothrow_default_constructible<allocator_type>::value);
97 explicit basic_string(const allocator_type& a);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000098 basic_string(const basic_string& str);
Howard Hinnant53f7d4c2011-06-03 18:40:47 +000099 basic_string(basic_string&& str)
100 noexcept(is_nothrow_move_constructible<allocator_type>::value);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000101 basic_string(const basic_string& str, size_type pos, size_type n = npos,
102 const allocator_type& a = allocator_type());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000103 basic_string(const_pointer s, const allocator_type& a = allocator_type());
104 basic_string(const_pointer s, size_type n, const allocator_type& a = allocator_type());
105 basic_string(size_type n, value_type c, const allocator_type& a = allocator_type());
106 template<class InputIterator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000107 basic_string(InputIterator begin, InputIterator end,
108 const allocator_type& a = allocator_type());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000109 basic_string(initializer_list<value_type>, const Allocator& = Allocator());
110 basic_string(const basic_string&, const Allocator&);
111 basic_string(basic_string&&, const Allocator&);
112
113 ~basic_string();
114
115 basic_string& operator=(const basic_string& str);
Howard Hinnant53f7d4c2011-06-03 18:40:47 +0000116 basic_string& operator=(basic_string&& str)
117 noexcept(
118 allocator_type::propagate_on_container_move_assignment::value &&
119 is_nothrow_move_assignable<allocator_type>::value);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000120 basic_string& operator=(const_pointer s);
121 basic_string& operator=(value_type c);
122 basic_string& operator=(initializer_list<value_type>);
123
Howard Hinnanta6119a82011-05-29 19:57:12 +0000124 iterator begin() noexcept;
125 const_iterator begin() const noexcept;
126 iterator end() noexcept;
127 const_iterator end() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000128
Howard Hinnanta6119a82011-05-29 19:57:12 +0000129 reverse_iterator rbegin() noexcept;
130 const_reverse_iterator rbegin() const noexcept;
131 reverse_iterator rend() noexcept;
132 const_reverse_iterator rend() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000133
Howard Hinnanta6119a82011-05-29 19:57:12 +0000134 const_iterator cbegin() const noexcept;
135 const_iterator cend() const noexcept;
136 const_reverse_iterator crbegin() const noexcept;
137 const_reverse_iterator crend() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000138
Howard Hinnanta6119a82011-05-29 19:57:12 +0000139 size_type size() const noexcept;
140 size_type length() const noexcept;
141 size_type max_size() const noexcept;
142 size_type capacity() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000143
144 void resize(size_type n, value_type c);
145 void resize(size_type n);
146
147 void reserve(size_type res_arg = 0);
148 void shrink_to_fit();
Howard Hinnanta6119a82011-05-29 19:57:12 +0000149 void clear() noexcept;
150 bool empty() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000151
152 const_reference operator[](size_type pos) const;
153 reference operator[](size_type pos);
154
155 const_reference at(size_type n) const;
156 reference at(size_type n);
157
158 basic_string& operator+=(const basic_string& str);
159 basic_string& operator+=(const_pointer s);
160 basic_string& operator+=(value_type c);
161 basic_string& operator+=(initializer_list<value_type>);
162
163 basic_string& append(const basic_string& str);
164 basic_string& append(const basic_string& str, size_type pos, size_type n);
165 basic_string& append(const_pointer s, size_type n);
166 basic_string& append(const_pointer s);
167 basic_string& append(size_type n, value_type c);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000168 template<class InputIterator>
169 basic_string& append(InputIterator first, InputIterator last);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000170 basic_string& append(initializer_list<value_type>);
171
172 void push_back(value_type c);
173 void pop_back();
174 reference front();
175 const_reference front() const;
176 reference back();
177 const_reference back() const;
178
179 basic_string& assign(const basic_string& str);
Howard Hinnanta6119a82011-05-29 19:57:12 +0000180 basic_string& assign(basic_string&& str);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000181 basic_string& assign(const basic_string& str, size_type pos, size_type n);
182 basic_string& assign(const_pointer s, size_type n);
183 basic_string& assign(const_pointer s);
184 basic_string& assign(size_type n, value_type c);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000185 template<class InputIterator>
186 basic_string& assign(InputIterator first, InputIterator last);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000187 basic_string& assign(initializer_list<value_type>);
188
189 basic_string& insert(size_type pos1, const basic_string& str);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000190 basic_string& insert(size_type pos1, const basic_string& str,
191 size_type pos2, size_type n);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000192 basic_string& insert(size_type pos, const_pointer s, size_type n);
193 basic_string& insert(size_type pos, const_pointer s);
194 basic_string& insert(size_type pos, size_type n, value_type c);
195 iterator insert(const_iterator p, value_type c);
196 iterator insert(const_iterator p, size_type n, value_type c);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000197 template<class InputIterator>
198 iterator insert(const_iterator p, InputIterator first, InputIterator last);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000199 iterator insert(const_iterator p, initializer_list<value_type>);
200
201 basic_string& erase(size_type pos = 0, size_type n = npos);
202 iterator erase(const_iterator position);
203 iterator erase(const_iterator first, const_iterator last);
204
205 basic_string& replace(size_type pos1, size_type n1, const basic_string& str);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000206 basic_string& replace(size_type pos1, size_type n1, const basic_string& str,
207 size_type pos2, size_type n2);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000208 basic_string& replace(size_type pos, size_type n1, const_pointer s, size_type n2);
209 basic_string& replace(size_type pos, size_type n1, const_pointer s);
210 basic_string& replace(size_type pos, size_type n1, size_type n2, value_type c);
Howard Hinnant7b2cb482010-11-17 21:11:40 +0000211 basic_string& replace(const_iterator i1, const_iterator i2, const basic_string& str);
212 basic_string& replace(const_iterator i1, const_iterator i2, const_pointer s, size_type n);
213 basic_string& replace(const_iterator i1, const_iterator i2, const_pointer s);
214 basic_string& replace(const_iterator i1, const_iterator i2, size_type n, value_type c);
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000215 template<class InputIterator>
Howard Hinnant7b2cb482010-11-17 21:11:40 +0000216 basic_string& replace(const_iterator i1, const_iterator i2, InputIterator j1, InputIterator j2);
217 basic_string& replace(const_iterator i1, const_iterator i2, initializer_list<value_type>);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000218
219 size_type copy(pointer s, size_type n, size_type pos = 0) const;
220 basic_string substr(size_type pos = 0, size_type n = npos) const;
221
Howard Hinnant53f7d4c2011-06-03 18:40:47 +0000222 void swap(basic_string& str)
223 noexcept(!allocator_type::propagate_on_container_swap::value ||
224 __is_nothrow_swappable<allocator_type>::value)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000225
Howard Hinnanta6119a82011-05-29 19:57:12 +0000226 const_pointer c_str() const noexcept;
227 const_pointer data() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000228
Howard Hinnanta6119a82011-05-29 19:57:12 +0000229 allocator_type get_allocator() const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000230
Howard Hinnanta6119a82011-05-29 19:57:12 +0000231 size_type find(const basic_string& str, size_type pos = 0) const noexcept;
232 size_type find(const_pointer s, size_type pos, size_type n) const noexcept;
233 size_type find(const_pointer s, size_type pos = 0) const noexcept;
234 size_type find(value_type c, size_type pos = 0) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000235
Howard Hinnanta6119a82011-05-29 19:57:12 +0000236 size_type rfind(const basic_string& str, size_type pos = npos) const noexcept;
237 size_type rfind(const_pointer s, size_type pos, size_type n) const noexcept;
238 size_type rfind(const_pointer s, size_type pos = npos) const noexcept;
239 size_type rfind(value_type c, size_type pos = npos) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000240
Howard Hinnanta6119a82011-05-29 19:57:12 +0000241 size_type find_first_of(const basic_string& str, size_type pos = 0) const noexcept;
242 size_type find_first_of(const_pointer s, size_type pos, size_type n) const noexcept;
243 size_type find_first_of(const_pointer s, size_type pos = 0) const noexcept;
244 size_type find_first_of(value_type c, size_type pos = 0) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000245
Howard Hinnanta6119a82011-05-29 19:57:12 +0000246 size_type find_last_of(const basic_string& str, size_type pos = npos) const noexcept;
247 size_type find_last_of(const_pointer s, size_type pos, size_type n) const noexcept;
248 size_type find_last_of(const_pointer s, size_type pos = npos) const noexcept;
249 size_type find_last_of(value_type c, size_type pos = npos) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000250
Howard Hinnanta6119a82011-05-29 19:57:12 +0000251 size_type find_first_not_of(const basic_string& str, size_type pos = 0) const noexcept;
252 size_type find_first_not_of(const_pointer s, size_type pos, size_type n) const noexcept;
253 size_type find_first_not_of(const_pointer s, size_type pos = 0) const noexcept;
254 size_type find_first_not_of(value_type c, size_type pos = 0) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000255
Howard Hinnanta6119a82011-05-29 19:57:12 +0000256 size_type find_last_not_of(const basic_string& str, size_type pos = npos) const noexcept;
257 size_type find_last_not_of(const_pointer s, size_type pos, size_type n) const noexcept;
258 size_type find_last_not_of(const_pointer s, size_type pos = npos) const noexcept;
259 size_type find_last_not_of(value_type c, size_type pos = npos) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000260
Howard Hinnanta6119a82011-05-29 19:57:12 +0000261 int compare(const basic_string& str) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000262 int compare(size_type pos1, size_type n1, const basic_string& str) const;
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000263 int compare(size_type pos1, size_type n1, const basic_string& str,
264 size_type pos2, size_type n2) const;
Howard Hinnanta6119a82011-05-29 19:57:12 +0000265 int compare(const_pointer s) const noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000266 int compare(size_type pos1, size_type n1, const_pointer s) const;
267 int compare(size_type pos1, size_type n1, const_pointer s, size_type n2) const;
268
269 bool __invariants() const;
270};
271
272template<class charT, class traits, class Allocator>
273basic_string<charT, traits, Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000274operator+(const basic_string<charT, traits, Allocator>& lhs,
275 const basic_string<charT, traits, Allocator>& rhs);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000276
277template<class charT, class traits, class Allocator>
278basic_string<charT, traits, Allocator>
279operator+(const charT* lhs , const basic_string<charT,traits,Allocator>&rhs);
280
281template<class charT, class traits, class Allocator>
282basic_string<charT, traits, Allocator>
283operator+(charT lhs, const basic_string<charT,traits,Allocator>& rhs);
284
285template<class charT, class traits, class Allocator>
286basic_string<charT, traits, Allocator>
287operator+(const basic_string<charT, traits, Allocator>& lhs, const charT* rhs);
288
289template<class charT, class traits, class Allocator>
290basic_string<charT, traits, Allocator>
291operator+(const basic_string<charT, traits, Allocator>& lhs, charT rhs);
292
293template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000294bool operator==(const basic_string<charT, traits, Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000295 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000296
297template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000298bool operator==(const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000299
300template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000301bool operator==(const basic_string<charT,traits,Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000302
Howard Hinnant324bb032010-08-22 00:02:43 +0000303template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000304bool operator!=(const basic_string<charT,traits,Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000305 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000306
307template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000308bool operator!=(const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000309
310template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000311bool operator!=(const basic_string<charT, traits, Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000312
313template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000314bool operator< (const basic_string<charT, traits, Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000315 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000316
317template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000318bool operator< (const basic_string<charT, traits, Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000319
320template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000321bool operator< (const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000322
323template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000324bool operator> (const basic_string<charT, traits, Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000325 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000326
327template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000328bool operator> (const basic_string<charT, traits, Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000329
330template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000331bool operator> (const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000332
333template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000334bool operator<=(const basic_string<charT, traits, Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000335 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000336
337template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000338bool operator<=(const basic_string<charT, traits, Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000339
340template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000341bool operator<=(const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000342
343template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000344bool operator>=(const basic_string<charT, traits, Allocator>& lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +0000345 const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000346
347template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000348bool operator>=(const basic_string<charT, traits, Allocator>& lhs, const charT* rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000349
350template<class charT, class traits, class Allocator>
Howard Hinnanta6119a82011-05-29 19:57:12 +0000351bool operator>=(const charT* lhs, const basic_string<charT, traits, Allocator>& rhs) noexcept;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000352
353template<class charT, class traits, class Allocator>
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000354void swap(basic_string<charT, traits, Allocator>& lhs,
Howard Hinnant53f7d4c2011-06-03 18:40:47 +0000355 basic_string<charT, traits, Allocator>& rhs)
356 noexcept(noexcept(lhs.swap(rhs)));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000357
358template<class charT, class traits, class Allocator>
359basic_istream<charT, traits>&
360operator>>(basic_istream<charT, traits>& is, basic_string<charT, traits, Allocator>& str);
361
362template<class charT, class traits, class Allocator>
363basic_ostream<charT, traits>&
364operator<<(basic_ostream<charT, traits>& os, const basic_string<charT, traits, Allocator>& str);
365
366template<class charT, class traits, class Allocator>
Howard Hinnant324bb032010-08-22 00:02:43 +0000367basic_istream<charT, traits>&
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000368getline(basic_istream<charT, traits>& is, basic_string<charT, traits, Allocator>& str,
369 charT delim);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000370
371template<class charT, class traits, class Allocator>
372basic_istream<charT, traits>&
373getline(basic_istream<charT, traits>& is, basic_string<charT, traits, Allocator>& str);
374
375typedef basic_string<char> string;
376typedef basic_string<wchar_t> wstring;
Howard Hinnanta6a062d2010-06-02 18:20:39 +0000377typedef basic_string<char16_t> u16string;
378typedef basic_string<char32_t> u32string;
379
380int stoi (const string& str, size_t* idx = 0, int base = 10);
381long stol (const string& str, size_t* idx = 0, int base = 10);
382unsigned long stoul (const string& str, size_t* idx = 0, int base = 10);
383long long stoll (const string& str, size_t* idx = 0, int base = 10);
384unsigned long long stoull(const string& str, size_t* idx = 0, int base = 10);
385
386float stof (const string& str, size_t* idx = 0);
387double stod (const string& str, size_t* idx = 0);
388long double stold(const string& str, size_t* idx = 0);
389
390string to_string(int val);
391string to_string(unsigned val);
392string to_string(long val);
393string to_string(unsigned long val);
394string to_string(long long val);
395string to_string(unsigned long long val);
396string to_string(float val);
397string to_string(double val);
398string to_string(long double val);
399
400int stoi (const wstring& str, size_t* idx = 0, int base = 10);
401long stol (const wstring& str, size_t* idx = 0, int base = 10);
402unsigned long stoul (const wstring& str, size_t* idx = 0, int base = 10);
403long long stoll (const wstring& str, size_t* idx = 0, int base = 10);
404unsigned long long stoull(const wstring& str, size_t* idx = 0, int base = 10);
405
406float stof (const wstring& str, size_t* idx = 0);
407double stod (const wstring& str, size_t* idx = 0);
408long double stold(const wstring& str, size_t* idx = 0);
409
410wstring to_wstring(int val);
411wstring to_wstring(unsigned val);
412wstring to_wstring(long val);
413wstring to_wstring(unsigned long val);
414wstring to_wstring(long long val);
415wstring to_wstring(unsigned long long val);
416wstring to_wstring(float val);
417wstring to_wstring(double val);
418wstring to_wstring(long double val);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000419
420template <> struct hash<string>;
421template <> struct hash<u16string>;
422template <> struct hash<u32string>;
423template <> struct hash<wstring>;
424
425} // std
426
427*/
428
429#include <__config>
430#include <iosfwd>
431#include <cstring>
Howard Hinnantadff4892010-05-24 17:49:41 +0000432#include <cstdio> // For EOF.
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000433#include <cwchar>
434#include <algorithm>
435#include <iterator>
436#include <utility>
437#include <memory>
438#include <stdexcept>
439#include <type_traits>
440#include <initializer_list>
441#include <__functional_base>
442#ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
443#include <cstdint>
444#endif
445#if defined(_LIBCPP_NO_EXCEPTIONS) || defined(_LIBCPP_DEBUG)
446#include <cassert>
447#endif
448
449#pragma GCC system_header
450
451_LIBCPP_BEGIN_NAMESPACE_STD
452
453// fpos
454
455template <class _StateT>
Howard Hinnant8d7a9552010-09-23 17:31:07 +0000456class _LIBCPP_VISIBLE fpos
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000457{
458private:
459 _StateT __st_;
460 streamoff __off_;
461public:
462 _LIBCPP_INLINE_VISIBILITY fpos(streamoff __off = streamoff()) : __st_(), __off_(__off) {}
463
464 _LIBCPP_INLINE_VISIBILITY operator streamoff() const {return __off_;}
465
466 _LIBCPP_INLINE_VISIBILITY _StateT state() const {return __st_;}
467 _LIBCPP_INLINE_VISIBILITY void state(_StateT __st) {__st_ = __st;}
468
469 _LIBCPP_INLINE_VISIBILITY fpos& operator+=(streamoff __off) {__off_ += __off; return *this;}
470 _LIBCPP_INLINE_VISIBILITY fpos operator+ (streamoff __off) const {fpos __t(*this); __t += __off; return __t;}
471 _LIBCPP_INLINE_VISIBILITY fpos& operator-=(streamoff __off) {__off_ -= __off; return *this;}
472 _LIBCPP_INLINE_VISIBILITY fpos operator- (streamoff __off) const {fpos __t(*this); __t -= __off; return __t;}
473};
474
475template <class _StateT>
476inline _LIBCPP_INLINE_VISIBILITY
477streamoff operator-(const fpos<_StateT>& __x, const fpos<_StateT>& __y)
478 {return streamoff(__x) - streamoff(__y);}
479
480template <class _StateT>
481inline _LIBCPP_INLINE_VISIBILITY
482bool operator==(const fpos<_StateT>& __x, const fpos<_StateT>& __y)
483 {return streamoff(__x) == streamoff(__y);}
484
485template <class _StateT>
486inline _LIBCPP_INLINE_VISIBILITY
487bool operator!=(const fpos<_StateT>& __x, const fpos<_StateT>& __y)
488 {return streamoff(__x) != streamoff(__y);}
489
490// char_traits
491
492template <class _CharT>
Howard Hinnant36cdf022010-09-10 16:42:26 +0000493struct _LIBCPP_VISIBLE char_traits
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000494{
495 typedef _CharT char_type;
496 typedef int int_type;
497 typedef streamoff off_type;
498 typedef streampos pos_type;
499 typedef mbstate_t state_type;
500
Howard Hinnanta6119a82011-05-29 19:57:12 +0000501 _LIBCPP_INLINE_VISIBILITY
502 static void assign(char_type& __c1, const char_type& __c2) _NOEXCEPT
503 {__c1 = __c2;}
504 _LIBCPP_INLINE_VISIBILITY
505 static bool eq(char_type __c1, char_type __c2) _NOEXCEPT
506 {return __c1 == __c2;}
507 _LIBCPP_INLINE_VISIBILITY
508 static bool lt(char_type __c1, char_type __c2) _NOEXCEPT
509 {return __c1 < __c2;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000510
511 static int compare(const char_type* __s1, const char_type* __s2, size_t __n);
512 static size_t length(const char_type* __s);
513 static const char_type* find(const char_type* __s, size_t __n, const char_type& __a);
514 static char_type* move(char_type* __s1, const char_type* __s2, size_t __n);
515 static char_type* copy(char_type* __s1, const char_type* __s2, size_t __n);
516 static char_type* assign(char_type* __s, size_t __n, char_type __a);
517
Howard Hinnanta6119a82011-05-29 19:57:12 +0000518 _LIBCPP_INLINE_VISIBILITY static int_type not_eof(int_type __c) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000519 {return eq_int_type(__c, eof()) ? ~eof() : __c;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000520 _LIBCPP_INLINE_VISIBILITY
521 static char_type to_char_type(int_type __c) _NOEXCEPT
522 {return char_type(__c);}
523 _LIBCPP_INLINE_VISIBILITY
524 static int_type to_int_type(char_type __c) _NOEXCEPT
525 {return int_type(__c);}
526 _LIBCPP_INLINE_VISIBILITY
527 static bool eq_int_type(int_type __c1, int_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000528 {return __c1 == __c2;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000529 _LIBCPP_INLINE_VISIBILITY
530 static int_type eof() _NOEXCEPT
531 {return int_type(EOF);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000532};
533
534template <class _CharT>
535int
536char_traits<_CharT>::compare(const char_type* __s1, const char_type* __s2, size_t __n)
537{
538 for (; __n; --__n, ++__s1, ++__s2)
539 {
540 if (lt(*__s1, *__s2))
541 return -1;
542 if (lt(*__s2, *__s1))
543 return 1;
544 }
545 return 0;
546}
547
548template <class _CharT>
549inline _LIBCPP_INLINE_VISIBILITY
550size_t
551char_traits<_CharT>::length(const char_type* __s)
552{
553 size_t __len = 0;
554 for (; !eq(*__s, char_type(0)); ++__s)
555 ++__len;
556 return __len;
557}
558
559template <class _CharT>
560inline _LIBCPP_INLINE_VISIBILITY
561const _CharT*
562char_traits<_CharT>::find(const char_type* __s, size_t __n, const char_type& __a)
563{
564 for (; __n; --__n)
565 {
566 if (eq(*__s, __a))
567 return __s;
568 ++__s;
569 }
570 return 0;
571}
572
573template <class _CharT>
574_CharT*
575char_traits<_CharT>::move(char_type* __s1, const char_type* __s2, size_t __n)
576{
577 char_type* __r = __s1;
578 if (__s1 < __s2)
579 {
580 for (; __n; --__n, ++__s1, ++__s2)
581 assign(*__s1, *__s2);
582 }
583 else if (__s2 < __s1)
584 {
585 __s1 += __n;
586 __s2 += __n;
587 for (; __n; --__n)
588 assign(*--__s1, *--__s2);
589 }
590 return __r;
591}
592
593template <class _CharT>
594inline _LIBCPP_INLINE_VISIBILITY
595_CharT*
596char_traits<_CharT>::copy(char_type* __s1, const char_type* __s2, size_t __n)
597{
598 char_type* __r = __s1;
599 for (; __n; --__n, ++__s1, ++__s2)
600 assign(*__s1, *__s2);
601 return __r;
602}
603
604template <class _CharT>
605inline _LIBCPP_INLINE_VISIBILITY
606_CharT*
607char_traits<_CharT>::assign(char_type* __s, size_t __n, char_type __a)
608{
609 char_type* __r = __s;
610 for (; __n; --__n, ++__s)
611 assign(*__s, __a);
612 return __r;
613}
614
615// char_traits<char>
616
617template <>
Howard Hinnant36cdf022010-09-10 16:42:26 +0000618struct _LIBCPP_VISIBLE char_traits<char>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000619{
620 typedef char char_type;
621 typedef int int_type;
622 typedef streamoff off_type;
623 typedef streampos pos_type;
624 typedef mbstate_t state_type;
625
Howard Hinnanta6119a82011-05-29 19:57:12 +0000626 _LIBCPP_INLINE_VISIBILITY
627 static void assign(char_type& __c1, const char_type& __c2) _NOEXCEPT
628 {__c1 = __c2;}
629 _LIBCPP_INLINE_VISIBILITY
630 static bool eq(char_type __c1, char_type __c2) _NOEXCEPT
631 {return __c1 == __c2;}
632 _LIBCPP_INLINE_VISIBILITY
633 static bool lt(char_type __c1, char_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000634 {return (unsigned char)__c1 < (unsigned char)__c2;}
635
Howard Hinnanta6119a82011-05-29 19:57:12 +0000636 _LIBCPP_INLINE_VISIBILITY
637 static int compare(const char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000638 {return memcmp(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000639 _LIBCPP_INLINE_VISIBILITY
640 static size_t length(const char_type* __s) {return strlen(__s);}
641 _LIBCPP_INLINE_VISIBILITY
642 static const char_type* find(const char_type* __s, size_t __n, const char_type& __a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000643 {return (const char_type*)memchr(__s, to_int_type(__a), __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000644 _LIBCPP_INLINE_VISIBILITY
645 static char_type* move(char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000646 {return (char_type*)memmove(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000647 _LIBCPP_INLINE_VISIBILITY
648 static char_type* copy(char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000649 {return (char_type*)memcpy(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000650 _LIBCPP_INLINE_VISIBILITY
651 static char_type* assign(char_type* __s, size_t __n, char_type __a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000652 {return (char_type*)memset(__s, to_int_type(__a), __n);}
653
Howard Hinnanta6119a82011-05-29 19:57:12 +0000654 _LIBCPP_INLINE_VISIBILITY static int_type not_eof(int_type __c) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000655 {return eq_int_type(__c, eof()) ? ~eof() : __c;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000656 _LIBCPP_INLINE_VISIBILITY
657 static char_type to_char_type(int_type __c) _NOEXCEPT
658 {return char_type(__c);}
659 _LIBCPP_INLINE_VISIBILITY
660 static int_type to_int_type(char_type __c) _NOEXCEPT
661 {return int_type((unsigned char)__c);}
662 _LIBCPP_INLINE_VISIBILITY
663 static bool eq_int_type(int_type __c1, int_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000664 {return __c1 == __c2;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000665 _LIBCPP_INLINE_VISIBILITY
666 static int_type eof() _NOEXCEPT
667 {return int_type(EOF);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000668};
669
670// char_traits<wchar_t>
671
672template <>
Howard Hinnant8d7a9552010-09-23 17:31:07 +0000673struct _LIBCPP_VISIBLE char_traits<wchar_t>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000674{
675 typedef wchar_t char_type;
676 typedef wint_t int_type;
677 typedef streamoff off_type;
678 typedef streampos pos_type;
679 typedef mbstate_t state_type;
680
Howard Hinnanta6119a82011-05-29 19:57:12 +0000681 _LIBCPP_INLINE_VISIBILITY
682 static void assign(char_type& __c1, const char_type& __c2) _NOEXCEPT
683 {__c1 = __c2;}
684 _LIBCPP_INLINE_VISIBILITY
685 static bool eq(char_type __c1, char_type __c2) _NOEXCEPT
686 {return __c1 == __c2;}
687 _LIBCPP_INLINE_VISIBILITY
688 static bool lt(char_type __c1, char_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000689 {return __c1 < __c2;}
690
Howard Hinnanta6119a82011-05-29 19:57:12 +0000691 _LIBCPP_INLINE_VISIBILITY
692 static int compare(const char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000693 {return wmemcmp(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000694 _LIBCPP_INLINE_VISIBILITY
695 static size_t length(const char_type* __s)
696 {return wcslen(__s);}
697 _LIBCPP_INLINE_VISIBILITY
698 static const char_type* find(const char_type* __s, size_t __n, const char_type& __a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000699 {return (const char_type*)wmemchr(__s, __a, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000700 _LIBCPP_INLINE_VISIBILITY
701 static char_type* move(char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000702 {return (char_type*)wmemmove(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000703 _LIBCPP_INLINE_VISIBILITY
704 static char_type* copy(char_type* __s1, const char_type* __s2, size_t __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000705 {return (char_type*)wmemcpy(__s1, __s2, __n);}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000706 _LIBCPP_INLINE_VISIBILITY
707 static char_type* assign(char_type* __s, size_t __n, char_type __a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000708 {return (char_type*)wmemset(__s, __a, __n);}
709
Howard Hinnanta6119a82011-05-29 19:57:12 +0000710 _LIBCPP_INLINE_VISIBILITY
711 static int_type not_eof(int_type __c) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000712 {return eq_int_type(__c, eof()) ? ~eof() : __c;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000713 _LIBCPP_INLINE_VISIBILITY
714 static char_type to_char_type(int_type __c) _NOEXCEPT
715 {return char_type(__c);}
716 _LIBCPP_INLINE_VISIBILITY
717 static int_type to_int_type(char_type __c) _NOEXCEPT
718 {return int_type(__c);}
719 _LIBCPP_INLINE_VISIBILITY
720 static bool eq_int_type(int_type __c1, int_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000721 {return __c1 == __c2;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000722 _LIBCPP_INLINE_VISIBILITY
723 static int_type eof() _NOEXCEPT
724 {return int_type(WEOF);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000725};
726
727#ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
728
729template <>
Howard Hinnant8d7a9552010-09-23 17:31:07 +0000730struct _LIBCPP_VISIBLE char_traits<char16_t>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000731{
732 typedef char16_t char_type;
733 typedef uint_least16_t int_type;
734 typedef streamoff off_type;
735 typedef u16streampos pos_type;
736 typedef mbstate_t state_type;
737
Howard Hinnanta6119a82011-05-29 19:57:12 +0000738 _LIBCPP_INLINE_VISIBILITY
739 static void assign(char_type& __c1, const char_type& __c2) _NOEXCEPT
740 {__c1 = __c2;}
741 _LIBCPP_INLINE_VISIBILITY
742 static bool eq(char_type __c1, char_type __c2) _NOEXCEPT
743 {return __c1 == __c2;}
744 _LIBCPP_INLINE_VISIBILITY
745 static bool lt(char_type __c1, char_type __c2) _NOEXCEPT
746 {return __c1 < __c2;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000747
748 static int compare(const char_type* __s1, const char_type* __s2, size_t __n);
749 static size_t length(const char_type* __s);
750 static const char_type* find(const char_type* __s, size_t __n, const char_type& __a);
751 static char_type* move(char_type* __s1, const char_type* __s2, size_t __n);
752 static char_type* copy(char_type* __s1, const char_type* __s2, size_t __n);
753 static char_type* assign(char_type* __s, size_t __n, char_type __a);
754
Howard Hinnanta6119a82011-05-29 19:57:12 +0000755 _LIBCPP_INLINE_VISIBILITY
756 static int_type not_eof(int_type __c) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000757 {return eq_int_type(__c, eof()) ? ~eof() : __c;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000758 _LIBCPP_INLINE_VISIBILITY
759 static char_type to_char_type(int_type __c) _NOEXCEPT
760 {return char_type(__c);}
761 _LIBCPP_INLINE_VISIBILITY
762 static int_type to_int_type(char_type __c) _NOEXCEPT
763 {return int_type(__c);}
764 _LIBCPP_INLINE_VISIBILITY
765 static bool eq_int_type(int_type __c1, int_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000766 {return __c1 == __c2;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000767 _LIBCPP_INLINE_VISIBILITY
768 static int_type eof() _NOEXCEPT
769 {return int_type(0xDFFF);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000770};
771
772inline _LIBCPP_INLINE_VISIBILITY
773int
774char_traits<char16_t>::compare(const char_type* __s1, const char_type* __s2, size_t __n)
775{
776 for (; __n; --__n, ++__s1, ++__s2)
777 {
778 if (lt(*__s1, *__s2))
779 return -1;
780 if (lt(*__s2, *__s1))
781 return 1;
782 }
783 return 0;
784}
785
786inline _LIBCPP_INLINE_VISIBILITY
787size_t
788char_traits<char16_t>::length(const char_type* __s)
789{
790 size_t __len = 0;
791 for (; !eq(*__s, char_type(0)); ++__s)
792 ++__len;
793 return __len;
794}
795
796inline _LIBCPP_INLINE_VISIBILITY
797const char16_t*
798char_traits<char16_t>::find(const char_type* __s, size_t __n, const char_type& __a)
799{
800 for (; __n; --__n)
801 {
802 if (eq(*__s, __a))
803 return __s;
804 ++__s;
805 }
806 return 0;
807}
808
809inline _LIBCPP_INLINE_VISIBILITY
810char16_t*
811char_traits<char16_t>::move(char_type* __s1, const char_type* __s2, size_t __n)
812{
813 char_type* __r = __s1;
814 if (__s1 < __s2)
815 {
816 for (; __n; --__n, ++__s1, ++__s2)
817 assign(*__s1, *__s2);
818 }
819 else if (__s2 < __s1)
820 {
821 __s1 += __n;
822 __s2 += __n;
823 for (; __n; --__n)
824 assign(*--__s1, *--__s2);
825 }
826 return __r;
827}
828
829inline _LIBCPP_INLINE_VISIBILITY
830char16_t*
831char_traits<char16_t>::copy(char_type* __s1, const char_type* __s2, size_t __n)
832{
833 char_type* __r = __s1;
834 for (; __n; --__n, ++__s1, ++__s2)
835 assign(*__s1, *__s2);
836 return __r;
837}
838
839inline _LIBCPP_INLINE_VISIBILITY
840char16_t*
841char_traits<char16_t>::assign(char_type* __s, size_t __n, char_type __a)
842{
843 char_type* __r = __s;
844 for (; __n; --__n, ++__s)
845 assign(*__s, __a);
846 return __r;
847}
848
849template <>
Howard Hinnant8d7a9552010-09-23 17:31:07 +0000850struct _LIBCPP_VISIBLE char_traits<char32_t>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000851{
852 typedef char32_t char_type;
853 typedef uint_least32_t int_type;
854 typedef streamoff off_type;
855 typedef u32streampos pos_type;
856 typedef mbstate_t state_type;
857
Howard Hinnanta6119a82011-05-29 19:57:12 +0000858 _LIBCPP_INLINE_VISIBILITY
859 static void assign(char_type& __c1, const char_type& __c2) _NOEXCEPT
860 {__c1 = __c2;}
861 _LIBCPP_INLINE_VISIBILITY
862 static bool eq(char_type __c1, char_type __c2) _NOEXCEPT
863 {return __c1 == __c2;}
864 _LIBCPP_INLINE_VISIBILITY
865 static bool lt(char_type __c1, char_type __c2) _NOEXCEPT
866 {return __c1 < __c2;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000867
868 static int compare(const char_type* __s1, const char_type* __s2, size_t __n);
869 static size_t length(const char_type* __s);
870 static const char_type* find(const char_type* __s, size_t __n, const char_type& __a);
871 static char_type* move(char_type* __s1, const char_type* __s2, size_t __n);
872 static char_type* copy(char_type* __s1, const char_type* __s2, size_t __n);
873 static char_type* assign(char_type* __s, size_t __n, char_type __a);
874
Howard Hinnanta6119a82011-05-29 19:57:12 +0000875 _LIBCPP_INLINE_VISIBILITY
876 static int_type not_eof(int_type __c) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000877 {return eq_int_type(__c, eof()) ? ~eof() : __c;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000878 _LIBCPP_INLINE_VISIBILITY
879 static char_type to_char_type(int_type __c) _NOEXCEPT
880 {return char_type(__c);}
881 _LIBCPP_INLINE_VISIBILITY
882 static int_type to_int_type(char_type __c) _NOEXCEPT
883 {return int_type(__c);}
884 _LIBCPP_INLINE_VISIBILITY
885 static bool eq_int_type(int_type __c1, int_type __c2) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000886 {return __c1 == __c2;}
Howard Hinnanta6119a82011-05-29 19:57:12 +0000887 _LIBCPP_INLINE_VISIBILITY
888 static int_type eof() _NOEXCEPT
889 {return int_type(0xFFFFFFFF);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000890};
891
892inline _LIBCPP_INLINE_VISIBILITY
893int
894char_traits<char32_t>::compare(const char_type* __s1, const char_type* __s2, size_t __n)
895{
896 for (; __n; --__n, ++__s1, ++__s2)
897 {
898 if (lt(*__s1, *__s2))
899 return -1;
900 if (lt(*__s2, *__s1))
901 return 1;
902 }
903 return 0;
904}
905
906inline _LIBCPP_INLINE_VISIBILITY
907size_t
908char_traits<char32_t>::length(const char_type* __s)
909{
910 size_t __len = 0;
911 for (; !eq(*__s, char_type(0)); ++__s)
912 ++__len;
913 return __len;
914}
915
916inline _LIBCPP_INLINE_VISIBILITY
917const char32_t*
918char_traits<char32_t>::find(const char_type* __s, size_t __n, const char_type& __a)
919{
920 for (; __n; --__n)
921 {
922 if (eq(*__s, __a))
923 return __s;
924 ++__s;
925 }
926 return 0;
927}
928
929inline _LIBCPP_INLINE_VISIBILITY
930char32_t*
931char_traits<char32_t>::move(char_type* __s1, const char_type* __s2, size_t __n)
932{
933 char_type* __r = __s1;
934 if (__s1 < __s2)
935 {
936 for (; __n; --__n, ++__s1, ++__s2)
937 assign(*__s1, *__s2);
938 }
939 else if (__s2 < __s1)
940 {
941 __s1 += __n;
942 __s2 += __n;
943 for (; __n; --__n)
944 assign(*--__s1, *--__s2);
945 }
946 return __r;
947}
948
949inline _LIBCPP_INLINE_VISIBILITY
950char32_t*
951char_traits<char32_t>::copy(char_type* __s1, const char_type* __s2, size_t __n)
952{
953 char_type* __r = __s1;
954 for (; __n; --__n, ++__s1, ++__s2)
955 assign(*__s1, *__s2);
956 return __r;
957}
958
959inline _LIBCPP_INLINE_VISIBILITY
960char32_t*
961char_traits<char32_t>::assign(char_type* __s, size_t __n, char_type __a)
962{
963 char_type* __r = __s;
964 for (; __n; --__n, ++__s)
965 assign(*__s, __a);
966 return __r;
967}
968
Howard Hinnant324bb032010-08-22 00:02:43 +0000969#endif // _LIBCPP_HAS_NO_UNICODE_CHARS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000970
971// basic_string
972
973template<class _CharT, class _Traits, class _Allocator>
974basic_string<_CharT, _Traits, _Allocator>
Howard Hinnant2b1b2d42011-06-14 19:58:17 +0000975operator+(const basic_string<_CharT, _Traits, _Allocator>& __x,
976 const basic_string<_CharT, _Traits, _Allocator>& __y);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000977
978template<class _CharT, class _Traits, class _Allocator>
979basic_string<_CharT, _Traits, _Allocator>
Howard Hinnant2b1b2d42011-06-14 19:58:17 +0000980operator+(const _CharT* __x, const basic_string<_CharT,_Traits,_Allocator>& __y);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000981
982template<class _CharT, class _Traits, class _Allocator>
983basic_string<_CharT, _Traits, _Allocator>
Howard Hinnant2b1b2d42011-06-14 19:58:17 +0000984operator+(_CharT __x, const basic_string<_CharT,_Traits,_Allocator>& __y);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000985
986template<class _CharT, class _Traits, class _Allocator>
987basic_string<_CharT, _Traits, _Allocator>
Howard Hinnant2b1b2d42011-06-14 19:58:17 +0000988operator+(const basic_string<_CharT, _Traits, _Allocator>& __x, const _CharT* __y);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000989
990template<class _CharT, class _Traits, class _Allocator>
991basic_string<_CharT, _Traits, _Allocator>
Howard Hinnant2b1b2d42011-06-14 19:58:17 +0000992operator+(const basic_string<_CharT, _Traits, _Allocator>& __x, _CharT __y);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000993
994template <bool>
995class __basic_string_common
996{
997protected:
998 void __throw_length_error() const;
999 void __throw_out_of_range() const;
1000};
1001
1002template <bool __b>
1003void
1004__basic_string_common<__b>::__throw_length_error() const
1005{
1006#ifndef _LIBCPP_NO_EXCEPTIONS
1007 throw length_error("basic_string");
1008#else
1009 assert(!"basic_string length_error");
1010#endif
1011}
1012
1013template <bool __b>
1014void
1015__basic_string_common<__b>::__throw_out_of_range() const
1016{
1017#ifndef _LIBCPP_NO_EXCEPTIONS
1018 throw out_of_range("basic_string");
1019#else
1020 assert(!"basic_string out_of_range");
1021#endif
1022}
1023
1024extern template class __basic_string_common<true>;
1025
Howard Hinnant324bb032010-08-22 00:02:43 +00001026template<class _CharT, class _Traits, class _Allocator>
Howard Hinnant36cdf022010-09-10 16:42:26 +00001027class _LIBCPP_VISIBLE basic_string
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001028 : private __basic_string_common<true>
1029{
1030public:
1031 typedef basic_string __self;
1032 typedef _Traits traits_type;
1033 typedef typename traits_type::char_type value_type;
1034 typedef _Allocator allocator_type;
Howard Hinnante32b5e22010-11-17 17:55:08 +00001035 typedef allocator_traits<allocator_type> __alloc_traits;
1036 typedef typename __alloc_traits::size_type size_type;
1037 typedef typename __alloc_traits::difference_type difference_type;
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001038 typedef value_type& reference;
1039 typedef const value_type& const_reference;
Howard Hinnante32b5e22010-11-17 17:55:08 +00001040 typedef typename __alloc_traits::pointer pointer;
1041 typedef typename __alloc_traits::const_pointer const_pointer;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001042#ifdef _LIBCPP_DEBUG
1043 typedef __debug_iter<basic_string, pointer> iterator;
1044 typedef __debug_iter<basic_string, const_pointer> const_iterator;
1045
1046 friend class __debug_iter<basic_string, pointer>;
1047 friend class __debug_iter<basic_string, const_pointer>;
1048#elif defined(_LIBCPP_RAW_ITERATORS)
1049 typedef pointer iterator;
1050 typedef const_pointer const_iterator;
Howard Hinnant324bb032010-08-22 00:02:43 +00001051#else // defined(_LIBCPP_RAW_ITERATORS)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001052 typedef __wrap_iter<pointer> iterator;
1053 typedef __wrap_iter<const_pointer> const_iterator;
Howard Hinnant324bb032010-08-22 00:02:43 +00001054#endif // defined(_LIBCPP_RAW_ITERATORS)
Howard Hinnant0949eed2011-06-30 21:18:19 +00001055 typedef _VSTD::reverse_iterator<iterator> reverse_iterator;
1056 typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001057
1058private:
1059 struct __long
1060 {
1061 size_type __cap_;
1062 size_type __size_;
1063 pointer __data_;
1064 };
1065
1066#if _LIBCPP_BIG_ENDIAN
1067 enum {__short_mask = 0x80};
1068 enum {__long_mask = ~(size_type(~0) >> 1)};
Howard Hinnant324bb032010-08-22 00:02:43 +00001069#else // _LIBCPP_BIG_ENDIAN
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001070 enum {__short_mask = 0x01};
1071 enum {__long_mask = 0x1};
Howard Hinnant324bb032010-08-22 00:02:43 +00001072#endif // _LIBCPP_BIG_ENDIAN
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001073
1074 enum {__mask = size_type(~0) >> 1};
1075
1076 enum {__min_cap = (sizeof(__long) - 1)/sizeof(value_type) > 2 ?
1077 (sizeof(__long) - 1)/sizeof(value_type) : 2};
1078
1079 struct __short
1080 {
1081 union
1082 {
1083 unsigned char __size_;
1084 value_type _;
1085 };
1086 value_type __data_[__min_cap];
1087 };
1088
1089 union _{__long _; __short __;};
1090
1091 enum {__n_words = sizeof(_) / sizeof(size_type)};
1092
1093 struct __raw
1094 {
1095 size_type __words[__n_words];
1096 };
1097
1098 struct __rep
1099 {
1100 union
1101 {
1102 __long __l;
1103 __short __s;
1104 __raw __r;
1105 };
1106 };
1107
1108 __compressed_pair<__rep, allocator_type> __r_;
1109
1110#ifdef _LIBCPP_DEBUG
1111
1112 pair<iterator*, const_iterator*> __iterator_list_;
1113
1114 _LIBCPP_INLINE_VISIBILITY iterator*& __get_iterator_list(iterator*) {return __iterator_list_.first;}
1115 _LIBCPP_INLINE_VISIBILITY const_iterator*& __get_iterator_list(const_iterator*) {return __iterator_list_.second;}
1116
1117#endif // _LIBCPP_DEBUG
1118
1119public:
1120 static const size_type npos = -1;
1121
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001122 _LIBCPP_INLINE_VISIBILITY basic_string()
1123 _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001124 _LIBCPP_INLINE_VISIBILITY explicit basic_string(const allocator_type& __a);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001125 basic_string(const basic_string& __str);
1126 basic_string(const basic_string& __str, const allocator_type& __a);
Howard Hinnant73d21a42010-09-04 23:28:19 +00001127#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant9f193f22011-01-26 00:06:59 +00001128 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001129 basic_string(basic_string&& __str)
1130 _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value);
Howard Hinnant9f193f22011-01-26 00:06:59 +00001131 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001132 basic_string(basic_string&& __str, const allocator_type& __a);
Howard Hinnant73d21a42010-09-04 23:28:19 +00001133#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001134 _LIBCPP_INLINE_VISIBILITY basic_string(const_pointer __s);
1135 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001136 basic_string(const_pointer __s, const allocator_type& __a);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001137 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001138 basic_string(const_pointer __s, size_type __n);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001139 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001140 basic_string(const_pointer __s, size_type __n, const allocator_type& __a);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001141 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001142 basic_string(size_type __n, value_type __c);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001143 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001144 basic_string(size_type __n, value_type __c, const allocator_type& __a);
1145 basic_string(const basic_string& __str, size_type __pos, size_type __n = npos,
1146 const allocator_type& __a = allocator_type());
1147 template<class _InputIterator>
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001148 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001149 basic_string(_InputIterator __first, _InputIterator __last);
1150 template<class _InputIterator>
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001151 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001152 basic_string(_InputIterator __first, _InputIterator __last, const allocator_type& __a);
Howard Hinnante3e32912011-08-12 21:56:02 +00001153#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001154 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001155 basic_string(initializer_list<value_type> __il);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001156 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001157 basic_string(initializer_list<value_type> __il, const allocator_type& __a);
Howard Hinnante3e32912011-08-12 21:56:02 +00001158#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001159
1160 ~basic_string();
1161
Howard Hinnante32b5e22010-11-17 17:55:08 +00001162 basic_string& operator=(const basic_string& __str);
Howard Hinnant73d21a42010-09-04 23:28:19 +00001163#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001164 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001165 basic_string& operator=(basic_string&& __str)
1166 _NOEXCEPT_(__alloc_traits::propagate_on_container_move_assignment::value &&
1167 is_nothrow_move_assignable<allocator_type>::value);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001168#endif
Howard Hinnanta6119a82011-05-29 19:57:12 +00001169 _LIBCPP_INLINE_VISIBILITY basic_string& operator=(const_pointer __s) {return assign(__s);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001170 basic_string& operator=(value_type __c);
Howard Hinnante3e32912011-08-12 21:56:02 +00001171#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001172 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001173 basic_string& operator=(initializer_list<value_type> __il) {return assign(__il.begin(), __il.size());}
Howard Hinnante3e32912011-08-12 21:56:02 +00001174#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001175
1176#ifndef _LIBCPP_DEBUG
Howard Hinnanta6119a82011-05-29 19:57:12 +00001177 _LIBCPP_INLINE_VISIBILITY
1178 iterator begin() _NOEXCEPT
1179 {return iterator(__get_pointer());}
1180 _LIBCPP_INLINE_VISIBILITY
1181 const_iterator begin() const _NOEXCEPT
1182 {return const_iterator(data());}
1183 _LIBCPP_INLINE_VISIBILITY
1184 iterator end() _NOEXCEPT
1185 {return iterator(__get_pointer() + size());}
1186 _LIBCPP_INLINE_VISIBILITY
1187 const_iterator end() const _NOEXCEPT
1188 {return const_iterator(data() + size());}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001189#else // _LIBCPP_DEBUG
1190 _LIBCPP_INLINE_VISIBILITY iterator begin() {return iterator(this, __get_pointer());}
1191 _LIBCPP_INLINE_VISIBILITY const_iterator begin() const {return const_iterator(this, data());}
1192 _LIBCPP_INLINE_VISIBILITY iterator end() {return iterator(this, __get_pointer() + size());}
1193 _LIBCPP_INLINE_VISIBILITY const_iterator end() const {return const_iterator(this, data() + size());}
1194#endif // _LIBCPP_DEBUG
Howard Hinnanta6119a82011-05-29 19:57:12 +00001195 _LIBCPP_INLINE_VISIBILITY
1196 reverse_iterator rbegin() _NOEXCEPT
1197 {return reverse_iterator(end());}
1198 _LIBCPP_INLINE_VISIBILITY
1199 const_reverse_iterator rbegin() const _NOEXCEPT
1200 {return const_reverse_iterator(end());}
1201 _LIBCPP_INLINE_VISIBILITY
1202 reverse_iterator rend() _NOEXCEPT
1203 {return reverse_iterator(begin());}
1204 _LIBCPP_INLINE_VISIBILITY
1205 const_reverse_iterator rend() const _NOEXCEPT
1206 {return const_reverse_iterator(begin());}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001207
Howard Hinnanta6119a82011-05-29 19:57:12 +00001208 _LIBCPP_INLINE_VISIBILITY
1209 const_iterator cbegin() const _NOEXCEPT
1210 {return begin();}
1211 _LIBCPP_INLINE_VISIBILITY
1212 const_iterator cend() const _NOEXCEPT
1213 {return end();}
1214 _LIBCPP_INLINE_VISIBILITY
1215 const_reverse_iterator crbegin() const _NOEXCEPT
1216 {return rbegin();}
1217 _LIBCPP_INLINE_VISIBILITY
1218 const_reverse_iterator crend() const _NOEXCEPT
1219 {return rend();}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001220
Howard Hinnanta6119a82011-05-29 19:57:12 +00001221 _LIBCPP_INLINE_VISIBILITY size_type size() const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001222 {return __is_long() ? __get_long_size() : __get_short_size();}
Howard Hinnanta6119a82011-05-29 19:57:12 +00001223 _LIBCPP_INLINE_VISIBILITY size_type length() const _NOEXCEPT {return size();}
1224 _LIBCPP_INLINE_VISIBILITY size_type max_size() const _NOEXCEPT;
1225 _LIBCPP_INLINE_VISIBILITY size_type capacity() const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001226 {return (__is_long() ? __get_long_cap() : __min_cap) - 1;}
1227
1228 void resize(size_type __n, value_type __c);
1229 _LIBCPP_INLINE_VISIBILITY void resize(size_type __n) {resize(__n, value_type());}
1230
1231 void reserve(size_type res_arg = 0);
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001232 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001233 void shrink_to_fit() _NOEXCEPT {reserve();}
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001234 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001235 void clear() _NOEXCEPT;
1236 _LIBCPP_INLINE_VISIBILITY bool empty() const _NOEXCEPT {return size() == 0;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001237
1238 _LIBCPP_INLINE_VISIBILITY const_reference operator[](size_type __pos) const;
1239 _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __pos);
1240
1241 const_reference at(size_type __n) const;
1242 reference at(size_type __n);
1243
1244 _LIBCPP_INLINE_VISIBILITY basic_string& operator+=(const basic_string& __str) {return append(__str);}
1245 _LIBCPP_INLINE_VISIBILITY basic_string& operator+=(const_pointer __s) {return append(__s);}
1246 _LIBCPP_INLINE_VISIBILITY basic_string& operator+=(value_type __c) {push_back(__c); return *this;}
Howard Hinnante3e32912011-08-12 21:56:02 +00001247#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001248 _LIBCPP_INLINE_VISIBILITY basic_string& operator+=(initializer_list<value_type> __il) {return append(__il);}
Howard Hinnante3e32912011-08-12 21:56:02 +00001249#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001250
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001251 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001252 basic_string& append(const basic_string& __str);
1253 basic_string& append(const basic_string& __str, size_type __pos, size_type __n);
1254 basic_string& append(const_pointer __s, size_type __n);
1255 basic_string& append(const_pointer __s);
1256 basic_string& append(size_type __n, value_type __c);
1257 template<class _InputIterator>
1258 typename enable_if
1259 <
1260 __is_input_iterator <_InputIterator>::value &&
1261 !__is_forward_iterator<_InputIterator>::value,
1262 basic_string&
1263 >::type
1264 append(_InputIterator __first, _InputIterator __last);
1265 template<class _ForwardIterator>
1266 typename enable_if
1267 <
1268 __is_forward_iterator<_ForwardIterator>::value,
1269 basic_string&
1270 >::type
1271 append(_ForwardIterator __first, _ForwardIterator __last);
Howard Hinnante3e32912011-08-12 21:56:02 +00001272#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001273 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001274 basic_string& append(initializer_list<value_type> __il) {return append(__il.begin(), __il.size());}
Howard Hinnante3e32912011-08-12 21:56:02 +00001275#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001276
1277 void push_back(value_type __c);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001278 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001279 void pop_back();
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001280 _LIBCPP_INLINE_VISIBILITY reference front();
1281 _LIBCPP_INLINE_VISIBILITY const_reference front() const;
1282 _LIBCPP_INLINE_VISIBILITY reference back();
1283 _LIBCPP_INLINE_VISIBILITY const_reference back() const;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001284
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001285 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001286 basic_string& assign(const basic_string& __str);
Howard Hinnanta6119a82011-05-29 19:57:12 +00001287#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
1288 _LIBCPP_INLINE_VISIBILITY
1289 basic_string& assign(basic_string&& str)
Howard Hinnant0949eed2011-06-30 21:18:19 +00001290 {*this = _VSTD::move(str); return *this;}
Howard Hinnanta6119a82011-05-29 19:57:12 +00001291#endif
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001292 basic_string& assign(const basic_string& __str, size_type __pos, size_type __n);
1293 basic_string& assign(const_pointer __s, size_type __n);
1294 basic_string& assign(const_pointer __s);
1295 basic_string& assign(size_type __n, value_type __c);
1296 template<class _InputIterator>
1297 typename enable_if
1298 <
1299 __is_input_iterator <_InputIterator>::value &&
1300 !__is_forward_iterator<_InputIterator>::value,
1301 basic_string&
1302 >::type
1303 assign(_InputIterator __first, _InputIterator __last);
1304 template<class _ForwardIterator>
1305 typename enable_if
1306 <
1307 __is_forward_iterator<_ForwardIterator>::value,
1308 basic_string&
1309 >::type
1310 assign(_ForwardIterator __first, _ForwardIterator __last);
Howard Hinnante3e32912011-08-12 21:56:02 +00001311#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001312 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001313 basic_string& assign(initializer_list<value_type> __il) {return assign(__il.begin(), __il.size());}
Howard Hinnante3e32912011-08-12 21:56:02 +00001314#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001315
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001316 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001317 basic_string& insert(size_type __pos1, const basic_string& __str);
1318 basic_string& insert(size_type __pos1, const basic_string& __str, size_type __pos2, size_type __n);
1319 basic_string& insert(size_type __pos, const_pointer __s, size_type __n);
1320 basic_string& insert(size_type __pos, const_pointer __s);
1321 basic_string& insert(size_type __pos, size_type __n, value_type __c);
1322 iterator insert(const_iterator __pos, value_type __c);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001323 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001324 iterator insert(const_iterator __pos, size_type __n, value_type __c);
1325 template<class _InputIterator>
1326 typename enable_if
1327 <
1328 __is_input_iterator <_InputIterator>::value &&
1329 !__is_forward_iterator<_InputIterator>::value,
1330 iterator
1331 >::type
1332 insert(const_iterator __pos, _InputIterator __first, _InputIterator __last);
1333 template<class _ForwardIterator>
1334 typename enable_if
1335 <
1336 __is_forward_iterator<_ForwardIterator>::value,
1337 iterator
1338 >::type
1339 insert(const_iterator __pos, _ForwardIterator __first, _ForwardIterator __last);
Howard Hinnante3e32912011-08-12 21:56:02 +00001340#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001341 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001342 iterator insert(const_iterator __pos, initializer_list<value_type> __il)
1343 {return insert(__pos, __il.begin(), __il.end());}
Howard Hinnante3e32912011-08-12 21:56:02 +00001344#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001345
1346 basic_string& erase(size_type __pos = 0, size_type __n = npos);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001347 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001348 iterator erase(const_iterator __pos);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001349 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001350 iterator erase(const_iterator __first, const_iterator __last);
1351
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001352 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001353 basic_string& replace(size_type __pos1, size_type __n1, const basic_string& __str);
1354 basic_string& replace(size_type __pos1, size_type __n1, const basic_string& __str, size_type __pos2, size_type __n2);
1355 basic_string& replace(size_type __pos, size_type __n1, const_pointer __s, size_type __n2);
1356 basic_string& replace(size_type __pos, size_type __n1, const_pointer __s);
1357 basic_string& replace(size_type __pos, size_type __n1, size_type __n2, value_type __c);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001358 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001359 basic_string& replace(const_iterator __i1, const_iterator __i2, const basic_string& __str);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001360 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001361 basic_string& replace(const_iterator __i1, const_iterator __i2, const_pointer __s, size_type __n);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001362 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001363 basic_string& replace(const_iterator __i1, const_iterator __i2, const_pointer __s);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001364 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001365 basic_string& replace(const_iterator __i1, const_iterator __i2, size_type __n, value_type __c);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001366 template<class _InputIterator>
1367 typename enable_if
1368 <
1369 __is_input_iterator<_InputIterator>::value,
1370 basic_string&
1371 >::type
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001372 replace(const_iterator __i1, const_iterator __i2, _InputIterator __j1, _InputIterator __j2);
Howard Hinnante3e32912011-08-12 21:56:02 +00001373#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnant8d7a9552010-09-23 17:31:07 +00001374 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant7b2cb482010-11-17 21:11:40 +00001375 basic_string& replace(const_iterator __i1, const_iterator __i2, initializer_list<value_type> __il)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001376 {return replace(__i1, __i2, __il.begin(), __il.end());}
Howard Hinnante3e32912011-08-12 21:56:02 +00001377#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001378
1379 size_type copy(pointer __s, size_type __n, size_type __pos = 0) const;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001380 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001381 basic_string substr(size_type __pos = 0, size_type __n = npos) const;
1382
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001383 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001384 void swap(basic_string& __str)
1385 _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value ||
1386 __is_nothrow_swappable<allocator_type>::value);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001387
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001388 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001389 const_pointer c_str() const _NOEXCEPT {return data();}
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001390 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001391 const_pointer data() const _NOEXCEPT {return __get_pointer();}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001392
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001393 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001394 allocator_type get_allocator() const _NOEXCEPT {return __alloc();}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001395
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001396 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001397 size_type find(const basic_string& __str, size_type __pos = 0) const _NOEXCEPT;
1398 size_type find(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001399 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001400 size_type find(const_pointer __s, size_type __pos = 0) const _NOEXCEPT;
1401 size_type find(value_type __c, size_type __pos = 0) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001402
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001403 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001404 size_type rfind(const basic_string& __str, size_type __pos = npos) const _NOEXCEPT;
1405 size_type rfind(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001406 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001407 size_type rfind(const_pointer __s, size_type __pos = npos) const _NOEXCEPT;
1408 size_type rfind(value_type __c, size_type __pos = npos) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001409
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001410 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001411 size_type find_first_of(const basic_string& __str, size_type __pos = 0) const _NOEXCEPT;
1412 size_type find_first_of(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001413 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001414 size_type find_first_of(const_pointer __s, size_type __pos = 0) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001415 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001416 size_type find_first_of(value_type __c, size_type __pos = 0) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001417
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001418 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001419 size_type find_last_of(const basic_string& __str, size_type __pos = npos) const _NOEXCEPT;
1420 size_type find_last_of(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001421 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001422 size_type find_last_of(const_pointer __s, size_type __pos = npos) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001423 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001424 size_type find_last_of(value_type __c, size_type __pos = npos) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001425
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001426 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001427 size_type find_first_not_of(const basic_string& __str, size_type __pos = 0) const _NOEXCEPT;
1428 size_type find_first_not_of(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
1429 _LIBCPP_INLINE_VISIBILITY
1430 size_type find_first_not_of(const_pointer __s, size_type __pos = 0) const _NOEXCEPT;
1431 _LIBCPP_INLINE_VISIBILITY
1432 size_type find_first_not_of(value_type __c, size_type __pos = 0) const _NOEXCEPT;
1433
1434 _LIBCPP_INLINE_VISIBILITY
1435 size_type find_last_not_of(const basic_string& __str, size_type __pos = npos) const _NOEXCEPT;
1436 size_type find_last_not_of(const_pointer __s, size_type __pos, size_type __n) const _NOEXCEPT;
1437 _LIBCPP_INLINE_VISIBILITY
1438 size_type find_last_not_of(const_pointer __s, size_type __pos = npos) const _NOEXCEPT;
1439 _LIBCPP_INLINE_VISIBILITY
1440 size_type find_last_not_of(value_type __c, size_type __pos = npos) const _NOEXCEPT;
1441
1442 _LIBCPP_INLINE_VISIBILITY
1443 int compare(const basic_string& __str) const _NOEXCEPT;
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001444 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001445 int compare(size_type __pos1, size_type __n1, const basic_string& __str) const;
1446 int compare(size_type __pos1, size_type __n1, const basic_string& __str, size_type __pos2, size_type __n2) const;
Howard Hinnanta6119a82011-05-29 19:57:12 +00001447 int compare(const_pointer __s) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001448 int compare(size_type __pos1, size_type __n1, const_pointer __s) const;
1449 int compare(size_type __pos1, size_type __n1, const_pointer __s, size_type __n2) const;
1450
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001451 _LIBCPP_INLINE_VISIBILITY bool __invariants() const;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001452private:
Howard Hinnanta6119a82011-05-29 19:57:12 +00001453 _LIBCPP_INLINE_VISIBILITY
1454 allocator_type& __alloc() _NOEXCEPT
1455 {return __r_.second();}
1456 _LIBCPP_INLINE_VISIBILITY
1457 const allocator_type& __alloc() const _NOEXCEPT
1458 {return __r_.second();}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001459
Howard Hinnanta6119a82011-05-29 19:57:12 +00001460 _LIBCPP_INLINE_VISIBILITY
1461 bool __is_long() const _NOEXCEPT
1462 {return bool(__r_.first().__s.__size_ & __short_mask);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001463
Howard Hinnanta6119a82011-05-29 19:57:12 +00001464 _LIBCPP_INLINE_VISIBILITY
1465 void __set_short_size(size_type __s) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001466#if _LIBCPP_BIG_ENDIAN
1467 {__r_.first().__s.__size_ = (unsigned char)(__s);}
1468#else
1469 {__r_.first().__s.__size_ = (unsigned char)(__s << 1);}
1470#endif
Howard Hinnanta6119a82011-05-29 19:57:12 +00001471 _LIBCPP_INLINE_VISIBILITY
1472 size_type __get_short_size() const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001473#if _LIBCPP_BIG_ENDIAN
1474 {return __r_.first().__s.__size_;}
1475#else
1476 {return __r_.first().__s.__size_ >> 1;}
1477#endif
Howard Hinnanta6119a82011-05-29 19:57:12 +00001478 _LIBCPP_INLINE_VISIBILITY
1479 void __set_long_size(size_type __s) _NOEXCEPT
1480 {__r_.first().__l.__size_ = __s;}
1481 _LIBCPP_INLINE_VISIBILITY
1482 size_type __get_long_size() const _NOEXCEPT
1483 {return __r_.first().__l.__size_;}
1484 _LIBCPP_INLINE_VISIBILITY
1485 void __set_size(size_type __s) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001486 {if (__is_long()) __set_long_size(__s); else __set_short_size(__s);}
1487
Howard Hinnanta6119a82011-05-29 19:57:12 +00001488 _LIBCPP_INLINE_VISIBILITY
1489 void __set_long_cap(size_type __s) _NOEXCEPT
1490 {__r_.first().__l.__cap_ = __long_mask | __s;}
1491 _LIBCPP_INLINE_VISIBILITY
1492 size_type __get_long_cap() const _NOEXCEPT
1493 {return __r_.first().__l.__cap_ & ~__long_mask;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001494
Howard Hinnanta6119a82011-05-29 19:57:12 +00001495 _LIBCPP_INLINE_VISIBILITY
1496 void __set_long_pointer(pointer __p) _NOEXCEPT
1497 {__r_.first().__l.__data_ = __p;}
1498 _LIBCPP_INLINE_VISIBILITY
1499 pointer __get_long_pointer() _NOEXCEPT
1500 {return __r_.first().__l.__data_;}
1501 _LIBCPP_INLINE_VISIBILITY
1502 const_pointer __get_long_pointer() const _NOEXCEPT
1503 {return __r_.first().__l.__data_;}
1504 _LIBCPP_INLINE_VISIBILITY
1505 pointer __get_short_pointer() _NOEXCEPT
1506 {return __r_.first().__s.__data_;}
1507 _LIBCPP_INLINE_VISIBILITY
1508 const_pointer __get_short_pointer() const _NOEXCEPT
1509 {return __r_.first().__s.__data_;}
1510 _LIBCPP_INLINE_VISIBILITY
1511 pointer __get_pointer() _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001512 {return __is_long() ? __get_long_pointer() : __get_short_pointer();}
Howard Hinnanta6119a82011-05-29 19:57:12 +00001513 _LIBCPP_INLINE_VISIBILITY
1514 const_pointer __get_pointer() const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001515 {return __is_long() ? __get_long_pointer() : __get_short_pointer();}
1516
Howard Hinnanta6119a82011-05-29 19:57:12 +00001517 _LIBCPP_INLINE_VISIBILITY
1518 void __zero() _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001519 {
1520 size_type (&__a)[__n_words] = __r_.first().__r.__words;
1521 for (unsigned __i = 0; __i < __n_words; ++__i)
1522 __a[__i] = 0;
1523 }
1524
1525 template <size_type __a> static
Howard Hinnanta6119a82011-05-29 19:57:12 +00001526 _LIBCPP_INLINE_VISIBILITY
1527 size_type __align(size_type __s) _NOEXCEPT
1528 {return __s + (__a-1) & ~(__a-1);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001529 enum {__alignment = 16};
Howard Hinnanta6119a82011-05-29 19:57:12 +00001530 static _LIBCPP_INLINE_VISIBILITY
1531 size_type __recommend(size_type __s) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001532 {return (__s < __min_cap ? __min_cap :
Howard Hinnanta6119a82011-05-29 19:57:12 +00001533 __align<sizeof(value_type) < __alignment ?
1534 __alignment/sizeof(value_type) : 1 > (__s+1)) - 1;}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001535
1536 void __init(const_pointer __s, size_type __sz, size_type __reserve);
1537 void __init(const_pointer __s, size_type __sz);
1538 void __init(size_type __n, value_type __c);
Howard Hinnant324bb032010-08-22 00:02:43 +00001539
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001540 template <class _InputIterator>
1541 typename enable_if
1542 <
1543 __is_input_iterator <_InputIterator>::value &&
1544 !__is_forward_iterator<_InputIterator>::value,
1545 void
1546 >::type
1547 __init(_InputIterator __first, _InputIterator __last);
1548
1549 template <class _ForwardIterator>
1550 typename enable_if
1551 <
1552 __is_forward_iterator<_ForwardIterator>::value,
1553 void
1554 >::type
1555 __init(_ForwardIterator __first, _ForwardIterator __last);
1556
1557 void __grow_by(size_type __old_cap, size_type __delta_cap, size_type __old_sz,
Howard Hinnant324bb032010-08-22 00:02:43 +00001558 size_type __n_copy, size_type __n_del, size_type __n_add = 0);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001559 void __grow_by_and_replace(size_type __old_cap, size_type __delta_cap, size_type __old_sz,
1560 size_type __n_copy, size_type __n_del,
1561 size_type __n_add, const_pointer __p_new_stuff);
1562
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001563 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001564 void __erase_to_end(size_type __pos);
1565
Howard Hinnante32b5e22010-11-17 17:55:08 +00001566 _LIBCPP_INLINE_VISIBILITY
1567 void __copy_assign_alloc(const basic_string& __str)
1568 {__copy_assign_alloc(__str, integral_constant<bool,
1569 __alloc_traits::propagate_on_container_copy_assignment::value>());}
1570
1571 _LIBCPP_INLINE_VISIBILITY
1572 void __copy_assign_alloc(const basic_string& __str, true_type)
1573 {
1574 if (__alloc() != __str.__alloc())
1575 {
1576 clear();
1577 shrink_to_fit();
1578 }
1579 __alloc() = __str.__alloc();
1580 }
1581
1582 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001583 void __copy_assign_alloc(const basic_string& __str, false_type) _NOEXCEPT
Howard Hinnante32b5e22010-11-17 17:55:08 +00001584 {}
1585
1586#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001587 _LIBCPP_INLINE_VISIBILITY
Howard Hinnante32b5e22010-11-17 17:55:08 +00001588 void __move_assign(basic_string& __str, false_type);
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001589 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001590 void __move_assign(basic_string& __str, true_type)
1591 _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value);
Howard Hinnante32b5e22010-11-17 17:55:08 +00001592#endif
1593
1594 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001595 static void __swap_alloc(allocator_type& __x, allocator_type& __y)
1596 _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value ||
1597 __is_nothrow_swappable<allocator_type>::value)
Howard Hinnante32b5e22010-11-17 17:55:08 +00001598 {__swap_alloc(__x, __y, integral_constant<bool,
1599 __alloc_traits::propagate_on_container_swap::value>());}
1600
1601 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001602 static void __swap_alloc(allocator_type& __x, allocator_type& __y, true_type)
1603 _NOEXCEPT_(__is_nothrow_swappable<allocator_type>::value)
Howard Hinnante32b5e22010-11-17 17:55:08 +00001604 {
Howard Hinnant0949eed2011-06-30 21:18:19 +00001605 using _VSTD::swap;
Howard Hinnante32b5e22010-11-17 17:55:08 +00001606 swap(__x, __y);
1607 }
1608 _LIBCPP_INLINE_VISIBILITY
Howard Hinnanta6119a82011-05-29 19:57:12 +00001609 static void __swap_alloc(allocator_type& __x, allocator_type& __y, false_type) _NOEXCEPT
Howard Hinnante32b5e22010-11-17 17:55:08 +00001610 {}
1611
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00001612 _LIBCPP_INLINE_VISIBILITY void __invalidate_all_iterators();
1613 _LIBCPP_INLINE_VISIBILITY void __invalidate_iterators_past(size_type);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001614
1615 friend basic_string operator+<>(const basic_string&, const basic_string&);
1616 friend basic_string operator+<>(const value_type*, const basic_string&);
1617 friend basic_string operator+<>(value_type, const basic_string&);
1618 friend basic_string operator+<>(const basic_string&, const value_type*);
1619 friend basic_string operator+<>(const basic_string&, value_type);
1620};
1621
1622template <class _CharT, class _Traits, class _Allocator>
1623#ifndef _LIBCPP_DEBUG
1624_LIBCPP_INLINE_VISIBILITY inline
1625#endif
1626void
1627basic_string<_CharT, _Traits, _Allocator>::__invalidate_all_iterators()
1628{
1629#ifdef _LIBCPP_DEBUG
1630 iterator::__remove_all(this);
1631 const_iterator::__remove_all(this);
Howard Hinnant324bb032010-08-22 00:02:43 +00001632#endif // _LIBCPP_DEBUG
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001633}
1634
1635template <class _CharT, class _Traits, class _Allocator>
1636#ifndef _LIBCPP_DEBUG
1637_LIBCPP_INLINE_VISIBILITY inline
1638#endif
1639void
1640basic_string<_CharT, _Traits, _Allocator>::__invalidate_iterators_past(size_type __pos)
1641{
1642#ifdef _LIBCPP_DEBUG
1643 const_iterator __beg = begin();
1644 if (__iterator_list_.first)
1645 {
1646 for (iterator* __p = __iterator_list_.first; __p;)
1647 {
1648 if (*__p - __beg > static_cast<difference_type>(__pos))
1649 {
1650 iterator* __n = __p;
1651 __p = __p->__next;
1652 __n->__remove_owner();
1653 }
1654 else
1655 __p = __p->__next;
1656 }
1657 }
1658 if (__iterator_list_.second)
1659 {
1660 for (const_iterator* __p = __iterator_list_.second; __p;)
1661 {
1662 if (*__p - __beg > static_cast<difference_type>(__pos))
1663 {
1664 const_iterator* __n = __p;
1665 __p = __p->__next;
1666 __n->__remove_owner();
1667 }
1668 else
1669 __p = __p->__next;
1670 }
1671 }
Howard Hinnant324bb032010-08-22 00:02:43 +00001672#endif // _LIBCPP_DEBUG
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001673}
1674
1675template <class _CharT, class _Traits, class _Allocator>
1676_LIBCPP_INLINE_VISIBILITY inline
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001677basic_string<_CharT, _Traits, _Allocator>::basic_string()
1678 _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001679{
1680 __zero();
1681}
1682
1683template <class _CharT, class _Traits, class _Allocator>
1684_LIBCPP_INLINE_VISIBILITY inline
1685basic_string<_CharT, _Traits, _Allocator>::basic_string(const allocator_type& __a)
1686 : __r_(__a)
1687{
1688 __zero();
1689}
1690
1691template <class _CharT, class _Traits, class _Allocator>
1692void
1693basic_string<_CharT, _Traits, _Allocator>::__init(const_pointer __s, size_type __sz, size_type __reserve)
1694{
1695 if (__reserve > max_size())
1696 this->__throw_length_error();
1697 pointer __p;
1698 if (__reserve < __min_cap)
1699 {
1700 __set_short_size(__sz);
1701 __p = __get_short_pointer();
1702 }
1703 else
1704 {
1705 size_type __cap = __recommend(__reserve);
Howard Hinnante32b5e22010-11-17 17:55:08 +00001706 __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001707 __set_long_pointer(__p);
1708 __set_long_cap(__cap+1);
1709 __set_long_size(__sz);
1710 }
1711 traits_type::copy(__p, __s, __sz);
1712 traits_type::assign(__p[__sz], value_type());
1713}
1714
1715template <class _CharT, class _Traits, class _Allocator>
1716void
1717basic_string<_CharT, _Traits, _Allocator>::__init(const_pointer __s, size_type __sz)
1718{
1719 if (__sz > max_size())
1720 this->__throw_length_error();
1721 pointer __p;
1722 if (__sz < __min_cap)
1723 {
1724 __set_short_size(__sz);
1725 __p = __get_short_pointer();
1726 }
1727 else
1728 {
1729 size_type __cap = __recommend(__sz);
Howard Hinnante32b5e22010-11-17 17:55:08 +00001730 __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001731 __set_long_pointer(__p);
1732 __set_long_cap(__cap+1);
1733 __set_long_size(__sz);
1734 }
1735 traits_type::copy(__p, __s, __sz);
1736 traits_type::assign(__p[__sz], value_type());
1737}
1738
1739template <class _CharT, class _Traits, class _Allocator>
1740_LIBCPP_INLINE_VISIBILITY inline
1741basic_string<_CharT, _Traits, _Allocator>::basic_string(const_pointer __s)
1742{
1743#ifdef _LIBCPP_DEBUG
1744 assert(__s != 0);
1745#endif
1746 __init(__s, traits_type::length(__s));
1747}
1748
1749template <class _CharT, class _Traits, class _Allocator>
1750_LIBCPP_INLINE_VISIBILITY inline
1751basic_string<_CharT, _Traits, _Allocator>::basic_string(const_pointer __s, const allocator_type& __a)
1752 : __r_(__a)
1753{
1754#ifdef _LIBCPP_DEBUG
1755 assert(__s != 0);
1756#endif
1757 __init(__s, traits_type::length(__s));
1758}
1759
1760template <class _CharT, class _Traits, class _Allocator>
1761_LIBCPP_INLINE_VISIBILITY inline
1762basic_string<_CharT, _Traits, _Allocator>::basic_string(const_pointer __s, size_type __n)
1763{
1764#ifdef _LIBCPP_DEBUG
1765 assert(__s != 0);
1766#endif
1767 __init(__s, __n);
1768}
1769
1770template <class _CharT, class _Traits, class _Allocator>
1771_LIBCPP_INLINE_VISIBILITY inline
1772basic_string<_CharT, _Traits, _Allocator>::basic_string(const_pointer __s, size_type __n, const allocator_type& __a)
1773 : __r_(__a)
1774{
1775#ifdef _LIBCPP_DEBUG
1776 assert(__s != 0);
1777#endif
1778 __init(__s, __n);
1779}
1780
1781template <class _CharT, class _Traits, class _Allocator>
1782basic_string<_CharT, _Traits, _Allocator>::basic_string(const basic_string& __str)
Howard Hinnante32b5e22010-11-17 17:55:08 +00001783 : __r_(__alloc_traits::select_on_container_copy_construction(__str.__alloc()))
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001784{
1785 if (!__str.__is_long())
1786 __r_.first().__r = __str.__r_.first().__r;
1787 else
1788 __init(__str.__get_long_pointer(), __str.__get_long_size());
1789}
1790
1791template <class _CharT, class _Traits, class _Allocator>
1792basic_string<_CharT, _Traits, _Allocator>::basic_string(const basic_string& __str, const allocator_type& __a)
1793 : __r_(__a)
1794{
1795 if (!__str.__is_long())
1796 __r_.first().__r = __str.__r_.first().__r;
1797 else
1798 __init(__str.__get_long_pointer(), __str.__get_long_size());
1799}
1800
Howard Hinnant73d21a42010-09-04 23:28:19 +00001801#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001802
1803template <class _CharT, class _Traits, class _Allocator>
1804_LIBCPP_INLINE_VISIBILITY inline
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00001805basic_string<_CharT, _Traits, _Allocator>::basic_string(basic_string&& __str)
1806 _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value)
Howard Hinnant0949eed2011-06-30 21:18:19 +00001807 : __r_(_VSTD::move(__str.__r_))
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001808{
1809 __str.__zero();
1810#ifdef _LIBCPP_DEBUG
1811 __str.__invalidate_all_iterators();
1812#endif
1813}
1814
1815template <class _CharT, class _Traits, class _Allocator>
1816_LIBCPP_INLINE_VISIBILITY inline
1817basic_string<_CharT, _Traits, _Allocator>::basic_string(basic_string&& __str, const allocator_type& __a)
Howard Hinnante32b5e22010-11-17 17:55:08 +00001818 : __r_(__a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001819{
Howard Hinnante32b5e22010-11-17 17:55:08 +00001820 if (__a == __str.__alloc() || !__str.__is_long())
1821 __r_.first().__r = __str.__r_.first().__r;
1822 else
1823 __init(__str.__get_long_pointer(), __str.__get_long_size());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001824 __str.__zero();
1825#ifdef _LIBCPP_DEBUG
1826 __str.__invalidate_all_iterators();
1827#endif
1828}
1829
Howard Hinnant73d21a42010-09-04 23:28:19 +00001830#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001831
1832template <class _CharT, class _Traits, class _Allocator>
1833void
1834basic_string<_CharT, _Traits, _Allocator>::__init(size_type __n, value_type __c)
1835{
1836 if (__n > max_size())
1837 this->__throw_length_error();
1838 pointer __p;
1839 if (__n < __min_cap)
1840 {
1841 __set_short_size(__n);
1842 __p = __get_short_pointer();
1843 }
1844 else
1845 {
1846 size_type __cap = __recommend(__n);
Howard Hinnante32b5e22010-11-17 17:55:08 +00001847 __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001848 __set_long_pointer(__p);
1849 __set_long_cap(__cap+1);
1850 __set_long_size(__n);
1851 }
1852 traits_type::assign(__p, __n, __c);
1853 traits_type::assign(__p[__n], value_type());
1854}
1855
1856template <class _CharT, class _Traits, class _Allocator>
1857_LIBCPP_INLINE_VISIBILITY inline
1858basic_string<_CharT, _Traits, _Allocator>::basic_string(size_type __n, value_type __c)
1859{
1860 __init(__n, __c);
1861}
1862
1863template <class _CharT, class _Traits, class _Allocator>
1864_LIBCPP_INLINE_VISIBILITY inline
1865basic_string<_CharT, _Traits, _Allocator>::basic_string(size_type __n, value_type __c, const allocator_type& __a)
1866 : __r_(__a)
1867{
1868 __init(__n, __c);
1869}
1870
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001871template <class _CharT, class _Traits, class _Allocator>
1872basic_string<_CharT, _Traits, _Allocator>::basic_string(const basic_string& __str, size_type __pos, size_type __n,
1873 const allocator_type& __a)
1874 : __r_(__a)
1875{
1876 size_type __str_sz = __str.size();
1877 if (__pos > __str_sz)
1878 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00001879 __init(__str.data() + __pos, _VSTD::min(__n, __str_sz - __pos));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001880}
1881
1882template <class _CharT, class _Traits, class _Allocator>
1883template <class _InputIterator>
1884typename enable_if
1885<
1886 __is_input_iterator <_InputIterator>::value &&
1887 !__is_forward_iterator<_InputIterator>::value,
1888 void
1889>::type
1890basic_string<_CharT, _Traits, _Allocator>::__init(_InputIterator __first, _InputIterator __last)
1891{
1892 __zero();
1893#ifndef _LIBCPP_NO_EXCEPTIONS
1894 try
1895 {
Howard Hinnant324bb032010-08-22 00:02:43 +00001896#endif // _LIBCPP_NO_EXCEPTIONS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001897 for (; __first != __last; ++__first)
1898 push_back(*__first);
1899#ifndef _LIBCPP_NO_EXCEPTIONS
1900 }
1901 catch (...)
1902 {
1903 if (__is_long())
Howard Hinnante32b5e22010-11-17 17:55:08 +00001904 __alloc_traits::deallocate(__alloc(), __get_long_pointer(), __get_long_cap());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001905 throw;
1906 }
Howard Hinnant324bb032010-08-22 00:02:43 +00001907#endif // _LIBCPP_NO_EXCEPTIONS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001908}
1909
1910template <class _CharT, class _Traits, class _Allocator>
1911template <class _ForwardIterator>
1912typename enable_if
1913<
1914 __is_forward_iterator<_ForwardIterator>::value,
1915 void
1916>::type
1917basic_string<_CharT, _Traits, _Allocator>::__init(_ForwardIterator __first, _ForwardIterator __last)
1918{
Howard Hinnant0949eed2011-06-30 21:18:19 +00001919 size_type __sz = static_cast<size_type>(_VSTD::distance(__first, __last));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001920 if (__sz > max_size())
1921 this->__throw_length_error();
1922 pointer __p;
1923 if (__sz < __min_cap)
1924 {
1925 __set_short_size(__sz);
1926 __p = __get_short_pointer();
1927 }
1928 else
1929 {
1930 size_type __cap = __recommend(__sz);
Howard Hinnante32b5e22010-11-17 17:55:08 +00001931 __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001932 __set_long_pointer(__p);
1933 __set_long_cap(__cap+1);
1934 __set_long_size(__sz);
1935 }
1936 for (; __first != __last; ++__first, ++__p)
1937 traits_type::assign(*__p, *__first);
1938 traits_type::assign(*__p, value_type());
1939}
1940
1941template <class _CharT, class _Traits, class _Allocator>
1942template<class _InputIterator>
1943_LIBCPP_INLINE_VISIBILITY inline
1944basic_string<_CharT, _Traits, _Allocator>::basic_string(_InputIterator __first, _InputIterator __last)
1945{
1946 __init(__first, __last);
1947}
1948
1949template <class _CharT, class _Traits, class _Allocator>
1950template<class _InputIterator>
1951_LIBCPP_INLINE_VISIBILITY inline
1952basic_string<_CharT, _Traits, _Allocator>::basic_string(_InputIterator __first, _InputIterator __last,
1953 const allocator_type& __a)
1954 : __r_(__a)
1955{
1956 __init(__first, __last);
1957}
1958
Howard Hinnante3e32912011-08-12 21:56:02 +00001959#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
1960
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001961template <class _CharT, class _Traits, class _Allocator>
1962_LIBCPP_INLINE_VISIBILITY inline
1963basic_string<_CharT, _Traits, _Allocator>::basic_string(initializer_list<value_type> __il)
1964{
1965 __init(__il.begin(), __il.end());
1966}
1967
1968template <class _CharT, class _Traits, class _Allocator>
1969_LIBCPP_INLINE_VISIBILITY inline
1970basic_string<_CharT, _Traits, _Allocator>::basic_string(initializer_list<value_type> __il, const allocator_type& __a)
1971 : __r_(__a)
1972{
1973 __init(__il.begin(), __il.end());
1974}
1975
Howard Hinnante3e32912011-08-12 21:56:02 +00001976#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
1977
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001978template <class _CharT, class _Traits, class _Allocator>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001979basic_string<_CharT, _Traits, _Allocator>::~basic_string()
1980{
1981 __invalidate_all_iterators();
1982 if (__is_long())
Howard Hinnante32b5e22010-11-17 17:55:08 +00001983 __alloc_traits::deallocate(__alloc(), __get_long_pointer(), __get_long_cap());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001984}
1985
1986template <class _CharT, class _Traits, class _Allocator>
1987void
1988basic_string<_CharT, _Traits, _Allocator>::__grow_by_and_replace
1989 (size_type __old_cap, size_type __delta_cap, size_type __old_sz,
1990 size_type __n_copy, size_type __n_del, size_type __n_add, const_pointer __p_new_stuff)
1991{
1992 size_type __ms = max_size();
1993 if (__delta_cap > __ms - __old_cap - 1)
1994 this->__throw_length_error();
1995 pointer __old_p = __get_pointer();
1996 size_type __cap = __old_cap < __ms / 2 - __alignment ?
Howard Hinnant0949eed2011-06-30 21:18:19 +00001997 __recommend(_VSTD::max(__old_cap + __delta_cap, 2 * __old_cap)) :
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001998 __ms - 1;
Howard Hinnante32b5e22010-11-17 17:55:08 +00001999 pointer __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002000 __invalidate_all_iterators();
2001 if (__n_copy != 0)
2002 traits_type::copy(__p, __old_p, __n_copy);
2003 if (__n_add != 0)
2004 traits_type::copy(__p + __n_copy, __p_new_stuff, __n_add);
2005 size_type __sec_cp_sz = __old_sz - __n_del - __n_copy;
2006 if (__sec_cp_sz != 0)
2007 traits_type::copy(__p + __n_copy + __n_add, __old_p + __n_copy + __n_del, __sec_cp_sz);
2008 if (__old_cap+1 != __min_cap)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002009 __alloc_traits::deallocate(__alloc(), __old_p, __old_cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002010 __set_long_pointer(__p);
2011 __set_long_cap(__cap+1);
2012 __old_sz = __n_copy + __n_add + __sec_cp_sz;
2013 __set_long_size(__old_sz);
2014 traits_type::assign(__p[__old_sz], value_type());
2015}
2016
2017template <class _CharT, class _Traits, class _Allocator>
2018void
2019basic_string<_CharT, _Traits, _Allocator>::__grow_by(size_type __old_cap, size_type __delta_cap, size_type __old_sz,
2020 size_type __n_copy, size_type __n_del, size_type __n_add)
2021{
2022 size_type __ms = max_size();
2023 if (__delta_cap > __ms - __old_cap - 1)
2024 this->__throw_length_error();
2025 pointer __old_p = __get_pointer();
2026 size_type __cap = __old_cap < __ms / 2 - __alignment ?
Howard Hinnant0949eed2011-06-30 21:18:19 +00002027 __recommend(_VSTD::max(__old_cap + __delta_cap, 2 * __old_cap)) :
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002028 __ms - 1;
Howard Hinnante32b5e22010-11-17 17:55:08 +00002029 pointer __p = __alloc_traits::allocate(__alloc(), __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002030 __invalidate_all_iterators();
2031 if (__n_copy != 0)
2032 traits_type::copy(__p, __old_p, __n_copy);
2033 size_type __sec_cp_sz = __old_sz - __n_del - __n_copy;
2034 if (__sec_cp_sz != 0)
2035 traits_type::copy(__p + __n_copy + __n_add, __old_p + __n_copy + __n_del, __sec_cp_sz);
2036 if (__old_cap+1 != __min_cap)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002037 __alloc_traits::deallocate(__alloc(), __old_p, __old_cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002038 __set_long_pointer(__p);
2039 __set_long_cap(__cap+1);
2040}
2041
2042// assign
2043
2044template <class _CharT, class _Traits, class _Allocator>
2045basic_string<_CharT, _Traits, _Allocator>&
2046basic_string<_CharT, _Traits, _Allocator>::assign(const_pointer __s, size_type __n)
2047{
2048#ifdef _LIBCPP_DEBUG
2049 assert(__s != 0);
2050#endif
2051 size_type __cap = capacity();
2052 if (__cap >= __n)
2053 {
2054 pointer __p = __get_pointer();
2055 traits_type::move(__p, __s, __n);
2056 traits_type::assign(__p[__n], value_type());
2057 __set_size(__n);
2058 __invalidate_iterators_past(__n);
2059 }
2060 else
2061 {
2062 size_type __sz = size();
2063 __grow_by_and_replace(__cap, __n - __cap, __sz, 0, __sz, __n, __s);
2064 }
2065 return *this;
2066}
2067
2068template <class _CharT, class _Traits, class _Allocator>
2069basic_string<_CharT, _Traits, _Allocator>&
2070basic_string<_CharT, _Traits, _Allocator>::assign(size_type __n, value_type __c)
2071{
2072 size_type __cap = capacity();
2073 if (__cap < __n)
2074 {
2075 size_type __sz = size();
2076 __grow_by(__cap, __n - __cap, __sz, 0, __sz);
2077 }
2078 else
2079 __invalidate_iterators_past(__n);
2080 pointer __p = __get_pointer();
2081 traits_type::assign(__p, __n, __c);
2082 traits_type::assign(__p[__n], value_type());
2083 __set_size(__n);
2084 return *this;
2085}
2086
2087template <class _CharT, class _Traits, class _Allocator>
2088basic_string<_CharT, _Traits, _Allocator>&
2089basic_string<_CharT, _Traits, _Allocator>::operator=(value_type __c)
2090{
2091 pointer __p;
2092 if (__is_long())
2093 {
2094 __p = __get_long_pointer();
2095 __set_long_size(1);
2096 }
2097 else
2098 {
2099 __p = __get_short_pointer();
2100 __set_short_size(1);
2101 }
2102 traits_type::assign(*__p, __c);
2103 traits_type::assign(*++__p, value_type());
2104 __invalidate_iterators_past(1);
2105 return *this;
2106}
2107
2108template <class _CharT, class _Traits, class _Allocator>
Howard Hinnante32b5e22010-11-17 17:55:08 +00002109basic_string<_CharT, _Traits, _Allocator>&
2110basic_string<_CharT, _Traits, _Allocator>::operator=(const basic_string& __str)
2111{
2112 if (this != &__str)
2113 {
2114 __copy_assign_alloc(__str);
2115 assign(__str);
2116 }
2117 return *this;
2118}
2119
2120#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
2121
2122template <class _CharT, class _Traits, class _Allocator>
2123_LIBCPP_INLINE_VISIBILITY inline
2124void
2125basic_string<_CharT, _Traits, _Allocator>::__move_assign(basic_string& __str, false_type)
2126{
2127 if (__alloc() != __str.__alloc())
2128 assign(__str);
2129 else
2130 __move_assign(__str, true_type());
2131}
2132
2133template <class _CharT, class _Traits, class _Allocator>
2134_LIBCPP_INLINE_VISIBILITY inline
2135void
2136basic_string<_CharT, _Traits, _Allocator>::__move_assign(basic_string& __str, true_type)
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00002137 _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002138{
2139 clear();
2140 shrink_to_fit();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002141 __r_ = _VSTD::move(__str.__r_);
Howard Hinnante32b5e22010-11-17 17:55:08 +00002142 __str.__zero();
2143}
2144
2145template <class _CharT, class _Traits, class _Allocator>
2146_LIBCPP_INLINE_VISIBILITY inline
2147basic_string<_CharT, _Traits, _Allocator>&
2148basic_string<_CharT, _Traits, _Allocator>::operator=(basic_string&& __str)
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00002149 _NOEXCEPT_(__alloc_traits::propagate_on_container_move_assignment::value &&
2150 is_nothrow_move_assignable<allocator_type>::value)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002151{
2152 __move_assign(__str, integral_constant<bool,
2153 __alloc_traits::propagate_on_container_move_assignment::value>());
2154 return *this;
2155}
2156
2157#endif
2158
2159template <class _CharT, class _Traits, class _Allocator>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002160template<class _InputIterator>
2161typename enable_if
2162<
2163 __is_input_iterator <_InputIterator>::value &&
2164 !__is_forward_iterator<_InputIterator>::value,
2165 basic_string<_CharT, _Traits, _Allocator>&
2166>::type
2167basic_string<_CharT, _Traits, _Allocator>::assign(_InputIterator __first, _InputIterator __last)
2168{
2169 clear();
2170 for (; __first != __last; ++__first)
2171 push_back(*__first);
2172}
2173
2174template <class _CharT, class _Traits, class _Allocator>
2175template<class _ForwardIterator>
2176typename enable_if
2177<
2178 __is_forward_iterator<_ForwardIterator>::value,
2179 basic_string<_CharT, _Traits, _Allocator>&
2180>::type
2181basic_string<_CharT, _Traits, _Allocator>::assign(_ForwardIterator __first, _ForwardIterator __last)
2182{
Howard Hinnant0949eed2011-06-30 21:18:19 +00002183 size_type __n = static_cast<size_type>(_VSTD::distance(__first, __last));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002184 size_type __cap = capacity();
2185 if (__cap < __n)
2186 {
2187 size_type __sz = size();
2188 __grow_by(__cap, __n - __cap, __sz, 0, __sz);
2189 }
2190 else
2191 __invalidate_iterators_past(__n);
2192 pointer __p = __get_pointer();
2193 for (; __first != __last; ++__first, ++__p)
2194 traits_type::assign(*__p, *__first);
2195 traits_type::assign(*__p, value_type());
2196 __set_size(__n);
2197 return *this;
2198}
2199
2200template <class _CharT, class _Traits, class _Allocator>
2201_LIBCPP_INLINE_VISIBILITY inline
2202basic_string<_CharT, _Traits, _Allocator>&
2203basic_string<_CharT, _Traits, _Allocator>::assign(const basic_string& __str)
2204{
2205 return assign(__str.data(), __str.size());
2206}
2207
2208template <class _CharT, class _Traits, class _Allocator>
2209basic_string<_CharT, _Traits, _Allocator>&
2210basic_string<_CharT, _Traits, _Allocator>::assign(const basic_string& __str, size_type __pos, size_type __n)
2211{
2212 size_type __sz = __str.size();
2213 if (__pos > __sz)
2214 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002215 return assign(__str.data() + __pos, _VSTD::min(__n, __sz - __pos));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002216}
2217
2218template <class _CharT, class _Traits, class _Allocator>
2219basic_string<_CharT, _Traits, _Allocator>&
2220basic_string<_CharT, _Traits, _Allocator>::assign(const_pointer __s)
2221{
2222#ifdef _LIBCPP_DEBUG
2223 assert(__s != 0);
2224#endif
2225 return assign(__s, traits_type::length(__s));
2226}
2227
2228// append
2229
2230template <class _CharT, class _Traits, class _Allocator>
2231basic_string<_CharT, _Traits, _Allocator>&
2232basic_string<_CharT, _Traits, _Allocator>::append(const_pointer __s, size_type __n)
2233{
2234#ifdef _LIBCPP_DEBUG
2235 assert(__s != 0);
2236#endif
2237 size_type __cap = capacity();
2238 size_type __sz = size();
2239 if (__cap - __sz >= __n)
2240 {
2241 if (__n)
2242 {
2243 pointer __p = __get_pointer();
2244 traits_type::copy(__p + __sz, __s, __n);
2245 __sz += __n;
2246 __set_size(__sz);
2247 traits_type::assign(__p[__sz], value_type());
2248 }
2249 }
2250 else
2251 __grow_by_and_replace(__cap, __sz + __n - __cap, __sz, __sz, 0, __n, __s);
2252 return *this;
2253}
2254
2255template <class _CharT, class _Traits, class _Allocator>
2256basic_string<_CharT, _Traits, _Allocator>&
2257basic_string<_CharT, _Traits, _Allocator>::append(size_type __n, value_type __c)
2258{
2259 if (__n)
2260 {
2261 size_type __cap = capacity();
2262 size_type __sz = size();
2263 if (__cap - __sz < __n)
2264 __grow_by(__cap, __sz + __n - __cap, __sz, __sz, 0);
2265 pointer __p = __get_pointer();
2266 traits_type::assign(__p + __sz, __n, __c);
2267 __sz += __n;
2268 __set_size(__sz);
2269 traits_type::assign(__p[__sz], value_type());
2270 }
2271 return *this;
2272}
2273
2274template <class _CharT, class _Traits, class _Allocator>
2275void
2276basic_string<_CharT, _Traits, _Allocator>::push_back(value_type __c)
2277{
2278 size_type __cap = capacity();
2279 size_type __sz = size();
2280 if (__sz == __cap)
2281 __grow_by(__cap, 1, __sz, __sz, 0);
2282 pointer __p = __get_pointer() + __sz;
2283 traits_type::assign(*__p, __c);
2284 traits_type::assign(*++__p, value_type());
2285 __set_size(__sz+1);
2286}
2287
2288template <class _CharT, class _Traits, class _Allocator>
2289template<class _InputIterator>
2290typename enable_if
2291<
2292 __is_input_iterator <_InputIterator>::value &&
2293 !__is_forward_iterator<_InputIterator>::value,
2294 basic_string<_CharT, _Traits, _Allocator>&
2295>::type
2296basic_string<_CharT, _Traits, _Allocator>::append(_InputIterator __first, _InputIterator __last)
2297{
2298 for (; __first != __last; ++__first)
2299 push_back(*__first);
2300 return *this;
2301}
2302
2303template <class _CharT, class _Traits, class _Allocator>
2304template<class _ForwardIterator>
2305typename enable_if
2306<
2307 __is_forward_iterator<_ForwardIterator>::value,
2308 basic_string<_CharT, _Traits, _Allocator>&
2309>::type
2310basic_string<_CharT, _Traits, _Allocator>::append(_ForwardIterator __first, _ForwardIterator __last)
2311{
2312 size_type __sz = size();
2313 size_type __cap = capacity();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002314 size_type __n = static_cast<size_type>(_VSTD::distance(__first, __last));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002315 if (__n)
2316 {
2317 if (__cap - __sz < __n)
2318 __grow_by(__cap, __sz + __n - __cap, __sz, __sz, 0);
2319 pointer __p = __get_pointer() + __sz;
2320 for (; __first != __last; ++__p, ++__first)
2321 traits_type::assign(*__p, *__first);
2322 traits_type::assign(*__p, value_type());
2323 __set_size(__sz + __n);
2324 }
2325 return *this;
2326}
2327
2328template <class _CharT, class _Traits, class _Allocator>
2329_LIBCPP_INLINE_VISIBILITY inline
2330basic_string<_CharT, _Traits, _Allocator>&
2331basic_string<_CharT, _Traits, _Allocator>::append(const basic_string& __str)
2332{
2333 return append(__str.data(), __str.size());
2334}
2335
2336template <class _CharT, class _Traits, class _Allocator>
2337basic_string<_CharT, _Traits, _Allocator>&
2338basic_string<_CharT, _Traits, _Allocator>::append(const basic_string& __str, size_type __pos, size_type __n)
2339{
2340 size_type __sz = __str.size();
2341 if (__pos > __sz)
2342 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002343 return append(__str.data() + __pos, _VSTD::min(__n, __sz - __pos));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002344}
2345
2346template <class _CharT, class _Traits, class _Allocator>
2347basic_string<_CharT, _Traits, _Allocator>&
2348basic_string<_CharT, _Traits, _Allocator>::append(const_pointer __s)
2349{
2350#ifdef _LIBCPP_DEBUG
2351 assert(__s != 0);
2352#endif
2353 return append(__s, traits_type::length(__s));
2354}
2355
2356// insert
2357
2358template <class _CharT, class _Traits, class _Allocator>
2359basic_string<_CharT, _Traits, _Allocator>&
2360basic_string<_CharT, _Traits, _Allocator>::insert(size_type __pos, const_pointer __s, size_type __n)
2361{
2362#ifdef _LIBCPP_DEBUG
2363 assert(__s != 0);
2364#endif
2365 size_type __sz = size();
2366 if (__pos > __sz)
2367 this->__throw_out_of_range();
2368 size_type __cap = capacity();
2369 if (__cap - __sz >= __n)
2370 {
2371 if (__n)
2372 {
2373 pointer __p = __get_pointer();
2374 size_type __n_move = __sz - __pos;
2375 if (__n_move != 0)
2376 {
2377 if (__p + __pos <= __s && __s < __p + __sz)
2378 __s += __n;
2379 traits_type::move(__p + __pos + __n, __p + __pos, __n_move);
2380 }
2381 traits_type::move(__p + __pos, __s, __n);
2382 __sz += __n;
2383 __set_size(__sz);
2384 traits_type::assign(__p[__sz], value_type());
2385 }
2386 }
2387 else
2388 __grow_by_and_replace(__cap, __sz + __n - __cap, __sz, __pos, 0, __n, __s);
2389 return *this;
2390}
2391
2392template <class _CharT, class _Traits, class _Allocator>
2393basic_string<_CharT, _Traits, _Allocator>&
2394basic_string<_CharT, _Traits, _Allocator>::insert(size_type __pos, size_type __n, value_type __c)
2395{
2396 size_type __sz = size();
2397 if (__pos > __sz)
2398 this->__throw_out_of_range();
2399 if (__n)
2400 {
2401 size_type __cap = capacity();
2402 pointer __p;
2403 if (__cap - __sz >= __n)
2404 {
2405 __p = __get_pointer();
2406 size_type __n_move = __sz - __pos;
2407 if (__n_move != 0)
2408 traits_type::move(__p + __pos + __n, __p + __pos, __n_move);
2409 }
2410 else
2411 {
2412 __grow_by(__cap, __sz + __n - __cap, __sz, __pos, 0, __n);
2413 __p = __get_long_pointer();
2414 }
2415 traits_type::assign(__p + __pos, __n, __c);
2416 __sz += __n;
2417 __set_size(__sz);
2418 traits_type::assign(__p[__sz], value_type());
2419 }
2420 return *this;
2421}
2422
2423template <class _CharT, class _Traits, class _Allocator>
2424template<class _InputIterator>
2425typename enable_if
2426<
2427 __is_input_iterator <_InputIterator>::value &&
2428 !__is_forward_iterator<_InputIterator>::value,
2429 typename basic_string<_CharT, _Traits, _Allocator>::iterator
2430>::type
2431basic_string<_CharT, _Traits, _Allocator>::insert(const_iterator __pos, _InputIterator __first, _InputIterator __last)
2432{
2433 size_type __old_sz = size();
2434 difference_type __ip = __pos - begin();
2435 for (; __first != __last; ++__first)
2436 push_back(*__first);
2437 pointer __p = __get_pointer();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002438 _VSTD::rotate(__p + __ip, __p + __old_sz, __p + size());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002439 return iterator(__p + __ip);
2440}
2441
2442template <class _CharT, class _Traits, class _Allocator>
2443template<class _ForwardIterator>
2444typename enable_if
2445<
2446 __is_forward_iterator<_ForwardIterator>::value,
2447 typename basic_string<_CharT, _Traits, _Allocator>::iterator
2448>::type
2449basic_string<_CharT, _Traits, _Allocator>::insert(const_iterator __pos, _ForwardIterator __first, _ForwardIterator __last)
2450{
2451 size_type __ip = static_cast<size_type>(__pos - begin());
2452 size_type __sz = size();
2453 size_type __cap = capacity();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002454 size_type __n = static_cast<size_type>(_VSTD::distance(__first, __last));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002455 if (__n)
2456 {
2457 pointer __p;
2458 if (__cap - __sz >= __n)
2459 {
2460 __p = __get_pointer();
2461 size_type __n_move = __sz - __ip;
2462 if (__n_move != 0)
2463 traits_type::move(__p + __ip + __n, __p + __ip, __n_move);
2464 }
2465 else
2466 {
2467 __grow_by(__cap, __sz + __n - __cap, __sz, __ip, 0, __n);
2468 __p = __get_long_pointer();
2469 }
2470 __sz += __n;
2471 __set_size(__sz);
2472 traits_type::assign(__p[__sz], value_type());
2473 for (__p += __ip; __first != __last; ++__p, ++__first)
2474 traits_type::assign(*__p, *__first);
2475 }
2476 return begin() + __ip;
2477}
2478
2479template <class _CharT, class _Traits, class _Allocator>
2480_LIBCPP_INLINE_VISIBILITY inline
2481basic_string<_CharT, _Traits, _Allocator>&
2482basic_string<_CharT, _Traits, _Allocator>::insert(size_type __pos1, const basic_string& __str)
2483{
2484 return insert(__pos1, __str.data(), __str.size());
2485}
2486
2487template <class _CharT, class _Traits, class _Allocator>
2488basic_string<_CharT, _Traits, _Allocator>&
2489basic_string<_CharT, _Traits, _Allocator>::insert(size_type __pos1, const basic_string& __str,
2490 size_type __pos2, size_type __n)
2491{
2492 size_type __str_sz = __str.size();
2493 if (__pos2 > __str_sz)
2494 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002495 return insert(__pos1, __str.data() + __pos2, _VSTD::min(__n, __str_sz - __pos2));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002496}
2497
2498template <class _CharT, class _Traits, class _Allocator>
2499basic_string<_CharT, _Traits, _Allocator>&
2500basic_string<_CharT, _Traits, _Allocator>::insert(size_type __pos, const_pointer __s)
2501{
2502#ifdef _LIBCPP_DEBUG
2503 assert(__s != 0);
2504#endif
2505 return insert(__pos, __s, traits_type::length(__s));
2506}
2507
2508template <class _CharT, class _Traits, class _Allocator>
2509typename basic_string<_CharT, _Traits, _Allocator>::iterator
2510basic_string<_CharT, _Traits, _Allocator>::insert(const_iterator __pos, value_type __c)
2511{
2512 size_type __ip = static_cast<size_type>(__pos - begin());
2513 size_type __sz = size();
2514 size_type __cap = capacity();
2515 pointer __p;
2516 if (__cap == __sz)
2517 {
2518 __grow_by(__cap, 1, __sz, __ip, 0, 1);
2519 __p = __get_long_pointer();
2520 }
2521 else
2522 {
2523 __p = __get_pointer();
2524 size_type __n_move = __sz - __ip;
2525 if (__n_move != 0)
2526 traits_type::move(__p + __ip + 1, __p + __ip, __n_move);
2527 }
2528 traits_type::assign(__p[__ip], __c);
2529 traits_type::assign(__p[++__sz], value_type());
2530 __set_size(__sz);
2531 return begin() + static_cast<difference_type>(__ip);
2532}
2533
2534template <class _CharT, class _Traits, class _Allocator>
2535_LIBCPP_INLINE_VISIBILITY inline
2536typename basic_string<_CharT, _Traits, _Allocator>::iterator
2537basic_string<_CharT, _Traits, _Allocator>::insert(const_iterator __pos, size_type __n, value_type __c)
2538{
2539 difference_type __p = __pos - begin();
2540 insert(static_cast<size_type>(__p), __n, __c);
2541 return begin() + __p;
2542}
2543
2544// replace
2545
2546template <class _CharT, class _Traits, class _Allocator>
2547basic_string<_CharT, _Traits, _Allocator>&
2548basic_string<_CharT, _Traits, _Allocator>::replace(size_type __pos, size_type __n1, const_pointer __s, size_type __n2)
2549{
2550#ifdef _LIBCPP_DEBUG
2551 assert(__s != 0);
2552#endif
2553 size_type __sz = size();
2554 if (__pos > __sz)
2555 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002556 __n1 = _VSTD::min(__n1, __sz - __pos);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002557 size_type __cap = capacity();
2558 if (__cap - __sz + __n1 >= __n2)
2559 {
2560 pointer __p = __get_pointer();
2561 if (__n1 != __n2)
2562 {
2563 size_type __n_move = __sz - __pos - __n1;
2564 if (__n_move != 0)
2565 {
2566 if (__n1 > __n2)
2567 {
2568 traits_type::move(__p + __pos, __s, __n2);
2569 traits_type::move(__p + __pos + __n2, __p + __pos + __n1, __n_move);
2570 goto __finish;
2571 }
2572 if (__p + __pos < __s && __s < __p + __sz)
2573 {
2574 if (__p + __pos + __n1 <= __s)
2575 __s += __n2 - __n1;
2576 else // __p + __pos < __s < __p + __pos + __n1
2577 {
2578 traits_type::move(__p + __pos, __s, __n1);
2579 __pos += __n1;
2580 __s += __n2;
2581 __n2 -= __n1;
2582 __n1 = 0;
2583 }
2584 }
2585 traits_type::move(__p + __pos + __n2, __p + __pos + __n1, __n_move);
2586 }
2587 }
2588 traits_type::move(__p + __pos, __s, __n2);
2589__finish:
2590 __sz += __n2 - __n1;
2591 __set_size(__sz);
2592 __invalidate_iterators_past(__sz);
2593 traits_type::assign(__p[__sz], value_type());
2594 }
2595 else
2596 __grow_by_and_replace(__cap, __sz - __n1 + __n2 - __cap, __sz, __pos, __n1, __n2, __s);
2597 return *this;
2598}
2599
2600template <class _CharT, class _Traits, class _Allocator>
2601basic_string<_CharT, _Traits, _Allocator>&
2602basic_string<_CharT, _Traits, _Allocator>::replace(size_type __pos, size_type __n1, size_type __n2, value_type __c)
2603{
2604 size_type __sz = size();
2605 if (__pos > __sz)
2606 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002607 __n1 = _VSTD::min(__n1, __sz - __pos);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002608 size_type __cap = capacity();
2609 pointer __p;
2610 if (__cap - __sz + __n1 >= __n2)
2611 {
2612 __p = __get_pointer();
2613 if (__n1 != __n2)
2614 {
2615 size_type __n_move = __sz - __pos - __n1;
2616 if (__n_move != 0)
2617 traits_type::move(__p + __pos + __n2, __p + __pos + __n1, __n_move);
2618 }
2619 }
2620 else
2621 {
2622 __grow_by(__cap, __sz - __n1 + __n2 - __cap, __sz, __pos, __n1, __n2);
2623 __p = __get_long_pointer();
2624 }
2625 traits_type::assign(__p + __pos, __n2, __c);
2626 __sz += __n2 - __n1;
2627 __set_size(__sz);
2628 __invalidate_iterators_past(__sz);
2629 traits_type::assign(__p[__sz], value_type());
2630 return *this;
2631}
2632
2633template <class _CharT, class _Traits, class _Allocator>
2634template<class _InputIterator>
2635typename enable_if
2636<
2637 __is_input_iterator<_InputIterator>::value,
2638 basic_string<_CharT, _Traits, _Allocator>&
2639>::type
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002640basic_string<_CharT, _Traits, _Allocator>::replace(const_iterator __i1, const_iterator __i2,
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002641 _InputIterator __j1, _InputIterator __j2)
2642{
2643 for (; true; ++__i1, ++__j1)
2644 {
2645 if (__i1 == __i2)
2646 {
2647 if (__j1 != __j2)
2648 insert(__i1, __j1, __j2);
2649 break;
2650 }
2651 if (__j1 == __j2)
2652 {
2653 erase(__i1, __i2);
2654 break;
2655 }
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002656 traits_type::assign(const_cast<value_type&>(*__i1), *__j1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002657 }
2658 return *this;
2659}
2660
2661template <class _CharT, class _Traits, class _Allocator>
2662_LIBCPP_INLINE_VISIBILITY inline
2663basic_string<_CharT, _Traits, _Allocator>&
2664basic_string<_CharT, _Traits, _Allocator>::replace(size_type __pos1, size_type __n1, const basic_string& __str)
2665{
2666 return replace(__pos1, __n1, __str.data(), __str.size());
2667}
2668
2669template <class _CharT, class _Traits, class _Allocator>
2670basic_string<_CharT, _Traits, _Allocator>&
2671basic_string<_CharT, _Traits, _Allocator>::replace(size_type __pos1, size_type __n1, const basic_string& __str,
2672 size_type __pos2, size_type __n2)
2673{
2674 size_type __str_sz = __str.size();
2675 if (__pos2 > __str_sz)
2676 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002677 return replace(__pos1, __n1, __str.data() + __pos2, _VSTD::min(__n2, __str_sz - __pos2));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002678}
2679
2680template <class _CharT, class _Traits, class _Allocator>
2681basic_string<_CharT, _Traits, _Allocator>&
2682basic_string<_CharT, _Traits, _Allocator>::replace(size_type __pos, size_type __n1, const_pointer __s)
2683{
2684#ifdef _LIBCPP_DEBUG
2685 assert(__s != 0);
2686#endif
2687 return replace(__pos, __n1, __s, traits_type::length(__s));
2688}
2689
2690template <class _CharT, class _Traits, class _Allocator>
2691_LIBCPP_INLINE_VISIBILITY inline
2692basic_string<_CharT, _Traits, _Allocator>&
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002693basic_string<_CharT, _Traits, _Allocator>::replace(const_iterator __i1, const_iterator __i2, const basic_string& __str)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002694{
2695 return replace(static_cast<size_type>(__i1 - begin()), static_cast<size_type>(__i2 - __i1),
2696 __str.data(), __str.size());
2697}
2698
2699template <class _CharT, class _Traits, class _Allocator>
2700_LIBCPP_INLINE_VISIBILITY inline
2701basic_string<_CharT, _Traits, _Allocator>&
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002702basic_string<_CharT, _Traits, _Allocator>::replace(const_iterator __i1, const_iterator __i2, const_pointer __s, size_type __n)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002703{
2704 return replace(static_cast<size_type>(__i1 - begin()), static_cast<size_type>(__i2 - __i1), __s, __n);
2705}
2706
2707template <class _CharT, class _Traits, class _Allocator>
2708_LIBCPP_INLINE_VISIBILITY inline
2709basic_string<_CharT, _Traits, _Allocator>&
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002710basic_string<_CharT, _Traits, _Allocator>::replace(const_iterator __i1, const_iterator __i2, const_pointer __s)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002711{
2712 return replace(static_cast<size_type>(__i1 - begin()), static_cast<size_type>(__i2 - __i1), __s);
2713}
2714
2715template <class _CharT, class _Traits, class _Allocator>
2716_LIBCPP_INLINE_VISIBILITY inline
2717basic_string<_CharT, _Traits, _Allocator>&
Howard Hinnant7b2cb482010-11-17 21:11:40 +00002718basic_string<_CharT, _Traits, _Allocator>::replace(const_iterator __i1, const_iterator __i2, size_type __n, value_type __c)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002719{
2720 return replace(static_cast<size_type>(__i1 - begin()), static_cast<size_type>(__i2 - __i1), __n, __c);
2721}
2722
2723// erase
2724
2725template <class _CharT, class _Traits, class _Allocator>
2726basic_string<_CharT, _Traits, _Allocator>&
2727basic_string<_CharT, _Traits, _Allocator>::erase(size_type __pos, size_type __n)
2728{
2729 size_type __sz = size();
2730 if (__pos > __sz)
2731 this->__throw_out_of_range();
2732 if (__n)
2733 {
2734 pointer __p = __get_pointer();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002735 __n = _VSTD::min(__n, __sz - __pos);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002736 size_type __n_move = __sz - __pos - __n;
2737 if (__n_move != 0)
2738 traits_type::move(__p + __pos, __p + __pos + __n, __n_move);
2739 __sz -= __n;
2740 __set_size(__sz);
2741 __invalidate_iterators_past(__sz);
2742 traits_type::assign(__p[__sz], value_type());
2743 }
2744 return *this;
2745}
2746
2747template <class _CharT, class _Traits, class _Allocator>
2748_LIBCPP_INLINE_VISIBILITY inline
2749typename basic_string<_CharT, _Traits, _Allocator>::iterator
2750basic_string<_CharT, _Traits, _Allocator>::erase(const_iterator __pos)
2751{
2752 iterator __b = begin();
2753 size_type __r = static_cast<size_type>(__pos - __b);
2754 erase(__r, 1);
2755 return __b + __r;
2756}
2757
2758template <class _CharT, class _Traits, class _Allocator>
2759_LIBCPP_INLINE_VISIBILITY inline
2760typename basic_string<_CharT, _Traits, _Allocator>::iterator
2761basic_string<_CharT, _Traits, _Allocator>::erase(const_iterator __first, const_iterator __last)
2762{
2763 iterator __b = begin();
2764 size_type __r = static_cast<size_type>(__first - __b);
2765 erase(__r, static_cast<size_type>(__last - __first));
2766 return __b + __r;
2767}
2768
2769template <class _CharT, class _Traits, class _Allocator>
2770_LIBCPP_INLINE_VISIBILITY inline
2771void
2772basic_string<_CharT, _Traits, _Allocator>::pop_back()
2773{
2774#ifdef _LIBCPP_DEBUG
2775 assert(!empty());
2776#endif
2777 size_type __sz;
2778 if (__is_long())
2779 {
2780 __sz = __get_long_size() - 1;
2781 __set_long_size(__sz);
2782 traits_type::assign(*(__get_long_pointer() + __sz), value_type());
2783 }
2784 else
2785 {
2786 __sz = __get_short_size() - 1;
2787 __set_short_size(__sz);
2788 traits_type::assign(*(__get_short_pointer() + __sz), value_type());
2789 }
2790 __invalidate_iterators_past(__sz);
2791}
2792
2793template <class _CharT, class _Traits, class _Allocator>
2794_LIBCPP_INLINE_VISIBILITY inline
2795void
Howard Hinnanta6119a82011-05-29 19:57:12 +00002796basic_string<_CharT, _Traits, _Allocator>::clear() _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002797{
2798 __invalidate_all_iterators();
2799 if (__is_long())
2800 {
2801 traits_type::assign(*__get_long_pointer(), value_type());
2802 __set_long_size(0);
2803 }
2804 else
2805 {
2806 traits_type::assign(*__get_short_pointer(), value_type());
2807 __set_short_size(0);
2808 }
2809}
2810
2811template <class _CharT, class _Traits, class _Allocator>
2812_LIBCPP_INLINE_VISIBILITY inline
2813void
2814basic_string<_CharT, _Traits, _Allocator>::__erase_to_end(size_type __pos)
2815{
2816 if (__is_long())
2817 {
2818 traits_type::assign(*(__get_long_pointer() + __pos), value_type());
2819 __set_long_size(__pos);
2820 }
2821 else
2822 {
2823 traits_type::assign(*(__get_short_pointer() + __pos), value_type());
2824 __set_short_size(__pos);
2825 }
2826 __invalidate_iterators_past(__pos);
2827}
2828
2829template <class _CharT, class _Traits, class _Allocator>
2830void
2831basic_string<_CharT, _Traits, _Allocator>::resize(size_type __n, value_type __c)
2832{
2833 size_type __sz = size();
2834 if (__n > __sz)
2835 append(__n - __sz, __c);
2836 else
2837 __erase_to_end(__n);
2838}
2839
2840template <class _CharT, class _Traits, class _Allocator>
2841_LIBCPP_INLINE_VISIBILITY inline
2842typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00002843basic_string<_CharT, _Traits, _Allocator>::max_size() const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002844{
Howard Hinnante32b5e22010-11-17 17:55:08 +00002845 size_type __m = __alloc_traits::max_size(__alloc());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002846#if _LIBCPP_BIG_ENDIAN
2847 return (__m <= ~__long_mask ? __m : __m/2) - 1;
2848#else
2849 return __m - 1;
2850#endif
2851}
2852
2853template <class _CharT, class _Traits, class _Allocator>
2854void
2855basic_string<_CharT, _Traits, _Allocator>::reserve(size_type __res_arg)
2856{
2857 if (__res_arg > max_size())
2858 this->__throw_length_error();
2859 size_type __cap = capacity();
2860 size_type __sz = size();
Howard Hinnant0949eed2011-06-30 21:18:19 +00002861 __res_arg = _VSTD::max(__res_arg, __sz);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002862 __res_arg = __recommend(__res_arg);
2863 if (__res_arg != __cap)
2864 {
2865 pointer __new_data, __p;
2866 bool __was_long, __now_long;
2867 if (__res_arg == __min_cap - 1)
2868 {
2869 __was_long = true;
2870 __now_long = false;
2871 __new_data = __get_short_pointer();
2872 __p = __get_long_pointer();
2873 }
2874 else
2875 {
2876 if (__res_arg > __cap)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002877 __new_data = __alloc_traits::allocate(__alloc(), __res_arg+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002878 else
2879 {
2880 #ifndef _LIBCPP_NO_EXCEPTIONS
2881 try
2882 {
Howard Hinnant324bb032010-08-22 00:02:43 +00002883 #endif // _LIBCPP_NO_EXCEPTIONS
Howard Hinnante32b5e22010-11-17 17:55:08 +00002884 __new_data = __alloc_traits::allocate(__alloc(), __res_arg+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002885 #ifndef _LIBCPP_NO_EXCEPTIONS
2886 }
2887 catch (...)
2888 {
2889 return;
2890 }
Howard Hinnant324bb032010-08-22 00:02:43 +00002891 #else // _LIBCPP_NO_EXCEPTIONS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002892 if (__new_data == 0)
2893 return;
Howard Hinnant324bb032010-08-22 00:02:43 +00002894 #endif // _LIBCPP_NO_EXCEPTIONS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002895 }
2896 __now_long = true;
2897 __was_long = __is_long();
2898 __p = __get_pointer();
2899 }
2900 traits_type::copy(__new_data, __p, size()+1);
2901 if (__was_long)
Howard Hinnante32b5e22010-11-17 17:55:08 +00002902 __alloc_traits::deallocate(__alloc(), __p, __cap+1);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00002903 if (__now_long)
2904 {
2905 __set_long_cap(__res_arg+1);
2906 __set_long_size(__sz);
2907 __set_long_pointer(__new_data);
2908 }
2909 else
2910 __set_short_size(__sz);
2911 __invalidate_all_iterators();
2912 }
2913}
2914
2915template <class _CharT, class _Traits, class _Allocator>
2916_LIBCPP_INLINE_VISIBILITY inline
2917typename basic_string<_CharT, _Traits, _Allocator>::const_reference
2918basic_string<_CharT, _Traits, _Allocator>::operator[](size_type __pos) const
2919{
2920#ifdef __LIBCPP_DEBUG
2921 assert(__pos <= size());
2922#endif
2923 return *(data() + __pos);
2924}
2925
2926template <class _CharT, class _Traits, class _Allocator>
2927_LIBCPP_INLINE_VISIBILITY inline
2928typename basic_string<_CharT, _Traits, _Allocator>::reference
2929basic_string<_CharT, _Traits, _Allocator>::operator[](size_type __pos)
2930{
2931#ifdef __LIBCPP_DEBUG
2932 assert(__pos < size());
2933#endif
2934 return *(__get_pointer() + __pos);
2935}
2936
2937template <class _CharT, class _Traits, class _Allocator>
2938typename basic_string<_CharT, _Traits, _Allocator>::const_reference
2939basic_string<_CharT, _Traits, _Allocator>::at(size_type __n) const
2940{
2941 if (__n >= size())
2942 this->__throw_out_of_range();
2943 return (*this)[__n];
2944}
2945
2946template <class _CharT, class _Traits, class _Allocator>
2947typename basic_string<_CharT, _Traits, _Allocator>::reference
2948basic_string<_CharT, _Traits, _Allocator>::at(size_type __n)
2949{
2950 if (__n >= size())
2951 this->__throw_out_of_range();
2952 return (*this)[__n];
2953}
2954
2955template <class _CharT, class _Traits, class _Allocator>
2956_LIBCPP_INLINE_VISIBILITY inline
2957typename basic_string<_CharT, _Traits, _Allocator>::reference
2958basic_string<_CharT, _Traits, _Allocator>::front()
2959{
2960#ifdef _LIBCPP_DEBUG
2961 assert(!empty());
2962#endif
2963 return *__get_pointer();
2964}
2965
2966template <class _CharT, class _Traits, class _Allocator>
2967_LIBCPP_INLINE_VISIBILITY inline
2968typename basic_string<_CharT, _Traits, _Allocator>::const_reference
2969basic_string<_CharT, _Traits, _Allocator>::front() const
2970{
2971#ifdef _LIBCPP_DEBUG
2972 assert(!empty());
2973#endif
2974 return *data();
2975}
2976
2977template <class _CharT, class _Traits, class _Allocator>
2978_LIBCPP_INLINE_VISIBILITY inline
2979typename basic_string<_CharT, _Traits, _Allocator>::reference
2980basic_string<_CharT, _Traits, _Allocator>::back()
2981{
2982#ifdef _LIBCPP_DEBUG
2983 assert(!empty());
2984#endif
2985 return *(__get_pointer() + size() - 1);
2986}
2987
2988template <class _CharT, class _Traits, class _Allocator>
2989_LIBCPP_INLINE_VISIBILITY inline
2990typename basic_string<_CharT, _Traits, _Allocator>::const_reference
2991basic_string<_CharT, _Traits, _Allocator>::back() const
2992{
2993#ifdef _LIBCPP_DEBUG
2994 assert(!empty());
2995#endif
2996 return *(data() + size() - 1);
2997}
2998
2999template <class _CharT, class _Traits, class _Allocator>
3000typename basic_string<_CharT, _Traits, _Allocator>::size_type
3001basic_string<_CharT, _Traits, _Allocator>::copy(pointer __s, size_type __n, size_type __pos) const
3002{
3003 size_type __sz = size();
3004 if (__pos > __sz)
3005 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003006 size_type __rlen = _VSTD::min(__n, __sz - __pos);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003007 traits_type::copy(__s, data() + __pos, __rlen);
3008 return __rlen;
3009}
3010
3011template <class _CharT, class _Traits, class _Allocator>
3012_LIBCPP_INLINE_VISIBILITY inline
3013basic_string<_CharT, _Traits, _Allocator>
3014basic_string<_CharT, _Traits, _Allocator>::substr(size_type __pos, size_type __n) const
3015{
3016 return basic_string(*this, __pos, __n, __alloc());
3017}
3018
3019template <class _CharT, class _Traits, class _Allocator>
3020_LIBCPP_INLINE_VISIBILITY inline
3021void
3022basic_string<_CharT, _Traits, _Allocator>::swap(basic_string& __str)
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00003023 _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value ||
3024 __is_nothrow_swappable<allocator_type>::value)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003025{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003026 _VSTD::swap(__r_.first(), __str.__r_.first());
Howard Hinnante32b5e22010-11-17 17:55:08 +00003027 __swap_alloc(__alloc(), __str.__alloc());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003028#ifdef _LIBCPP_DEBUG
3029 __invalidate_all_iterators();
3030 __str.__invalidate_all_iterators();
Howard Hinnant324bb032010-08-22 00:02:43 +00003031#endif // _LIBCPP_DEBUG
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003032}
3033
3034// find
3035
3036template <class _Traits>
3037struct _LIBCPP_HIDDEN __traits_eq
3038{
3039 typedef typename _Traits::char_type char_type;
Howard Hinnanta6119a82011-05-29 19:57:12 +00003040 _LIBCPP_INLINE_VISIBILITY
3041 bool operator()(const char_type& __x, const char_type& __y) _NOEXCEPT
3042 {return _Traits::eq(__x, __y);}
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003043};
3044
3045template<class _CharT, class _Traits, class _Allocator>
3046typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003047basic_string<_CharT, _Traits, _Allocator>::find(const_pointer __s,
3048 size_type __pos,
3049 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003050{
3051#ifdef _LIBCPP_DEBUG
3052 assert(__s != 0);
3053#endif
3054 size_type __sz = size();
3055 if (__pos > __sz || __sz - __pos < __n)
3056 return npos;
3057 if (__n == 0)
3058 return __pos;
3059 const_pointer __p = data();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003060 const_pointer __r = _VSTD::search(__p + __pos, __p + __sz, __s, __s + __n,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003061 __traits_eq<traits_type>());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003062 if (__r == __p + __sz)
3063 return npos;
3064 return static_cast<size_type>(__r - __p);
3065}
3066
3067template<class _CharT, class _Traits, class _Allocator>
3068_LIBCPP_INLINE_VISIBILITY inline
3069typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003070basic_string<_CharT, _Traits, _Allocator>::find(const basic_string& __str,
3071 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003072{
3073 return find(__str.data(), __pos, __str.size());
3074}
3075
3076template<class _CharT, class _Traits, class _Allocator>
3077_LIBCPP_INLINE_VISIBILITY inline
3078typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003079basic_string<_CharT, _Traits, _Allocator>::find(const_pointer __s,
3080 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003081{
3082#ifdef _LIBCPP_DEBUG
3083 assert(__s != 0);
3084#endif
3085 return find(__s, __pos, traits_type::length(__s));
3086}
3087
3088template<class _CharT, class _Traits, class _Allocator>
3089typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003090basic_string<_CharT, _Traits, _Allocator>::find(value_type __c,
3091 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003092{
3093 size_type __sz = size();
3094 if (__pos >= __sz)
3095 return npos;
3096 const_pointer __p = data();
3097 const_pointer __r = traits_type::find(__p + __pos, __sz - __pos, __c);
3098 if (__r == 0)
3099 return npos;
3100 return static_cast<size_type>(__r - __p);
3101}
3102
3103// rfind
3104
3105template<class _CharT, class _Traits, class _Allocator>
3106typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003107basic_string<_CharT, _Traits, _Allocator>::rfind(const_pointer __s,
3108 size_type __pos,
3109 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003110{
3111#ifdef _LIBCPP_DEBUG
3112 assert(__s != 0);
3113#endif
3114 size_type __sz = size();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003115 __pos = _VSTD::min(__pos, __sz);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003116 if (__n < __sz - __pos)
3117 __pos += __n;
3118 else
3119 __pos = __sz;
3120 const_pointer __p = data();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003121 const_pointer __r = _VSTD::find_end(__p, __p + __pos, __s, __s + __n,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003122 __traits_eq<traits_type>());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003123 if (__n > 0 && __r == __p + __pos)
3124 return npos;
3125 return static_cast<size_type>(__r - __p);
3126}
3127
3128template<class _CharT, class _Traits, class _Allocator>
3129_LIBCPP_INLINE_VISIBILITY inline
3130typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003131basic_string<_CharT, _Traits, _Allocator>::rfind(const basic_string& __str,
3132 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003133{
3134 return rfind(__str.data(), __pos, __str.size());
3135}
3136
3137template<class _CharT, class _Traits, class _Allocator>
3138_LIBCPP_INLINE_VISIBILITY inline
3139typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003140basic_string<_CharT, _Traits, _Allocator>::rfind(const_pointer __s,
3141 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003142{
3143#ifdef _LIBCPP_DEBUG
3144 assert(__s != 0);
3145#endif
3146 return rfind(__s, __pos, traits_type::length(__s));
3147}
3148
3149template<class _CharT, class _Traits, class _Allocator>
3150typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003151basic_string<_CharT, _Traits, _Allocator>::rfind(value_type __c,
3152 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003153{
3154 size_type __sz = size();
3155 if (__sz)
3156 {
3157 if (__pos < __sz)
3158 ++__pos;
3159 else
3160 __pos = __sz;
3161 const_pointer __p = data();
3162 for (const_pointer __ps = __p + __pos; __ps != __p;)
3163 {
3164 if (traits_type::eq(*--__ps, __c))
3165 return static_cast<size_type>(__ps - __p);
3166 }
3167 }
3168 return npos;
3169}
3170
3171// find_first_of
3172
3173template<class _CharT, class _Traits, class _Allocator>
3174typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003175basic_string<_CharT, _Traits, _Allocator>::find_first_of(const_pointer __s,
3176 size_type __pos,
3177 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003178{
3179#ifdef _LIBCPP_DEBUG
3180 assert(__s != 0);
3181#endif
3182 size_type __sz = size();
3183 if (__pos >= __sz || __n == 0)
3184 return npos;
3185 const_pointer __p = data();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003186 const_pointer __r = _VSTD::find_first_of(__p + __pos, __p + __sz, __s,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003187 __s + __n, __traits_eq<traits_type>());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003188 if (__r == __p + __sz)
3189 return npos;
3190 return static_cast<size_type>(__r - __p);
3191}
3192
3193template<class _CharT, class _Traits, class _Allocator>
3194_LIBCPP_INLINE_VISIBILITY inline
3195typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003196basic_string<_CharT, _Traits, _Allocator>::find_first_of(const basic_string& __str,
3197 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003198{
3199 return find_first_of(__str.data(), __pos, __str.size());
3200}
3201
3202template<class _CharT, class _Traits, class _Allocator>
3203_LIBCPP_INLINE_VISIBILITY inline
3204typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003205basic_string<_CharT, _Traits, _Allocator>::find_first_of(const_pointer __s,
3206 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003207{
3208#ifdef _LIBCPP_DEBUG
3209 assert(__s != 0);
3210#endif
3211 return find_first_of(__s, __pos, traits_type::length(__s));
3212}
3213
3214template<class _CharT, class _Traits, class _Allocator>
3215_LIBCPP_INLINE_VISIBILITY inline
3216typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003217basic_string<_CharT, _Traits, _Allocator>::find_first_of(value_type __c,
3218 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003219{
3220 return find(__c, __pos);
3221}
3222
3223// find_last_of
3224
3225template<class _CharT, class _Traits, class _Allocator>
3226typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003227basic_string<_CharT, _Traits, _Allocator>::find_last_of(const_pointer __s,
3228 size_type __pos,
3229 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003230{
3231#ifdef _LIBCPP_DEBUG
3232 assert(__s != 0);
3233#endif
3234 if (__n != 0)
3235 {
3236 size_type __sz = size();
3237 if (__pos < __sz)
3238 ++__pos;
3239 else
3240 __pos = __sz;
3241 const_pointer __p = data();
3242 for (const_pointer __ps = __p + __pos; __ps != __p;)
3243 {
3244 const_pointer __r = traits_type::find(__s, __n, *--__ps);
3245 if (__r)
3246 return static_cast<size_type>(__ps - __p);
3247 }
3248 }
3249 return npos;
3250}
3251
3252template<class _CharT, class _Traits, class _Allocator>
3253_LIBCPP_INLINE_VISIBILITY inline
3254typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003255basic_string<_CharT, _Traits, _Allocator>::find_last_of(const basic_string& __str,
3256 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003257{
3258 return find_last_of(__str.data(), __pos, __str.size());
3259}
3260
3261template<class _CharT, class _Traits, class _Allocator>
3262_LIBCPP_INLINE_VISIBILITY inline
3263typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003264basic_string<_CharT, _Traits, _Allocator>::find_last_of(const_pointer __s,
3265 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003266{
3267#ifdef _LIBCPP_DEBUG
3268 assert(__s != 0);
3269#endif
3270 return find_last_of(__s, __pos, traits_type::length(__s));
3271}
3272
3273template<class _CharT, class _Traits, class _Allocator>
3274_LIBCPP_INLINE_VISIBILITY inline
3275typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003276basic_string<_CharT, _Traits, _Allocator>::find_last_of(value_type __c,
3277 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003278{
3279 return rfind(__c, __pos);
3280}
3281
3282// find_first_not_of
3283
3284template<class _CharT, class _Traits, class _Allocator>
3285typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003286basic_string<_CharT, _Traits, _Allocator>::find_first_not_of(const_pointer __s,
3287 size_type __pos,
3288 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003289{
3290#ifdef _LIBCPP_DEBUG
3291 assert(__s != 0);
3292#endif
3293 size_type __sz = size();
3294 if (__pos < __sz)
3295 {
3296 const_pointer __p = data();
3297 const_pointer __pe = __p + __sz;
3298 for (const_pointer __ps = __p + __pos; __ps != __pe; ++__ps)
3299 if (traits_type::find(__s, __n, *__ps) == 0)
3300 return static_cast<size_type>(__ps - __p);
3301 }
3302 return npos;
3303}
3304
3305template<class _CharT, class _Traits, class _Allocator>
3306_LIBCPP_INLINE_VISIBILITY inline
3307typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003308basic_string<_CharT, _Traits, _Allocator>::find_first_not_of(const basic_string& __str,
3309 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003310{
3311 return find_first_not_of(__str.data(), __pos, __str.size());
3312}
3313
3314template<class _CharT, class _Traits, class _Allocator>
3315_LIBCPP_INLINE_VISIBILITY inline
3316typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003317basic_string<_CharT, _Traits, _Allocator>::find_first_not_of(const_pointer __s,
3318 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003319{
3320#ifdef _LIBCPP_DEBUG
3321 assert(__s != 0);
3322#endif
3323 return find_first_not_of(__s, __pos, traits_type::length(__s));
3324}
3325
3326template<class _CharT, class _Traits, class _Allocator>
3327_LIBCPP_INLINE_VISIBILITY inline
3328typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003329basic_string<_CharT, _Traits, _Allocator>::find_first_not_of(value_type __c,
3330 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003331{
3332 size_type __sz = size();
3333 if (__pos < __sz)
3334 {
3335 const_pointer __p = data();
3336 const_pointer __pe = __p + __sz;
3337 for (const_pointer __ps = __p + __pos; __p != __pe; ++__ps)
3338 if (!traits_type::eq(*__ps, __c))
3339 return static_cast<size_type>(__ps - __p);
3340 }
3341 return npos;
3342}
3343
3344// find_last_not_of
3345
3346template<class _CharT, class _Traits, class _Allocator>
3347typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003348basic_string<_CharT, _Traits, _Allocator>::find_last_not_of(const_pointer __s,
3349 size_type __pos,
3350 size_type __n) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003351{
3352#ifdef _LIBCPP_DEBUG
3353 assert(__s != 0);
3354#endif
3355 size_type __sz = size();
3356 if (__pos < __sz)
3357 ++__pos;
3358 else
3359 __pos = __sz;
3360 const_pointer __p = data();
3361 for (const_pointer __ps = __p + __pos; __ps != __p;)
3362 if (traits_type::find(__s, __n, *--__ps) == 0)
3363 return static_cast<size_type>(__ps - __p);
3364 return npos;
3365}
3366
3367template<class _CharT, class _Traits, class _Allocator>
3368_LIBCPP_INLINE_VISIBILITY inline
3369typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003370basic_string<_CharT, _Traits, _Allocator>::find_last_not_of(const basic_string& __str,
3371 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003372{
3373 return find_last_not_of(__str.data(), __pos, __str.size());
3374}
3375
3376template<class _CharT, class _Traits, class _Allocator>
3377_LIBCPP_INLINE_VISIBILITY inline
3378typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003379basic_string<_CharT, _Traits, _Allocator>::find_last_not_of(const_pointer __s,
3380 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003381{
3382#ifdef _LIBCPP_DEBUG
3383 assert(__s != 0);
3384#endif
3385 return find_last_not_of(__s, __pos, traits_type::length(__s));
3386}
3387
3388template<class _CharT, class _Traits, class _Allocator>
3389_LIBCPP_INLINE_VISIBILITY inline
3390typename basic_string<_CharT, _Traits, _Allocator>::size_type
Howard Hinnanta6119a82011-05-29 19:57:12 +00003391basic_string<_CharT, _Traits, _Allocator>::find_last_not_of(value_type __c,
3392 size_type __pos) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003393{
3394 size_type __sz = size();
3395 if (__pos < __sz)
3396 ++__pos;
3397 else
3398 __pos = __sz;
3399 const_pointer __p = data();
3400 for (const_pointer __ps = __p + __pos; __ps != __p;)
3401 if (!traits_type::eq(*--__ps, __c))
3402 return static_cast<size_type>(__ps - __p);
3403 return npos;
3404}
3405
3406// compare
3407
3408template <class _CharT, class _Traits, class _Allocator>
3409_LIBCPP_INLINE_VISIBILITY inline
3410int
Howard Hinnanta6119a82011-05-29 19:57:12 +00003411basic_string<_CharT, _Traits, _Allocator>::compare(const basic_string& __str) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003412{
Howard Hinnantfa06d752011-07-24 21:45:06 +00003413 size_t __lhs_sz = size();
3414 size_t __rhs_sz = __str.size();
3415 int __result = traits_type::compare(data(), __str.data(),
3416 _VSTD::min(__lhs_sz, __rhs_sz));
3417 if (__result != 0)
3418 return __result;
3419 if (__lhs_sz < __rhs_sz)
3420 return -1;
3421 if (__lhs_sz > __rhs_sz)
3422 return 1;
3423 return 0;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003424}
3425
3426template <class _CharT, class _Traits, class _Allocator>
3427_LIBCPP_INLINE_VISIBILITY inline
3428int
Howard Hinnanta6119a82011-05-29 19:57:12 +00003429basic_string<_CharT, _Traits, _Allocator>::compare(size_type __pos1,
3430 size_type __n1,
3431 const basic_string& __str) const
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003432{
3433 return compare(__pos1, __n1, __str.data(), __str.size());
3434}
3435
3436template <class _CharT, class _Traits, class _Allocator>
3437int
Howard Hinnanta6119a82011-05-29 19:57:12 +00003438basic_string<_CharT, _Traits, _Allocator>::compare(size_type __pos1,
3439 size_type __n1,
3440 const basic_string& __str,
3441 size_type __pos2,
3442 size_type __n2) const
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003443{
3444 size_type __sz = __str.size();
3445 if (__pos2 > __sz)
3446 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003447 return compare(__pos1, __n1, __str.data() + __pos2, _VSTD::min(__n2,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003448 __sz - __pos2));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003449}
3450
3451template <class _CharT, class _Traits, class _Allocator>
3452int
3453basic_string<_CharT, _Traits, _Allocator>::compare(const_pointer __s) const
3454{
3455#ifdef _LIBCPP_DEBUG
3456 assert(__s != 0);
3457#endif
3458 return compare(0, npos, __s, traits_type::length(__s));
3459}
3460
3461template <class _CharT, class _Traits, class _Allocator>
3462int
Howard Hinnanta6119a82011-05-29 19:57:12 +00003463basic_string<_CharT, _Traits, _Allocator>::compare(size_type __pos1,
3464 size_type __n1,
3465 const_pointer __s) const
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003466{
3467#ifdef _LIBCPP_DEBUG
3468 assert(__s != 0);
3469#endif
3470 return compare(__pos1, __n1, __s, traits_type::length(__s));
3471}
3472
3473template <class _CharT, class _Traits, class _Allocator>
3474int
Howard Hinnanta6119a82011-05-29 19:57:12 +00003475basic_string<_CharT, _Traits, _Allocator>::compare(size_type __pos1,
3476 size_type __n1,
3477 const_pointer __s,
3478 size_type __n2) const
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003479{
3480#ifdef _LIBCPP_DEBUG
3481 assert(__s != 0);
3482#endif
3483 size_type __sz = size();
3484 if (__pos1 > __sz || __n2 == npos)
3485 this->__throw_out_of_range();
Howard Hinnant0949eed2011-06-30 21:18:19 +00003486 size_type __rlen = _VSTD::min(__n1, __sz - __pos1);
3487 int __r = traits_type::compare(data() + __pos1, __s, _VSTD::min(__rlen, __n2));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003488 if (__r == 0)
3489 {
3490 if (__rlen < __n2)
3491 __r = -1;
3492 else if (__rlen > __n2)
3493 __r = 1;
3494 }
3495 return __r;
3496}
3497
3498// __invariants
3499
3500template<class _CharT, class _Traits, class _Allocator>
Howard Hinnant2d72b1e2010-12-17 14:46:43 +00003501_LIBCPP_INLINE_VISIBILITY inline
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003502bool
3503basic_string<_CharT, _Traits, _Allocator>::__invariants() const
3504{
3505 if (size() > capacity())
3506 return false;
3507 if (capacity() < __min_cap - 1)
3508 return false;
3509 if (data() == 0)
3510 return false;
3511 if (data()[size()] != value_type(0))
3512 return false;
3513 return true;
3514}
3515
3516// operator==
3517
3518template<class _CharT, class _Traits, class _Allocator>
3519_LIBCPP_INLINE_VISIBILITY inline
3520bool
3521operator==(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003522 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003523{
Howard Hinnanta6119a82011-05-29 19:57:12 +00003524 return __lhs.size() == __rhs.size() && _Traits::compare(__lhs.data(),
3525 __rhs.data(),
3526 __lhs.size()) == 0;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003527}
3528
3529template<class _CharT, class _Traits, class _Allocator>
3530_LIBCPP_INLINE_VISIBILITY inline
3531bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003532operator==(const _CharT* __lhs,
3533 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003534{
3535 return __rhs.compare(__lhs) == 0;
3536}
3537
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003538template<class _CharT, class _Traits, class _Allocator>
3539_LIBCPP_INLINE_VISIBILITY inline
3540bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003541operator==(const basic_string<_CharT,_Traits,_Allocator>& __lhs,
3542 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003543{
3544 return __lhs.compare(__rhs) == 0;
3545}
3546
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003547// operator!=
3548
Howard Hinnant324bb032010-08-22 00:02:43 +00003549template<class _CharT, class _Traits, class _Allocator>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003550_LIBCPP_INLINE_VISIBILITY inline
3551bool
3552operator!=(const basic_string<_CharT,_Traits,_Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003553 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003554{
3555 return !(__lhs == __rhs);
3556}
3557
3558template<class _CharT, class _Traits, class _Allocator>
3559_LIBCPP_INLINE_VISIBILITY inline
3560bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003561operator!=(const _CharT* __lhs,
3562 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003563{
3564 return !(__lhs == __rhs);
3565}
3566
3567template<class _CharT, class _Traits, class _Allocator>
3568_LIBCPP_INLINE_VISIBILITY inline
3569bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003570operator!=(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3571 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003572{
3573 return !(__lhs == __rhs);
3574}
3575
3576// operator<
3577
3578template<class _CharT, class _Traits, class _Allocator>
3579_LIBCPP_INLINE_VISIBILITY inline
3580bool
3581operator< (const basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003582 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003583{
Howard Hinnant2644a7b2011-07-24 15:07:21 +00003584 return __lhs.compare(__rhs) < 0;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003585}
3586
3587template<class _CharT, class _Traits, class _Allocator>
3588_LIBCPP_INLINE_VISIBILITY inline
3589bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003590operator< (const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3591 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003592{
Howard Hinnant2644a7b2011-07-24 15:07:21 +00003593 return __lhs.compare(__rhs) < 0;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003594}
3595
3596template<class _CharT, class _Traits, class _Allocator>
3597_LIBCPP_INLINE_VISIBILITY inline
3598bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003599operator< (const _CharT* __lhs,
3600 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003601{
3602 return __rhs.compare(__lhs) > 0;
3603}
3604
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003605// operator>
3606
3607template<class _CharT, class _Traits, class _Allocator>
3608_LIBCPP_INLINE_VISIBILITY inline
3609bool
3610operator> (const basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003611 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003612{
3613 return __rhs < __lhs;
3614}
3615
3616template<class _CharT, class _Traits, class _Allocator>
3617_LIBCPP_INLINE_VISIBILITY inline
3618bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003619operator> (const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3620 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003621{
3622 return __rhs < __lhs;
3623}
3624
3625template<class _CharT, class _Traits, class _Allocator>
3626_LIBCPP_INLINE_VISIBILITY inline
3627bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003628operator> (const _CharT* __lhs,
3629 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003630{
3631 return __rhs < __lhs;
3632}
3633
3634// operator<=
3635
3636template<class _CharT, class _Traits, class _Allocator>
3637_LIBCPP_INLINE_VISIBILITY inline
3638bool
3639operator<=(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003640 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003641{
3642 return !(__rhs < __lhs);
3643}
3644
3645template<class _CharT, class _Traits, class _Allocator>
3646_LIBCPP_INLINE_VISIBILITY inline
3647bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003648operator<=(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3649 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003650{
3651 return !(__rhs < __lhs);
3652}
3653
3654template<class _CharT, class _Traits, class _Allocator>
3655_LIBCPP_INLINE_VISIBILITY inline
3656bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003657operator<=(const _CharT* __lhs,
3658 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003659{
3660 return !(__rhs < __lhs);
3661}
3662
3663// operator>=
3664
3665template<class _CharT, class _Traits, class _Allocator>
3666_LIBCPP_INLINE_VISIBILITY inline
3667bool
3668operator>=(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnanta6119a82011-05-29 19:57:12 +00003669 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003670{
3671 return !(__lhs < __rhs);
3672}
3673
3674template<class _CharT, class _Traits, class _Allocator>
3675_LIBCPP_INLINE_VISIBILITY inline
3676bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003677operator>=(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3678 const _CharT* __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003679{
3680 return !(__lhs < __rhs);
3681}
3682
3683template<class _CharT, class _Traits, class _Allocator>
3684_LIBCPP_INLINE_VISIBILITY inline
3685bool
Howard Hinnanta6119a82011-05-29 19:57:12 +00003686operator>=(const _CharT* __lhs,
3687 const basic_string<_CharT, _Traits, _Allocator>& __rhs) _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003688{
3689 return !(__lhs < __rhs);
3690}
3691
3692// operator +
3693
3694template<class _CharT, class _Traits, class _Allocator>
3695basic_string<_CharT, _Traits, _Allocator>
3696operator+(const basic_string<_CharT, _Traits, _Allocator>& __lhs,
3697 const basic_string<_CharT, _Traits, _Allocator>& __rhs)
3698{
3699 basic_string<_CharT, _Traits, _Allocator> __r(__lhs.get_allocator());
3700 typename basic_string<_CharT, _Traits, _Allocator>::size_type __lhs_sz = __lhs.size();
3701 typename basic_string<_CharT, _Traits, _Allocator>::size_type __rhs_sz = __rhs.size();
3702 __r.__init(__lhs.data(), __lhs_sz, __lhs_sz + __rhs_sz);
3703 __r.append(__rhs.data(), __rhs_sz);
3704 return __r;
3705}
3706
3707template<class _CharT, class _Traits, class _Allocator>
3708basic_string<_CharT, _Traits, _Allocator>
3709operator+(const _CharT* __lhs , const basic_string<_CharT,_Traits,_Allocator>& __rhs)
3710{
3711 basic_string<_CharT, _Traits, _Allocator> __r(__rhs.get_allocator());
3712 typename basic_string<_CharT, _Traits, _Allocator>::size_type __lhs_sz = _Traits::length(__lhs);
3713 typename basic_string<_CharT, _Traits, _Allocator>::size_type __rhs_sz = __rhs.size();
3714 __r.__init(__lhs, __lhs_sz, __lhs_sz + __rhs_sz);
3715 __r.append(__rhs.data(), __rhs_sz);
3716 return __r;
3717}
3718
3719template<class _CharT, class _Traits, class _Allocator>
3720basic_string<_CharT, _Traits, _Allocator>
3721operator+(_CharT __lhs, const basic_string<_CharT,_Traits,_Allocator>& __rhs)
3722{
3723 basic_string<_CharT, _Traits, _Allocator> __r(__rhs.get_allocator());
3724 typename basic_string<_CharT, _Traits, _Allocator>::size_type __rhs_sz = __rhs.size();
3725 __r.__init(&__lhs, 1, 1 + __rhs_sz);
3726 __r.append(__rhs.data(), __rhs_sz);
3727 return __r;
3728}
3729
3730template<class _CharT, class _Traits, class _Allocator>
3731basic_string<_CharT, _Traits, _Allocator>
3732operator+(const basic_string<_CharT, _Traits, _Allocator>& __lhs, const _CharT* __rhs)
3733{
3734 basic_string<_CharT, _Traits, _Allocator> __r(__lhs.get_allocator());
3735 typename basic_string<_CharT, _Traits, _Allocator>::size_type __lhs_sz = __lhs.size();
3736 typename basic_string<_CharT, _Traits, _Allocator>::size_type __rhs_sz = _Traits::length(__rhs);
3737 __r.__init(__lhs.data(), __lhs_sz, __lhs_sz + __rhs_sz);
3738 __r.append(__rhs, __rhs_sz);
3739 return __r;
3740}
3741
3742template<class _CharT, class _Traits, class _Allocator>
3743basic_string<_CharT, _Traits, _Allocator>
3744operator+(const basic_string<_CharT, _Traits, _Allocator>& __lhs, _CharT __rhs)
3745{
3746 basic_string<_CharT, _Traits, _Allocator> __r(__lhs.get_allocator());
3747 typename basic_string<_CharT, _Traits, _Allocator>::size_type __lhs_sz = __lhs.size();
3748 __r.__init(__lhs.data(), __lhs_sz, __lhs_sz + 1);
3749 __r.push_back(__rhs);
3750 return __r;
3751}
3752
Howard Hinnant73d21a42010-09-04 23:28:19 +00003753#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003754
3755template<class _CharT, class _Traits, class _Allocator>
3756_LIBCPP_INLINE_VISIBILITY inline
3757basic_string<_CharT, _Traits, _Allocator>
3758operator+(basic_string<_CharT, _Traits, _Allocator>&& __lhs, const basic_string<_CharT, _Traits, _Allocator>& __rhs)
3759{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003760 return _VSTD::move(__lhs.append(__rhs));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003761}
3762
3763template<class _CharT, class _Traits, class _Allocator>
3764_LIBCPP_INLINE_VISIBILITY inline
3765basic_string<_CharT, _Traits, _Allocator>
3766operator+(const basic_string<_CharT, _Traits, _Allocator>& __lhs, basic_string<_CharT, _Traits, _Allocator>&& __rhs)
3767{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003768 return _VSTD::move(__rhs.insert(0, __lhs));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003769}
3770
3771template<class _CharT, class _Traits, class _Allocator>
3772_LIBCPP_INLINE_VISIBILITY inline
3773basic_string<_CharT, _Traits, _Allocator>
3774operator+(basic_string<_CharT, _Traits, _Allocator>&& __lhs, basic_string<_CharT, _Traits, _Allocator>&& __rhs)
3775{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003776 return _VSTD::move(__lhs.append(__rhs));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003777}
3778
3779template<class _CharT, class _Traits, class _Allocator>
3780_LIBCPP_INLINE_VISIBILITY inline
3781basic_string<_CharT, _Traits, _Allocator>
3782operator+(const _CharT* __lhs , basic_string<_CharT,_Traits,_Allocator>&& __rhs)
3783{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003784 return _VSTD::move(__rhs.insert(0, __lhs));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003785}
3786
3787template<class _CharT, class _Traits, class _Allocator>
3788_LIBCPP_INLINE_VISIBILITY inline
3789basic_string<_CharT, _Traits, _Allocator>
3790operator+(_CharT __lhs, basic_string<_CharT,_Traits,_Allocator>&& __rhs)
3791{
3792 __rhs.insert(__rhs.begin(), __lhs);
Howard Hinnant0949eed2011-06-30 21:18:19 +00003793 return _VSTD::move(__rhs);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003794}
3795
3796template<class _CharT, class _Traits, class _Allocator>
3797_LIBCPP_INLINE_VISIBILITY inline
3798basic_string<_CharT, _Traits, _Allocator>
3799operator+(basic_string<_CharT, _Traits, _Allocator>&& __lhs, const _CharT* __rhs)
3800{
Howard Hinnant0949eed2011-06-30 21:18:19 +00003801 return _VSTD::move(__lhs.append(__rhs));
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003802}
3803
3804template<class _CharT, class _Traits, class _Allocator>
3805_LIBCPP_INLINE_VISIBILITY inline
3806basic_string<_CharT, _Traits, _Allocator>
3807operator+(basic_string<_CharT, _Traits, _Allocator>&& __lhs, _CharT __rhs)
3808{
3809 __lhs.push_back(__rhs);
Howard Hinnant0949eed2011-06-30 21:18:19 +00003810 return _VSTD::move(__lhs);
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003811}
3812
Howard Hinnant73d21a42010-09-04 23:28:19 +00003813#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003814
3815// swap
3816
3817template<class _CharT, class _Traits, class _Allocator>
3818_LIBCPP_INLINE_VISIBILITY inline
3819void
Howard Hinnanta6119a82011-05-29 19:57:12 +00003820swap(basic_string<_CharT, _Traits, _Allocator>& __lhs,
Howard Hinnant53f7d4c2011-06-03 18:40:47 +00003821 basic_string<_CharT, _Traits, _Allocator>& __rhs)
3822 _NOEXCEPT_(_NOEXCEPT_(__lhs.swap(__rhs)))
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003823{
3824 __lhs.swap(__rhs);
3825}
3826
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003827#ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
3828
3829typedef basic_string<char16_t> u16string;
3830typedef basic_string<char32_t> u32string;
3831
Howard Hinnant324bb032010-08-22 00:02:43 +00003832#endif // _LIBCPP_HAS_NO_UNICODE_CHARS
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003833
Howard Hinnanta6a062d2010-06-02 18:20:39 +00003834int stoi (const string& __str, size_t* __idx = 0, int __base = 10);
3835long stol (const string& __str, size_t* __idx = 0, int __base = 10);
3836unsigned long stoul (const string& __str, size_t* __idx = 0, int __base = 10);
3837long long stoll (const string& __str, size_t* __idx = 0, int __base = 10);
3838unsigned long long stoull(const string& __str, size_t* __idx = 0, int __base = 10);
3839
3840float stof (const string& __str, size_t* __idx = 0);
3841double stod (const string& __str, size_t* __idx = 0);
3842long double stold(const string& __str, size_t* __idx = 0);
3843
3844string to_string(int __val);
3845string to_string(unsigned __val);
3846string to_string(long __val);
3847string to_string(unsigned long __val);
3848string to_string(long long __val);
3849string to_string(unsigned long long __val);
3850string to_string(float __val);
3851string to_string(double __val);
3852string to_string(long double __val);
3853
3854int stoi (const wstring& __str, size_t* __idx = 0, int __base = 10);
3855long stol (const wstring& __str, size_t* __idx = 0, int __base = 10);
3856unsigned long stoul (const wstring& __str, size_t* __idx = 0, int __base = 10);
3857long long stoll (const wstring& __str, size_t* __idx = 0, int __base = 10);
3858unsigned long long stoull(const wstring& __str, size_t* __idx = 0, int __base = 10);
3859
3860float stof (const wstring& __str, size_t* __idx = 0);
3861double stod (const wstring& __str, size_t* __idx = 0);
3862long double stold(const wstring& __str, size_t* __idx = 0);
3863
3864wstring to_wstring(int __val);
3865wstring to_wstring(unsigned __val);
3866wstring to_wstring(long __val);
3867wstring to_wstring(unsigned long __val);
3868wstring to_wstring(long long __val);
3869wstring to_wstring(unsigned long long __val);
3870wstring to_wstring(float __val);
3871wstring to_wstring(double __val);
3872wstring to_wstring(long double __val);
3873
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003874template<class _CharT, class _Traits, class _Allocator>
3875 const typename basic_string<_CharT, _Traits, _Allocator>::size_type
3876 basic_string<_CharT, _Traits, _Allocator>::npos;
3877
Sean Huntaffd9e52011-07-29 23:31:56 +00003878template<class _Ptr>
3879size_t _LIBCPP_INLINE_VISIBILITY __do_string_hash(_Ptr __p, _Ptr __e)
3880{
3881 size_t __r = 0;
3882 const size_t __sr = __CHAR_BIT__ * sizeof(size_t) - 8;
3883 const size_t __m = size_t(0xF) << (__sr + 4);
3884 for (; __p != __e; ++__p)
3885 {
3886 __r = (__r << 4) + *__p;
3887 size_t __g = __r & __m;
3888 __r ^= __g | (__g >> __sr);
3889 }
3890 return __r;
3891}
3892
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003893template<class _CharT, class _Traits, class _Allocator>
Howard Hinnant8d7a9552010-09-23 17:31:07 +00003894struct _LIBCPP_VISIBLE hash<basic_string<_CharT, _Traits, _Allocator> >
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003895 : public unary_function<basic_string<_CharT, _Traits, _Allocator>, size_t>
3896{
3897 size_t
Howard Hinnanta6119a82011-05-29 19:57:12 +00003898 operator()(const basic_string<_CharT, _Traits, _Allocator>& __val) const _NOEXCEPT;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003899};
3900
3901template<class _CharT, class _Traits, class _Allocator>
3902size_t
3903hash<basic_string<_CharT, _Traits, _Allocator> >::operator()(
Howard Hinnanta6119a82011-05-29 19:57:12 +00003904 const basic_string<_CharT, _Traits, _Allocator>& __val) const _NOEXCEPT
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003905{
Sean Huntaffd9e52011-07-29 23:31:56 +00003906 return __do_string_hash(__val.data(), __val.data() + __val.size());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003907}
3908
Howard Hinnant464aa5c2011-07-18 15:51:59 +00003909template<class _CharT, class _Traits, class _Allocator>
3910basic_ostream<_CharT, _Traits>&
3911operator<<(basic_ostream<_CharT, _Traits>& __os,
3912 const basic_string<_CharT, _Traits, _Allocator>& __str);
3913
3914template<class _CharT, class _Traits, class _Allocator>
3915basic_istream<_CharT, _Traits>&
3916operator>>(basic_istream<_CharT, _Traits>& __is,
3917 basic_string<_CharT, _Traits, _Allocator>& __str);
3918
3919template<class _CharT, class _Traits, class _Allocator>
3920basic_istream<_CharT, _Traits>&
3921getline(basic_istream<_CharT, _Traits>& __is,
3922 basic_string<_CharT, _Traits, _Allocator>& __str, _CharT __dlm);
3923
3924template<class _CharT, class _Traits, class _Allocator>
3925inline _LIBCPP_INLINE_VISIBILITY
3926basic_istream<_CharT, _Traits>&
3927getline(basic_istream<_CharT, _Traits>& __is,
3928 basic_string<_CharT, _Traits, _Allocator>& __str);
3929
3930#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
3931
3932template<class _CharT, class _Traits, class _Allocator>
3933inline _LIBCPP_INLINE_VISIBILITY
3934basic_istream<_CharT, _Traits>&
3935getline(basic_istream<_CharT, _Traits>&& __is,
3936 basic_string<_CharT, _Traits, _Allocator>& __str, _CharT __dlm);
3937
3938template<class _CharT, class _Traits, class _Allocator>
3939inline _LIBCPP_INLINE_VISIBILITY
3940basic_istream<_CharT, _Traits>&
3941getline(basic_istream<_CharT, _Traits>&& __is,
3942 basic_string<_CharT, _Traits, _Allocator>& __str);
3943
3944#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
3945
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003946extern template class basic_string<char>;
3947extern template class basic_string<wchar_t>;
3948
3949extern template
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00003950 string
3951 operator+<char, char_traits<char>, allocator<char> >(char const*, string const&);
3952
3953_LIBCPP_END_NAMESPACE_STD
3954
3955#endif // _LIBCPP_STRING