1 // Components for manipulating sequences of characters -*- C++ -*- 2 3 // Copyright (C) 1997-2013 Free Software Foundation, Inc. 4 // 5 // This file is part of the GNU ISO C++ Library. This library is free 6 // software; you can redistribute it and/or modify it under the 7 // terms of the GNU General Public License as published by the 8 // Free Software Foundation; either version 3, or (at your option) 9 // any later version. 10 11 // This library is distributed in the hope that it will be useful, 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 // GNU General Public License for more details. 15 16 // Under Section 7 of GPL version 3, you are granted additional 17 // permissions described in the GCC Runtime Library Exception, version 18 // 3.1, as published by the Free Software Foundation. 19 20 // You should have received a copy of the GNU General Public License and 21 // a copy of the GCC Runtime Library Exception along with this program; 22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see 23 // <http://www.gnu.org/licenses/>. 24 25 /** @file bits/basic_string.h 26 * This is an internal header file, included by other library headers. 27 * Do not attempt to use it directly. @headername{string} 28 */ 29 30 // 31 // ISO C++ 14882: 21 Strings library 32 // 33 34 #ifndef _BASIC_STRING_H 35 #define _BASIC_STRING_H 1 36 37 #pragma GCC system_header 38 39 #include <ext/atomicity.h> 40 #include <debug/debug.h> 41 #if __cplusplus >= 201103L 42 #include <initializer_list> 43 #endif 44 45 namespace std _GLIBCXX_VISIBILITY(default) 46 { 47 _GLIBCXX_BEGIN_NAMESPACE_VERSION 48 49 /** 50 * @class basic_string basic_string.h <string> 51 * @brief Managing sequences of characters and character-like objects. 52 * 53 * @ingroup strings 54 * @ingroup sequences 55 * 56 * @tparam _CharT Type of character 57 * @tparam _Traits Traits for character type, defaults to 58 * char_traits<_CharT>. 59 * @tparam _Alloc Allocator type, defaults to allocator<_CharT>. 60 * 61 * Meets the requirements of a <a href="tables.html#65">container</a>, a 62 * <a href="tables.html#66">reversible container</a>, and a 63 * <a href="tables.html#67">sequence</a>. Of the 64 * <a href="tables.html#68">optional sequence requirements</a>, only 65 * @c push_back, @c at, and @c %array access are supported. 66 * 67 * @doctodo 68 * 69 * 70 * Documentation? What's that? 71 * Nathan Myers <ncm@cantrip.org>. 72 * 73 * A string looks like this: 74 * 75 * @code 76 * [_Rep] 77 * _M_length 78 * [basic_string<char_type>] _M_capacity 79 * _M_dataplus _M_refcount 80 * _M_p ----------------> unnamed array of char_type 81 * @endcode 82 * 83 * Where the _M_p points to the first character in the string, and 84 * you cast it to a pointer-to-_Rep and subtract 1 to get a 85 * pointer to the header. 86 * 87 * This approach has the enormous advantage that a string object 88 * requires only one allocation. All the ugliness is confined 89 * within a single %pair of inline functions, which each compile to 90 * a single @a add instruction: _Rep::_M_data(), and 91 * string::_M_rep(); and the allocation function which gets a 92 * block of raw bytes and with room enough and constructs a _Rep 93 * object at the front. 94 * 95 * The reason you want _M_data pointing to the character %array and 96 * not the _Rep is so that the debugger can see the string 97 * contents. (Probably we should add a non-inline member to get 98 * the _Rep for the debugger to use, so users can check the actual 99 * string length.) 100 * 101 * Note that the _Rep object is a POD so that you can have a 102 * static <em>empty string</em> _Rep object already @a constructed before 103 * static constructors have run. The reference-count encoding is 104 * chosen so that a 0 indicates one reference, so you never try to 105 * destroy the empty-string _Rep object. 106 * 107 * All but the last paragraph is considered pretty conventional 108 * for a C++ string implementation. 109 */ 110 // 21.3 Template class basic_string 111 template<typename _CharT, typename _Traits, typename _Alloc> 112 class basic_string 113 { 114 typedef typename _Alloc::template rebind<_CharT>::other _CharT_alloc_type; 115 116 // Types: 117 public: 118 typedef _Traits traits_type; 119 typedef typename _Traits::char_type value_type; 120 typedef _Alloc allocator_type; 121 typedef typename _CharT_alloc_type::size_type size_type; 122 typedef typename _CharT_alloc_type::difference_type difference_type; 123 typedef typename _CharT_alloc_type::reference reference; 124 typedef typename _CharT_alloc_type::const_reference const_reference; 125 typedef typename _CharT_alloc_type::pointer pointer; 126 typedef typename _CharT_alloc_type::const_pointer const_pointer; 127 typedef __gnu_cxx::__normal_iterator<pointer, basic_string> iterator; 128 typedef __gnu_cxx::__normal_iterator<const_pointer, basic_string> 129 const_iterator; 130 typedef std::reverse_iterator<const_iterator> const_reverse_iterator; 131 typedef std::reverse_iterator<iterator> reverse_iterator; 132 133 private: 134 // _Rep: string representation 135 // Invariants: 136 // 1. String really contains _M_length + 1 characters: due to 21.3.4 137 // must be kept null-terminated. 138 // 2. _M_capacity >= _M_length 139 // Allocated memory is always (_M_capacity + 1) * sizeof(_CharT). 140 // 3. _M_refcount has three states: 141 // -1: leaked, one reference, no ref-copies allowed, non-const. 142 // 0: one reference, non-const. 143 // n>0: n + 1 references, operations require a lock, const. 144 // 4. All fields==0 is an empty string, given the extra storage 145 // beyond-the-end for a null terminator; thus, the shared 146 // empty string representation needs no constructor. 147 148 struct _Rep_base 149 { 150 size_type _M_length; 151 size_type _M_capacity; 152 _Atomic_word _M_refcount; 153 }; 154 155 struct _Rep : _Rep_base 156 { 157 // Types: 158 typedef typename _Alloc::template rebind<char>::other _Raw_bytes_alloc; 159 160 // (Public) Data members: 161 162 // The maximum number of individual char_type elements of an 163 // individual string is determined by _S_max_size. This is the 164 // value that will be returned by max_size(). (Whereas npos 165 // is the maximum number of bytes the allocator can allocate.) 166 // If one was to divvy up the theoretical largest size string, 167 // with a terminating character and m _CharT elements, it'd 168 // look like this: 169 // npos = sizeof(_Rep) + (m * sizeof(_CharT)) + sizeof(_CharT) 170 // Solving for m: 171 // m = ((npos - sizeof(_Rep))/sizeof(CharT)) - 1 172 // In addition, this implementation quarters this amount. 173 static const size_type _S_max_size; 174 static const _CharT _S_terminal; 175 176 // The following storage is init'd to 0 by the linker, resulting 177 // (carefully) in an empty string with one reference. 178 static size_type _S_empty_rep_storage[]; 179 180 static _Rep& 181 _S_empty_rep() 182 { 183 // NB: Mild hack to avoid strict-aliasing warnings. Note that 184 // _S_empty_rep_storage is never modified and the punning should 185 // be reasonably safe in this case. 186 void* __p = reinterpret_cast<void*>(&_S_empty_rep_storage); 187 return *reinterpret_cast<_Rep*>(__p); 188 } 189 190 bool 191 _M_is_leaked() const 192 { return this->_M_refcount < 0; } 193 194 bool 195 _M_is_shared() const 196 { return this->_M_refcount > 0; } 197 198 void 199 _M_set_leaked() 200 { this->_M_refcount = -1; } 201 202 void 203 _M_set_sharable() 204 { this->_M_refcount = 0; } 205 206 void 207 _M_set_length_and_sharable(size_type __n) 208 { 209 #if _GLIBCXX_FULLY_DYNAMIC_STRING == 0 210 if (__builtin_expect(this != &_S_empty_rep(), false)) 211 #endif 212 { 213 this->_M_set_sharable(); // One reference. 214 this->_M_length = __n; 215 traits_type::assign(this->_M_refdata()[__n], _S_terminal); 216 // grrr. (per 21.3.4) 217 // You cannot leave those LWG people alone for a second. 218 } 219 } 220 221 _CharT* 222 _M_refdata() throw() 223 { return reinterpret_cast<_CharT*>(this + 1); } 224 225 _CharT* 226 _M_grab(const _Alloc& __alloc1, const _Alloc& __alloc2) 227 { 228 return (!_M_is_leaked() && __alloc1 == __alloc2) 229 ? _M_refcopy() : _M_clone(__alloc1); 230 } 231 232 // Create & Destroy 233 static _Rep* 234 _S_create(size_type, size_type, const _Alloc&); 235 236 void 237 _M_dispose(const _Alloc& __a) 238 { 239 #if _GLIBCXX_FULLY_DYNAMIC_STRING == 0 240 if (__builtin_expect(this != &_S_empty_rep(), false)) 241 #endif 242 { 243 // Be race-detector-friendly. For more info see bits/c++config. 244 _GLIBCXX_SYNCHRONIZATION_HAPPENS_BEFORE(&this->_M_refcount); 245 if (__gnu_cxx::__exchange_and_add_dispatch(&this->_M_refcount, 246 -1) <= 0) 247 { 248 _GLIBCXX_SYNCHRONIZATION_HAPPENS_AFTER(&this->_M_refcount); 249 _M_destroy(__a); 250 } 251 } 252 } // XXX MT 253 254 void 255 _M_destroy(const _Alloc&) throw(); 256 257 _CharT* 258 _M_refcopy() throw() 259 { 260 #if _GLIBCXX_FULLY_DYNAMIC_STRING == 0 261 if (__builtin_expect(this != &_S_empty_rep(), false)) 262 #endif 263 __gnu_cxx::__atomic_add_dispatch(&this->_M_refcount, 1); 264 return _M_refdata(); 265 } // XXX MT 266 267 _CharT* 268 _M_clone(const _Alloc&, size_type __res = 0); 269 }; 270 271 // Use empty-base optimization: http://www.cantrip.org/emptyopt.html 272 struct _Alloc_hider : _Alloc 273 { 274 _Alloc_hider(_CharT* __dat, const _Alloc& __a) 275 : _Alloc(__a), _M_p(__dat) { } 276 277 _CharT* _M_p; // The actual data. 278 }; 279 280 public: 281 // Data Members (public): 282 // NB: This is an unsigned type, and thus represents the maximum 283 // size that the allocator can hold. 284 /// Value returned by various member functions when they fail. 285 static const size_type npos = static_cast<size_type>(-1); 286 287 private: 288 // Data Members (private): 289 mutable _Alloc_hider _M_dataplus; 290 291 _CharT* 292 _M_data() const 293 { return _M_dataplus._M_p; } 294 295 _CharT* 296 _M_data(_CharT* __p) 297 { return (_M_dataplus._M_p = __p); } 298 299 _Rep* 300 _M_rep() const 301 { return &((reinterpret_cast<_Rep*> (_M_data()))[-1]); } 302 303 // For the internal use we have functions similar to `begin'/`end' 304 // but they do not call _M_leak. 305 iterator 306 _M_ibegin() const 307 { return iterator(_M_data()); } 308 309 iterator 310 _M_iend() const 311 { return iterator(_M_data() + this->size()); } 312 313 void 314 _M_leak() // for use in begin() & non-const op[] 315 { 316 if (!_M_rep()->_M_is_leaked()) 317 _M_leak_hard(); 318 } 319 320 size_type 321 _M_check(size_type __pos, const char* __s) const 322 { 323 if (__pos > this->size()) 324 __throw_out_of_range(__N(__s)); 325 return __pos; 326 } 327 328 void 329 _M_check_length(size_type __n1, size_type __n2, const char* __s) const 330 { 331 if (this->max_size() - (this->size() - __n1) < __n2) 332 __throw_length_error(__N(__s)); 333 } 334 335 // NB: _M_limit doesn't check for a bad __pos value. 336 size_type 337 _M_limit(size_type __pos, size_type __off) const 338 { 339 const bool __testoff = __off < this->size() - __pos; 340 return __testoff ? __off : this->size() - __pos; 341 } 342 343 // True if _Rep and source do not overlap. 344 bool 345 _M_disjunct(const _CharT* __s) const 346 { 347 return (less<const _CharT*>()(__s, _M_data()) 348 || less<const _CharT*>()(_M_data() + this->size(), __s)); 349 } 350 351 // When __n = 1 way faster than the general multichar 352 // traits_type::copy/move/assign. 353 static void 354 _M_copy(_CharT* __d, const _CharT* __s, size_type __n) 355 { 356 if (__n == 1) 357 traits_type::assign(*__d, *__s); 358 else 359 traits_type::copy(__d, __s, __n); 360 } 361 362 static void 363 _M_move(_CharT* __d, const _CharT* __s, size_type __n) 364 { 365 if (__n == 1) 366 traits_type::assign(*__d, *__s); 367 else 368 traits_type::move(__d, __s, __n); 369 } 370 371 static void 372 _M_assign(_CharT* __d, size_type __n, _CharT __c) 373 { 374 if (__n == 1) 375 traits_type::assign(*__d, __c); 376 else 377 traits_type::assign(__d, __n, __c); 378 } 379 380 // _S_copy_chars is a separate template to permit specialization 381 // to optimize for the common case of pointers as iterators. 382 template<class _Iterator> 383 static void 384 _S_copy_chars(_CharT* __p, _Iterator __k1, _Iterator __k2) 385 { 386 for (; __k1 != __k2; ++__k1, ++__p) 387 traits_type::assign(*__p, *__k1); // These types are off. 388 } 389 390 static void 391 _S_copy_chars(_CharT* __p, iterator __k1, iterator __k2) 392 { _S_copy_chars(__p, __k1.base(), __k2.base()); } 393 394 static void 395 _S_copy_chars(_CharT* __p, const_iterator __k1, const_iterator __k2) 396 { _S_copy_chars(__p, __k1.base(), __k2.base()); } 397 398 static void 399 _S_copy_chars(_CharT* __p, _CharT* __k1, _CharT* __k2) 400 { _M_copy(__p, __k1, __k2 - __k1); } 401 402 static void 403 _S_copy_chars(_CharT* __p, const _CharT* __k1, const _CharT* __k2) 404 { _M_copy(__p, __k1, __k2 - __k1); } 405 406 static int 407 _S_compare(size_type __n1, size_type __n2) 408 { 409 const difference_type __d = difference_type(__n1 - __n2); 410 411 if (__d > __gnu_cxx::__numeric_traits<int>::__max) 412 return __gnu_cxx::__numeric_traits<int>::__max; 413 else if (__d < __gnu_cxx::__numeric_traits<int>::__min) 414 return __gnu_cxx::__numeric_traits<int>::__min; 415 else 416 return int(__d); 417 } 418 419 void 420 _M_mutate(size_type __pos, size_type __len1, size_type __len2); 421 422 void 423 _M_leak_hard(); 424 425 static _Rep& 426 _S_empty_rep() 427 { return _Rep::_S_empty_rep(); } 428 429 public: 430 // Construct/copy/destroy: 431 // NB: We overload ctors in some cases instead of using default 432 // arguments, per 17.4.4.4 para. 2 item 2. 433 434 /** 435 * @brief Default constructor creates an empty string. 436 */ 437 basic_string() 438 #if _GLIBCXX_FULLY_DYNAMIC_STRING == 0 439 : _M_dataplus(_S_empty_rep()._M_refdata(), _Alloc()) { } 440 #else 441 : _M_dataplus(_S_construct(size_type(), _CharT(), _Alloc()), _Alloc()){ } 442 #endif 443 444 /** 445 * @brief Construct an empty string using allocator @a a. 446 */ 447 explicit 448 basic_string(const _Alloc& __a); 449 450 // NB: per LWG issue 42, semantics different from IS: 451 /** 452 * @brief Construct string with copy of value of @a str. 453 * @param __str Source string. 454 */ 455 basic_string(const basic_string& __str); 456 /** 457 * @brief Construct string as copy of a substring. 458 * @param __str Source string. 459 * @param __pos Index of first character to copy from. 460 * @param __n Number of characters to copy (default remainder). 461 */ 462 basic_string(const basic_string& __str, size_type __pos, 463 size_type __n = npos); 464 /** 465 * @brief Construct string as copy of a substring. 466 * @param __str Source string. 467 * @param __pos Index of first character to copy from. 468 * @param __n Number of characters to copy. 469 * @param __a Allocator to use. 470 */ 471 basic_string(const basic_string& __str, size_type __pos, 472 size_type __n, const _Alloc& __a); 473 474 /** 475 * @brief Construct string initialized by a character %array. 476 * @param __s Source character %array. 477 * @param __n Number of characters to copy. 478 * @param __a Allocator to use (default is default allocator). 479 * 480 * NB: @a __s must have at least @a __n characters, '\\0' 481 * has no special meaning. 482 */ 483 basic_string(const _CharT* __s, size_type __n, 484 const _Alloc& __a = _Alloc()); 485 /** 486 * @brief Construct string as copy of a C string. 487 * @param __s Source C string. 488 * @param __a Allocator to use (default is default allocator). 489 */ 490 basic_string(const _CharT* __s, const _Alloc& __a = _Alloc()); 491 /** 492 * @brief Construct string as multiple characters. 493 * @param __n Number of characters. 494 * @param __c Character to use. 495 * @param __a Allocator to use (default is default allocator). 496 */ 497 basic_string(size_type __n, _CharT __c, const _Alloc& __a = _Alloc()); 498 499 #if __cplusplus >= 201103L 500 /** 501 * @brief Move construct string. 502 * @param __str Source string. 503 * 504 * The newly-created string contains the exact contents of @a __str. 505 * @a __str is a valid, but unspecified string. 506 **/ 507 basic_string(basic_string&& __str) noexcept 508 : _M_dataplus(__str._M_dataplus) 509 { 510 #if _GLIBCXX_FULLY_DYNAMIC_STRING == 0 511 __str._M_data(_S_empty_rep()._M_refdata()); 512 #else 513 __str._M_data(_S_construct(size_type(), _CharT(), get_allocator())); 514 #endif 515 } 516 517 /** 518 * @brief Construct string from an initializer %list. 519 * @param __l std::initializer_list of characters. 520 * @param __a Allocator to use (default is default allocator). 521 */ 522 basic_string(initializer_list<_CharT> __l, const _Alloc& __a = _Alloc()); 523 #endif // C++11 524 525 /** 526 * @brief Construct string as copy of a range. 527 * @param __beg Start of range. 528 * @param __end End of range. 529 * @param __a Allocator to use (default is default allocator). 530 */ 531 template<class _InputIterator> 532 basic_string(_InputIterator __beg, _InputIterator __end, 533 const _Alloc& __a = _Alloc()); 534 535 /** 536 * @brief Destroy the string instance. 537 */ 538 ~basic_string() _GLIBCXX_NOEXCEPT 539 { _M_rep()->_M_dispose(this->get_allocator()); } 540 541 /** 542 * @brief Assign the value of @a str to this string. 543 * @param __str Source string. 544 */ 545 basic_string& 546 operator=(const basic_string& __str) 547 { return this->assign(__str); } 548 549 /** 550 * @brief Copy contents of @a s into this string. 551 * @param __s Source null-terminated string. 552 */ 553 basic_string& 554 operator=(const _CharT* __s) 555 { return this->assign(__s); } 556 557 /** 558 * @brief Set value to string of length 1. 559 * @param __c Source character. 560 * 561 * Assigning to a character makes this string length 1 and 562 * (*this)[0] == @a c. 563 */ 564 basic_string& 565 operator=(_CharT __c) 566 { 567 this->assign(1, __c); 568 return *this; 569 } 570 571 #if __cplusplus >= 201103L 572 /** 573 * @brief Move assign the value of @a str to this string. 574 * @param __str Source string. 575 * 576 * The contents of @a str are moved into this string (without copying). 577 * @a str is a valid, but unspecified string. 578 **/ 579 basic_string& 580 operator=(basic_string&& __str) 581 { 582 // NB: DR 1204. 583 this->swap(__str); 584 return *this; 585 } 586 587 /** 588 * @brief Set value to string constructed from initializer %list. 589 * @param __l std::initializer_list. 590 */ 591 basic_string& 592 operator=(initializer_list<_CharT> __l) 593 { 594 this->assign(__l.begin(), __l.size()); 595 return *this; 596 } 597 #endif // C++11 598 599 // Iterators: 600 /** 601 * Returns a read/write iterator that points to the first character in 602 * the %string. Unshares the string. 603 */ 604 iterator 605 begin() _GLIBCXX_NOEXCEPT 606 { 607 _M_leak(); 608 return iterator(_M_data()); 609 } 610 611 /** 612 * Returns a read-only (constant) iterator that points to the first 613 * character in the %string. 614 */ 615 const_iterator 616 begin() const _GLIBCXX_NOEXCEPT 617 { return const_iterator(_M_data()); } 618 619 /** 620 * Returns a read/write iterator that points one past the last 621 * character in the %string. Unshares the string. 622 */ 623 iterator 624 end() _GLIBCXX_NOEXCEPT 625 { 626 _M_leak(); 627 return iterator(_M_data() + this->size()); 628 } 629 630 /** 631 * Returns a read-only (constant) iterator that points one past the 632 * last character in the %string. 633 */ 634 const_iterator 635 end() const _GLIBCXX_NOEXCEPT 636 { return const_iterator(_M_data() + this->size()); } 637 638 /** 639 * Returns a read/write reverse iterator that points to the last 640 * character in the %string. Iteration is done in reverse element 641 * order. Unshares the string. 642 */ 643 reverse_iterator 644 rbegin() _GLIBCXX_NOEXCEPT 645 { return reverse_iterator(this->end()); } 646 647 /** 648 * Returns a read-only (constant) reverse iterator that points 649 * to the last character in the %string. Iteration is done in 650 * reverse element order. 651 */ 652 const_reverse_iterator 653 rbegin() const _GLIBCXX_NOEXCEPT 654 { return const_reverse_iterator(this->end()); } 655 656 /** 657 * Returns a read/write reverse iterator that points to one before the 658 * first character in the %string. Iteration is done in reverse 659 * element order. Unshares the string. 660 */ 661 reverse_iterator 662 rend() _GLIBCXX_NOEXCEPT 663 { return reverse_iterator(this->begin()); } 664 665 /** 666 * Returns a read-only (constant) reverse iterator that points 667 * to one before the first character in the %string. Iteration 668 * is done in reverse element order. 669 */ 670 const_reverse_iterator 671 rend() const _GLIBCXX_NOEXCEPT 672 { return const_reverse_iterator(this->begin()); } 673 674 #if __cplusplus >= 201103L 675 /** 676 * Returns a read-only (constant) iterator that points to the first 677 * character in the %string. 678 */ 679 const_iterator 680 cbegin() const noexcept 681 { return const_iterator(this->_M_data()); } 682 683 /** 684 * Returns a read-only (constant) iterator that points one past the 685 * last character in the %string. 686 */ 687 const_iterator 688 cend() const noexcept 689 { return const_iterator(this->_M_data() + this->size()); } 690 691 /** 692 * Returns a read-only (constant) reverse iterator that points 693 * to the last character in the %string. Iteration is done in 694 * reverse element order. 695 */ 696 const_reverse_iterator 697 crbegin() const noexcept 698 { return const_reverse_iterator(this->end()); } 699 700 /** 701 * Returns a read-only (constant) reverse iterator that points 702 * to one before the first character in the %string. Iteration 703 * is done in reverse element order. 704 */ 705 const_reverse_iterator 706 crend() const noexcept 707 { return const_reverse_iterator(this->begin()); } 708 #endif 709 710 public: 711 // Capacity: 712 /// Returns the number of characters in the string, not including any 713 /// null-termination. 714 size_type 715 size() const _GLIBCXX_NOEXCEPT 716 { return _M_rep()->_M_length; } 717 718 /// Returns the number of characters in the string, not including any 719 /// null-termination. 720 size_type 721 length() const _GLIBCXX_NOEXCEPT 722 { return _M_rep()->_M_length; } 723 724 /// Returns the size() of the largest possible %string. 725 size_type 726 max_size() const _GLIBCXX_NOEXCEPT 727 { return _Rep::_S_max_size; } 728 729 /** 730 * @brief Resizes the %string to the specified number of characters. 731 * @param __n Number of characters the %string should contain. 732 * @param __c Character to fill any new elements. 733 * 734 * This function will %resize the %string to the specified 735 * number of characters. If the number is smaller than the 736 * %string's current size the %string is truncated, otherwise 737 * the %string is extended and new elements are %set to @a __c. 738 */ 739 void 740 resize(size_type __n, _CharT __c); 741 742 /** 743 * @brief Resizes the %string to the specified number of characters. 744 * @param __n Number of characters the %string should contain. 745 * 746 * This function will resize the %string to the specified length. If 747 * the new size is smaller than the %string's current size the %string 748 * is truncated, otherwise the %string is extended and new characters 749 * are default-constructed. For basic types such as char, this means 750 * setting them to 0. 751 */ 752 void 753 resize(size_type __n) 754 { this->resize(__n, _CharT()); } 755 756 #if __cplusplus >= 201103L 757 /// A non-binding request to reduce capacity() to size(). 758 void 759 shrink_to_fit() 760 { 761 if (capacity() > size()) 762 { 763 __try 764 { reserve(0); } 765 __catch(...) 766 { } 767 } 768 } 769 #endif 770 771 /** 772 * Returns the total number of characters that the %string can hold 773 * before needing to allocate more memory. 774 */ 775 size_type 776 capacity() const _GLIBCXX_NOEXCEPT 777 { return _M_rep()->_M_capacity; } 778 779 /** 780 * @brief Attempt to preallocate enough memory for specified number of 781 * characters. 782 * @param __res_arg Number of characters required. 783 * @throw std::length_error If @a __res_arg exceeds @c max_size(). 784 * 785 * This function attempts to reserve enough memory for the 786 * %string to hold the specified number of characters. If the 787 * number requested is more than max_size(), length_error is 788 * thrown. 789 * 790 * The advantage of this function is that if optimal code is a 791 * necessity and the user can determine the string length that will be 792 * required, the user can reserve the memory in %advance, and thus 793 * prevent a possible reallocation of memory and copying of %string 794 * data. 795 */ 796 void 797 reserve(size_type __res_arg = 0); 798 799 /** 800 * Erases the string, making it empty. 801 */ 802 void 803 clear() _GLIBCXX_NOEXCEPT 804 { _M_mutate(0, this->size(), 0); } 805 806 /** 807 * Returns true if the %string is empty. Equivalent to 808 * <code>*this == ""</code>. 809 */ 810 bool 811 empty() const _GLIBCXX_NOEXCEPT 812 { return this->size() == 0; } 813 814 // Element access: 815 /** 816 * @brief Subscript access to the data contained in the %string. 817 * @param __pos The index of the character to access. 818 * @return Read-only (constant) reference to the character. 819 * 820 * This operator allows for easy, array-style, data access. 821 * Note that data access with this operator is unchecked and 822 * out_of_range lookups are not defined. (For checked lookups 823 * see at().) 824 */ 825 const_reference 826 operator[] (size_type __pos) const 827 { 828 _GLIBCXX_DEBUG_ASSERT(__pos <= size()); 829 return _M_data()[__pos]; 830 } 831 832 /** 833 * @brief Subscript access to the data contained in the %string. 834 * @param __pos The index of the character to access. 835 * @return Read/write reference to the character. 836 * 837 * This operator allows for easy, array-style, data access. 838 * Note that data access with this operator is unchecked and 839 * out_of_range lookups are not defined. (For checked lookups 840 * see at().) Unshares the string. 841 */ 842 reference 843 operator[](size_type __pos) 844 { 845 // allow pos == size() as v3 extension: 846 _GLIBCXX_DEBUG_ASSERT(__pos <= size()); 847 // but be strict in pedantic mode: 848 _GLIBCXX_DEBUG_PEDASSERT(__pos < size()); 849 _M_leak(); 850 return _M_data()[__pos]; 851 } 852 853 /** 854 * @brief Provides access to the data contained in the %string. 855 * @param __n The index of the character to access. 856 * @return Read-only (const) reference to the character. 857 * @throw std::out_of_range If @a n is an invalid index. 858 * 859 * This function provides for safer data access. The parameter is 860 * first checked that it is in the range of the string. The function 861 * throws out_of_range if the check fails. 862 */ 863 const_reference 864 at(size_type __n) const 865 { 866 if (__n >= this->size()) 867 __throw_out_of_range(__N("basic_string::at")); 868 return _M_data()[__n]; 869 } 870 871 /** 872 * @brief Provides access to the data contained in the %string. 873 * @param __n The index of the character to access. 874 * @return Read/write reference to the character. 875 * @throw std::out_of_range If @a n is an invalid index. 876 * 877 * This function provides for safer data access. The parameter is 878 * first checked that it is in the range of the string. The function 879 * throws out_of_range if the check fails. Success results in 880 * unsharing the string. 881 */ 882 reference 883 at(size_type __n) 884 { 885 if (__n >= size()) 886 __throw_out_of_range(__N("basic_string::at")); 887 _M_leak(); 888 return _M_data()[__n]; 889 } 890 891 #if __cplusplus >= 201103L 892 /** 893 * Returns a read/write reference to the data at the first 894 * element of the %string. 895 */ 896 reference 897 front() 898 { return operator[](0); } 899 900 /** 901 * Returns a read-only (constant) reference to the data at the first 902 * element of the %string. 903 */ 904 const_reference 905 front() const 906 { return operator[](0); } 907 908 /** 909 * Returns a read/write reference to the data at the last 910 * element of the %string. 911 */ 912 reference 913 back() 914 { return operator[](this->size() - 1); } 915 916 /** 917 * Returns a read-only (constant) reference to the data at the 918 * last element of the %string. 919 */ 920 const_reference 921 back() const 922 { return operator[](this->size() - 1); } 923 #endif 924 925 // Modifiers: 926 /** 927 * @brief Append a string to this string. 928 * @param __str The string to append. 929 * @return Reference to this string. 930 */ 931 basic_string& 932 operator+=(const basic_string& __str) 933 { return this->append(__str); } 934 935 /** 936 * @brief Append a C string. 937 * @param __s The C string to append. 938 * @return Reference to this string. 939 */ 940 basic_string& 941 operator+=(const _CharT* __s) 942 { return this->append(__s); } 943 944 /** 945 * @brief Append a character. 946 * @param __c The character to append. 947 * @return Reference to this string. 948 */ 949 basic_string& 950 operator+=(_CharT __c) 951 { 952 this->push_back(__c); 953 return *this; 954 } 955 956 #if __cplusplus >= 201103L 957 /** 958 * @brief Append an initializer_list of characters. 959 * @param __l The initializer_list of characters to be appended. 960 * @return Reference to this string. 961 */ 962 basic_string& 963 operator+=(initializer_list<_CharT> __l) 964 { return this->append(__l.begin(), __l.size()); } 965 #endif // C++11 966 967 /** 968 * @brief Append a string to this string. 969 * @param __str The string to append. 970 * @return Reference to this string. 971 */ 972 basic_string& 973 append(const basic_string& __str); 974 975 /** 976 * @brief Append a substring. 977 * @param __str The string to append. 978 * @param __pos Index of the first character of str to append. 979 * @param __n The number of characters to append. 980 * @return Reference to this string. 981 * @throw std::out_of_range if @a __pos is not a valid index. 982 * 983 * This function appends @a __n characters from @a __str 984 * starting at @a __pos to this string. If @a __n is is larger 985 * than the number of available characters in @a __str, the 986 * remainder of @a __str is appended. 987 */ 988 basic_string& 989 append(const basic_string& __str, size_type __pos, size_type __n); 990 991 /** 992 * @brief Append a C substring. 993 * @param __s The C string to append. 994 * @param __n The number of characters to append. 995 * @return Reference to this string. 996 */ 997 basic_string& 998 append(const _CharT* __s, size_type __n); 999 1000 /** 1001 * @brief Append a C string. 1002 * @param __s The C string to append. 1003 * @return Reference to this string. 1004 */ 1005 basic_string& 1006 append(const _CharT* __s) 1007 { 1008 __glibcxx_requires_string(__s); 1009 return this->append(__s, traits_type::length(__s)); 1010 } 1011 1012 /** 1013 * @brief Append multiple characters. 1014 * @param __n The number of characters to append. 1015 * @param __c The character to use. 1016 * @return Reference to this string. 1017 * 1018 * Appends __n copies of __c to this string. 1019 */ 1020 basic_string& 1021 append(size_type __n, _CharT __c); 1022 1023 #if __cplusplus >= 201103L 1024 /** 1025 * @brief Append an initializer_list of characters. 1026 * @param __l The initializer_list of characters to append. 1027 * @return Reference to this string. 1028 */ 1029 basic_string& 1030 append(initializer_list<_CharT> __l) 1031 { return this->append(__l.begin(), __l.size()); } 1032 #endif // C++11 1033 1034 /** 1035 * @brief Append a range of characters. 1036 * @param __first Iterator referencing the first character to append. 1037 * @param __last Iterator marking the end of the range. 1038 * @return Reference to this string. 1039 * 1040 * Appends characters in the range [__first,__last) to this string. 1041 */ 1042 template<class _InputIterator> 1043 basic_string& 1044 append(_InputIterator __first, _InputIterator __last) 1045 { return this->replace(_M_iend(), _M_iend(), __first, __last); } 1046 1047 /** 1048 * @brief Append a single character. 1049 * @param __c Character to append. 1050 */ 1051 void 1052 push_back(_CharT __c) 1053 { 1054 const size_type __len = 1 + this->size(); 1055 if (__len > this->capacity() || _M_rep()->_M_is_shared()) 1056 this->reserve(__len); 1057 traits_type::assign(_M_data()[this->size()], __c); 1058 _M_rep()->_M_set_length_and_sharable(__len); 1059 } 1060 1061 /** 1062 * @brief Set value to contents of another string. 1063 * @param __str Source string to use. 1064 * @return Reference to this string. 1065 */ 1066 basic_string& 1067 assign(const basic_string& __str); 1068 1069 #if __cplusplus >= 201103L 1070 /** 1071 * @brief Set value to contents of another string. 1072 * @param __str Source string to use. 1073 * @return Reference to this string. 1074 * 1075 * This function sets this string to the exact contents of @a __str. 1076 * @a __str is a valid, but unspecified string. 1077 */ 1078 basic_string& 1079 assign(basic_string&& __str) 1080 { 1081 this->swap(__str); 1082 return *this; 1083 } 1084 #endif // C++11 1085 1086 /** 1087 * @brief Set value to a substring of a string. 1088 * @param __str The string to use. 1089 * @param __pos Index of the first character of str. 1090 * @param __n Number of characters to use. 1091 * @return Reference to this string. 1092 * @throw std::out_of_range if @a pos is not a valid index. 1093 * 1094 * This function sets this string to the substring of @a __str 1095 * consisting of @a __n characters at @a __pos. If @a __n is 1096 * is larger than the number of available characters in @a 1097 * __str, the remainder of @a __str is used. 1098 */ 1099 basic_string& 1100 assign(const basic_string& __str, size_type __pos, size_type __n) 1101 { return this->assign(__str._M_data() 1102 + __str._M_check(__pos, "basic_string::assign"), 1103 __str._M_limit(__pos, __n)); } 1104 1105 /** 1106 * @brief Set value to a C substring. 1107 * @param __s The C string to use. 1108 * @param __n Number of characters to use. 1109 * @return Reference to this string. 1110 * 1111 * This function sets the value of this string to the first @a __n 1112 * characters of @a __s. If @a __n is is larger than the number of 1113 * available characters in @a __s, the remainder of @a __s is used. 1114 */ 1115 basic_string& 1116 assign(const _CharT* __s, size_type __n); 1117 1118 /** 1119 * @brief Set value to contents of a C string. 1120 * @param __s The C string to use. 1121 * @return Reference to this string. 1122 * 1123 * This function sets the value of this string to the value of @a __s. 1124 * The data is copied, so there is no dependence on @a __s once the 1125 * function returns. 1126 */ 1127 basic_string& 1128 assign(const _CharT* __s) 1129 { 1130 __glibcxx_requires_string(__s); 1131 return this->assign(__s, traits_type::length(__s)); 1132 } 1133 1134 /** 1135 * @brief Set value to multiple characters. 1136 * @param __n Length of the resulting string. 1137 * @param __c The character to use. 1138 * @return Reference to this string. 1139 * 1140 * This function sets the value of this string to @a __n copies of 1141 * character @a __c. 1142 */ 1143 basic_string& 1144 assign(size_type __n, _CharT __c) 1145 { return _M_replace_aux(size_type(0), this->size(), __n, __c); } 1146 1147 /** 1148 * @brief Set value to a range of characters. 1149 * @param __first Iterator referencing the first character to append. 1150 * @param __last Iterator marking the end of the range. 1151 * @return Reference to this string. 1152 * 1153 * Sets value of string to characters in the range [__first,__last). 1154 */ 1155 template<class _InputIterator> 1156 basic_string& 1157 assign(_InputIterator __first, _InputIterator __last) 1158 { return this->replace(_M_ibegin(), _M_iend(), __first, __last); } 1159 1160 #if __cplusplus >= 201103L 1161 /** 1162 * @brief Set value to an initializer_list of characters. 1163 * @param __l The initializer_list of characters to assign. 1164 * @return Reference to this string. 1165 */ 1166 basic_string& 1167 assign(initializer_list<_CharT> __l) 1168 { return this->assign(__l.begin(), __l.size()); } 1169 #endif // C++11 1170 1171 /** 1172 * @brief Insert multiple characters. 1173 * @param __p Iterator referencing location in string to insert at. 1174 * @param __n Number of characters to insert 1175 * @param __c The character to insert. 1176 * @throw std::length_error If new length exceeds @c max_size(). 1177 * 1178 * Inserts @a __n copies of character @a __c starting at the 1179 * position referenced by iterator @a __p. If adding 1180 * characters causes the length to exceed max_size(), 1181 * length_error is thrown. The value of the string doesn't 1182 * change if an error is thrown. 1183 */ 1184 void 1185 insert(iterator __p, size_type __n, _CharT __c) 1186 { this->replace(__p, __p, __n, __c); } 1187 1188 /** 1189 * @brief Insert a range of characters. 1190 * @param __p Iterator referencing location in string to insert at. 1191 * @param __beg Start of range. 1192 * @param __end End of range. 1193 * @throw std::length_error If new length exceeds @c max_size(). 1194 * 1195 * Inserts characters in range [__beg,__end). If adding 1196 * characters causes the length to exceed max_size(), 1197 * length_error is thrown. The value of the string doesn't 1198 * change if an error is thrown. 1199 */ 1200 template<class _InputIterator> 1201 void 1202 insert(iterator __p, _InputIterator __beg, _InputIterator __end) 1203 { this->replace(__p, __p, __beg, __end); } 1204 1205 #if __cplusplus >= 201103L 1206 /** 1207 * @brief Insert an initializer_list of characters. 1208 * @param __p Iterator referencing location in string to insert at. 1209 * @param __l The initializer_list of characters to insert. 1210 * @throw std::length_error If new length exceeds @c max_size(). 1211 */ 1212 void 1213 insert(iterator __p, initializer_list<_CharT> __l) 1214 { 1215 _GLIBCXX_DEBUG_PEDASSERT(__p >= _M_ibegin() && __p <= _M_iend()); 1216 this->insert(__p - _M_ibegin(), __l.begin(), __l.size()); 1217 } 1218 #endif // C++11 1219 1220 /** 1221 * @brief Insert value of a string. 1222 * @param __pos1 Iterator referencing location in string to insert at. 1223 * @param __str The string to insert. 1224 * @return Reference to this string. 1225 * @throw std::length_error If new length exceeds @c max_size(). 1226 * 1227 * Inserts value of @a __str starting at @a __pos1. If adding 1228 * characters causes the length to exceed max_size(), 1229 * length_error is thrown. The value of the string doesn't 1230 * change if an error is thrown. 1231 */ 1232 basic_string& 1233 insert(size_type __pos1, const basic_string& __str) 1234 { return this->insert(__pos1, __str, size_type(0), __str.size()); } 1235 1236 /** 1237 * @brief Insert a substring. 1238 * @param __pos1 Iterator referencing location in string to insert at. 1239 * @param __str The string to insert. 1240 * @param __pos2 Start of characters in str to insert. 1241 * @param __n Number of characters to insert. 1242 * @return Reference to this string. 1243 * @throw std::length_error If new length exceeds @c max_size(). 1244 * @throw std::out_of_range If @a pos1 > size() or 1245 * @a __pos2 > @a str.size(). 1246 * 1247 * Starting at @a pos1, insert @a __n character of @a __str 1248 * beginning with @a __pos2. If adding characters causes the 1249 * length to exceed max_size(), length_error is thrown. If @a 1250 * __pos1 is beyond the end of this string or @a __pos2 is 1251 * beyond the end of @a __str, out_of_range is thrown. The 1252 * value of the string doesn't change if an error is thrown. 1253 */ 1254 basic_string& 1255 insert(size_type __pos1, const basic_string& __str, 1256 size_type __pos2, size_type __n) 1257 { return this->insert(__pos1, __str._M_data() 1258 + __str._M_check(__pos2, "basic_string::insert"), 1259 __str._M_limit(__pos2, __n)); } 1260 1261 /** 1262 * @brief Insert a C substring. 1263 * @param __pos Iterator referencing location in string to insert at. 1264 * @param __s The C string to insert. 1265 * @param __n The number of characters to insert. 1266 * @return Reference to this string. 1267 * @throw std::length_error If new length exceeds @c max_size(). 1268 * @throw std::out_of_range If @a __pos is beyond the end of this 1269 * string. 1270 * 1271 * Inserts the first @a __n characters of @a __s starting at @a 1272 * __pos. If adding characters causes the length to exceed 1273 * max_size(), length_error is thrown. If @a __pos is beyond 1274 * end(), out_of_range is thrown. The value of the string 1275 * doesn't change if an error is thrown. 1276 */ 1277 basic_string& 1278 insert(size_type __pos, const _CharT* __s, size_type __n); 1279 1280 /** 1281 * @brief Insert a C string. 1282 * @param __pos Iterator referencing location in string to insert at. 1283 * @param __s The C string to insert. 1284 * @return Reference to this string. 1285 * @throw std::length_error If new length exceeds @c max_size(). 1286 * @throw std::out_of_range If @a pos is beyond the end of this 1287 * string. 1288 * 1289 * Inserts the first @a n characters of @a __s starting at @a __pos. If 1290 * adding characters causes the length to exceed max_size(), 1291 * length_error is thrown. If @a __pos is beyond end(), out_of_range is 1292 * thrown. The value of the string doesn't change if an error is 1293 * thrown. 1294 */ 1295 basic_string& 1296 insert(size_type __pos, const _CharT* __s) 1297 { 1298 __glibcxx_requires_string(__s); 1299 return this->insert(__pos, __s, traits_type::length(__s)); 1300 } 1301 1302 /** 1303 * @brief Insert multiple characters. 1304 * @param __pos Index in string to insert at. 1305 * @param __n Number of characters to insert 1306 * @param __c The character to insert. 1307 * @return Reference to this string. 1308 * @throw std::length_error If new length exceeds @c max_size(). 1309 * @throw std::out_of_range If @a __pos is beyond the end of this 1310 * string. 1311 * 1312 * Inserts @a __n copies of character @a __c starting at index 1313 * @a __pos. If adding characters causes the length to exceed 1314 * max_size(), length_error is thrown. If @a __pos > length(), 1315 * out_of_range is thrown. The value of the string doesn't 1316 * change if an error is thrown. 1317 */ 1318 basic_string& 1319 insert(size_type __pos, size_type __n, _CharT __c) 1320 { return _M_replace_aux(_M_check(__pos, "basic_string::insert"), 1321 size_type(0), __n, __c); } 1322 1323 /** 1324 * @brief Insert one character. 1325 * @param __p Iterator referencing position in string to insert at. 1326 * @param __c The character to insert. 1327 * @return Iterator referencing newly inserted char. 1328 * @throw std::length_error If new length exceeds @c max_size(). 1329 * 1330 * Inserts character @a __c at position referenced by @a __p. 1331 * If adding character causes the length to exceed max_size(), 1332 * length_error is thrown. If @a __p is beyond end of string, 1333 * out_of_range is thrown. The value of the string doesn't 1334 * change if an error is thrown. 1335 */ 1336 iterator 1337 insert(iterator __p, _CharT __c) 1338 { 1339 _GLIBCXX_DEBUG_PEDASSERT(__p >= _M_ibegin() && __p <= _M_iend()); 1340 const size_type __pos = __p - _M_ibegin(); 1341 _M_replace_aux(__pos, size_type(0), size_type(1), __c); 1342 _M_rep()->_M_set_leaked(); 1343 return iterator(_M_data() + __pos); 1344 } 1345 1346 /** 1347 * @brief Remove characters. 1348 * @param __pos Index of first character to remove (default 0). 1349 * @param __n Number of characters to remove (default remainder). 1350 * @return Reference to this string. 1351 * @throw std::out_of_range If @a pos is beyond the end of this 1352 * string. 1353 * 1354 * Removes @a __n characters from this string starting at @a 1355 * __pos. The length of the string is reduced by @a __n. If 1356 * there are < @a __n characters to remove, the remainder of 1357 * the string is truncated. If @a __p is beyond end of string, 1358 * out_of_range is thrown. The value of the string doesn't 1359 * change if an error is thrown. 1360 */ 1361 basic_string& 1362 erase(size_type __pos = 0, size_type __n = npos) 1363 { 1364 _M_mutate(_M_check(__pos, "basic_string::erase"), 1365 _M_limit(__pos, __n), size_type(0)); 1366 return *this; 1367 } 1368 1369 /** 1370 * @brief Remove one character. 1371 * @param __position Iterator referencing the character to remove. 1372 * @return iterator referencing same location after removal. 1373 * 1374 * Removes the character at @a __position from this string. The value 1375 * of the string doesn't change if an error is thrown. 1376 */ 1377 iterator 1378 erase(iterator __position) 1379 { 1380 _GLIBCXX_DEBUG_PEDASSERT(__position >= _M_ibegin() 1381 && __position < _M_iend()); 1382 const size_type __pos = __position - _M_ibegin(); 1383 _M_mutate(__pos, size_type(1), size_type(0)); 1384 _M_rep()->_M_set_leaked(); 1385 return iterator(_M_data() + __pos); 1386 } 1387 1388 /** 1389 * @brief Remove a range of characters. 1390 * @param __first Iterator referencing the first character to remove. 1391 * @param __last Iterator referencing the end of the range. 1392 * @return Iterator referencing location of first after removal. 1393 * 1394 * Removes the characters in the range [first,last) from this string. 1395 * The value of the string doesn't change if an error is thrown. 1396 */ 1397 iterator 1398 erase(iterator __first, iterator __last); 1399 1400 #if __cplusplus >= 201103L 1401 /** 1402 * @brief Remove the last character. 1403 * 1404 * The string must be non-empty. 1405 */ 1406 void 1407 pop_back() 1408 { erase(size()-1, 1); } 1409 #endif // C++11 1410 1411 /** 1412 * @brief Replace characters with value from another string. 1413 * @param __pos Index of first character to replace. 1414 * @param __n Number of characters to be replaced. 1415 * @param __str String to insert. 1416 * @return Reference to this string. 1417 * @throw std::out_of_range If @a pos is beyond the end of this 1418 * string. 1419 * @throw std::length_error If new length exceeds @c max_size(). 1420 * 1421 * Removes the characters in the range [__pos,__pos+__n) from 1422 * this string. In place, the value of @a __str is inserted. 1423 * If @a __pos is beyond end of string, out_of_range is thrown. 1424 * If the length of the result exceeds max_size(), length_error 1425 * is thrown. The value of the string doesn't change if an 1426 * error is thrown. 1427 */ 1428 basic_string& 1429 replace(size_type __pos, size_type __n, const basic_string& __str) 1430 { return this->replace(__pos, __n, __str._M_data(), __str.size()); } 1431 1432 /** 1433 * @brief Replace characters with value from another string. 1434 * @param __pos1 Index of first character to replace. 1435 * @param __n1 Number of characters to be replaced. 1436 * @param __str String to insert. 1437 * @param __pos2 Index of first character of str to use. 1438 * @param __n2 Number of characters from str to use. 1439 * @return Reference to this string. 1440 * @throw std::out_of_range If @a __pos1 > size() or @a __pos2 > 1441 * __str.size(). 1442 * @throw std::length_error If new length exceeds @c max_size(). 1443 * 1444 * Removes the characters in the range [__pos1,__pos1 + n) from this 1445 * string. In place, the value of @a __str is inserted. If @a __pos is 1446 * beyond end of string, out_of_range is thrown. If the length of the 1447 * result exceeds max_size(), length_error is thrown. The value of the 1448 * string doesn't change if an error is thrown. 1449 */ 1450 basic_string& 1451 replace(size_type __pos1, size_type __n1, const basic_string& __str, 1452 size_type __pos2, size_type __n2) 1453 { return this->replace(__pos1, __n1, __str._M_data() 1454 + __str._M_check(__pos2, "basic_string::replace"), 1455 __str._M_limit(__pos2, __n2)); } 1456 1457 /** 1458 * @brief Replace characters with value of a C substring. 1459 * @param __pos Index of first character to replace. 1460 * @param __n1 Number of characters to be replaced. 1461 * @param __s C string to insert. 1462 * @param __n2 Number of characters from @a s to use. 1463 * @return Reference to this string. 1464 * @throw std::out_of_range If @a pos1 > size(). 1465 * @throw std::length_error If new length exceeds @c max_size(). 1466 * 1467 * Removes the characters in the range [__pos,__pos + __n1) 1468 * from this string. In place, the first @a __n2 characters of 1469 * @a __s are inserted, or all of @a __s if @a __n2 is too large. If 1470 * @a __pos is beyond end of string, out_of_range is thrown. If 1471 * the length of result exceeds max_size(), length_error is 1472 * thrown. The value of the string doesn't change if an error 1473 * is thrown. 1474 */ 1475 basic_string& 1476 replace(size_type __pos, size_type __n1, const _CharT* __s, 1477 size_type __n2); 1478 1479 /** 1480 * @brief Replace characters with value of a C string. 1481 * @param __pos Index of first character to replace. 1482 * @param __n1 Number of characters to be replaced. 1483 * @param __s C string to insert. 1484 * @return Reference to this string. 1485 * @throw std::out_of_range If @a pos > size(). 1486 * @throw std::length_error If new length exceeds @c max_size(). 1487 * 1488 * Removes the characters in the range [__pos,__pos + __n1) 1489 * from this string. In place, the characters of @a __s are 1490 * inserted. If @a __pos is beyond end of string, out_of_range 1491 * is thrown. If the length of result exceeds max_size(), 1492 * length_error is thrown. The value of the string doesn't 1493 * change if an error is thrown. 1494 */ 1495 basic_string& 1496 replace(size_type __pos, size_type __n1, const _CharT* __s) 1497 { 1498 __glibcxx_requires_string(__s); 1499 return this->replace(__pos, __n1, __s, traits_type::length(__s)); 1500 } 1501 1502 /** 1503 * @brief Replace characters with multiple characters. 1504 * @param __pos Index of first character to replace. 1505 * @param __n1 Number of characters to be replaced. 1506 * @param __n2 Number of characters to insert. 1507 * @param __c Character to insert. 1508 * @return Reference to this string. 1509 * @throw std::out_of_range If @a __pos > size(). 1510 * @throw std::length_error If new length exceeds @c max_size(). 1511 * 1512 * Removes the characters in the range [pos,pos + n1) from this 1513 * string. In place, @a __n2 copies of @a __c are inserted. 1514 * If @a __pos is beyond end of string, out_of_range is thrown. 1515 * If the length of result exceeds max_size(), length_error is 1516 * thrown. The value of the string doesn't change if an error 1517 * is thrown. 1518 */ 1519 basic_string& 1520 replace(size_type __pos, size_type __n1, size_type __n2, _CharT __c) 1521 { return _M_replace_aux(_M_check(__pos, "basic_string::replace"), 1522 _M_limit(__pos, __n1), __n2, __c); } 1523 1524 /** 1525 * @brief Replace range of characters with string. 1526 * @param __i1 Iterator referencing start of range to replace. 1527 * @param __i2 Iterator referencing end of range to replace. 1528 * @param __str String value to insert. 1529 * @return Reference to this string. 1530 * @throw std::length_error If new length exceeds @c max_size(). 1531 * 1532 * Removes the characters in the range [__i1,__i2). In place, 1533 * the value of @a __str is inserted. If the length of result 1534 * exceeds max_size(), length_error is thrown. The value of 1535 * the string doesn't change if an error is thrown. 1536 */ 1537 basic_string& 1538 replace(iterator __i1, iterator __i2, const basic_string& __str) 1539 { return this->replace(__i1, __i2, __str._M_data(), __str.size()); } 1540 1541 /** 1542 * @brief Replace range of characters with C substring. 1543 * @param __i1 Iterator referencing start of range to replace. 1544 * @param __i2 Iterator referencing end of range to replace. 1545 * @param __s C string value to insert. 1546 * @param __n Number of characters from s to insert. 1547 * @return Reference to this string. 1548 * @throw std::length_error If new length exceeds @c max_size(). 1549 * 1550 * Removes the characters in the range [__i1,__i2). In place, 1551 * the first @a __n characters of @a __s are inserted. If the 1552 * length of result exceeds max_size(), length_error is thrown. 1553 * The value of the string doesn't change if an error is 1554 * thrown. 1555 */ 1556 basic_string& 1557 replace(iterator __i1, iterator __i2, const _CharT* __s, size_type __n) 1558 { 1559 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1560 && __i2 <= _M_iend()); 1561 return this->replace(__i1 - _M_ibegin(), __i2 - __i1, __s, __n); 1562 } 1563 1564 /** 1565 * @brief Replace range of characters with C string. 1566 * @param __i1 Iterator referencing start of range to replace. 1567 * @param __i2 Iterator referencing end of range to replace. 1568 * @param __s C string value to insert. 1569 * @return Reference to this string. 1570 * @throw std::length_error If new length exceeds @c max_size(). 1571 * 1572 * Removes the characters in the range [__i1,__i2). In place, 1573 * the characters of @a __s are inserted. If the length of 1574 * result exceeds max_size(), length_error is thrown. The 1575 * value of the string doesn't change if an error is thrown. 1576 */ 1577 basic_string& 1578 replace(iterator __i1, iterator __i2, const _CharT* __s) 1579 { 1580 __glibcxx_requires_string(__s); 1581 return this->replace(__i1, __i2, __s, traits_type::length(__s)); 1582 } 1583 1584 /** 1585 * @brief Replace range of characters with multiple characters 1586 * @param __i1 Iterator referencing start of range to replace. 1587 * @param __i2 Iterator referencing end of range to replace. 1588 * @param __n Number of characters to insert. 1589 * @param __c Character to insert. 1590 * @return Reference to this string. 1591 * @throw std::length_error If new length exceeds @c max_size(). 1592 * 1593 * Removes the characters in the range [__i1,__i2). In place, 1594 * @a __n copies of @a __c are inserted. If the length of 1595 * result exceeds max_size(), length_error is thrown. The 1596 * value of the string doesn't change if an error is thrown. 1597 */ 1598 basic_string& 1599 replace(iterator __i1, iterator __i2, size_type __n, _CharT __c) 1600 { 1601 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1602 && __i2 <= _M_iend()); 1603 return _M_replace_aux(__i1 - _M_ibegin(), __i2 - __i1, __n, __c); 1604 } 1605 1606 /** 1607 * @brief Replace range of characters with range. 1608 * @param __i1 Iterator referencing start of range to replace. 1609 * @param __i2 Iterator referencing end of range to replace. 1610 * @param __k1 Iterator referencing start of range to insert. 1611 * @param __k2 Iterator referencing end of range to insert. 1612 * @return Reference to this string. 1613 * @throw std::length_error If new length exceeds @c max_size(). 1614 * 1615 * Removes the characters in the range [__i1,__i2). In place, 1616 * characters in the range [__k1,__k2) are inserted. If the 1617 * length of result exceeds max_size(), length_error is thrown. 1618 * The value of the string doesn't change if an error is 1619 * thrown. 1620 */ 1621 template<class _InputIterator> 1622 basic_string& 1623 replace(iterator __i1, iterator __i2, 1624 _InputIterator __k1, _InputIterator __k2) 1625 { 1626 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1627 && __i2 <= _M_iend()); 1628 __glibcxx_requires_valid_range(__k1, __k2); 1629 typedef typename std::__is_integer<_InputIterator>::__type _Integral; 1630 return _M_replace_dispatch(__i1, __i2, __k1, __k2, _Integral()); 1631 } 1632 1633 // Specializations for the common case of pointer and iterator: 1634 // useful to avoid the overhead of temporary buffering in _M_replace. 1635 basic_string& 1636 replace(iterator __i1, iterator __i2, _CharT* __k1, _CharT* __k2) 1637 { 1638 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1639 && __i2 <= _M_iend()); 1640 __glibcxx_requires_valid_range(__k1, __k2); 1641 return this->replace(__i1 - _M_ibegin(), __i2 - __i1, 1642 __k1, __k2 - __k1); 1643 } 1644 1645 basic_string& 1646 replace(iterator __i1, iterator __i2, 1647 const _CharT* __k1, const _CharT* __k2) 1648 { 1649 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1650 && __i2 <= _M_iend()); 1651 __glibcxx_requires_valid_range(__k1, __k2); 1652 return this->replace(__i1 - _M_ibegin(), __i2 - __i1, 1653 __k1, __k2 - __k1); 1654 } 1655 1656 basic_string& 1657 replace(iterator __i1, iterator __i2, iterator __k1, iterator __k2) 1658 { 1659 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1660 && __i2 <= _M_iend()); 1661 __glibcxx_requires_valid_range(__k1, __k2); 1662 return this->replace(__i1 - _M_ibegin(), __i2 - __i1, 1663 __k1.base(), __k2 - __k1); 1664 } 1665 1666 basic_string& 1667 replace(iterator __i1, iterator __i2, 1668 const_iterator __k1, const_iterator __k2) 1669 { 1670 _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 1671 && __i2 <= _M_iend()); 1672 __glibcxx_requires_valid_range(__k1, __k2); 1673 return this->replace(__i1 - _M_ibegin(), __i2 - __i1, 1674 __k1.base(), __k2 - __k1); 1675 } 1676 1677 #if __cplusplus >= 201103L 1678 /** 1679 * @brief Replace range of characters with initializer_list. 1680 * @param __i1 Iterator referencing start of range to replace. 1681 * @param __i2 Iterator referencing end of range to replace. 1682 * @param __l The initializer_list of characters to insert. 1683 * @return Reference to this string. 1684 * @throw std::length_error If new length exceeds @c max_size(). 1685 * 1686 * Removes the characters in the range [__i1,__i2). In place, 1687 * characters in the range [__k1,__k2) are inserted. If the 1688 * length of result exceeds max_size(), length_error is thrown. 1689 * The value of the string doesn't change if an error is 1690 * thrown. 1691 */ 1692 basic_string& replace(iterator __i1, iterator __i2, 1693 initializer_list<_CharT> __l) 1694 { return this->replace(__i1, __i2, __l.begin(), __l.end()); } 1695 #endif // C++11 1696 1697 private: 1698 template<class _Integer> 1699 basic_string& 1700 _M_replace_dispatch(iterator __i1, iterator __i2, _Integer __n, 1701 _Integer __val, __true_type) 1702 { return _M_replace_aux(__i1 - _M_ibegin(), __i2 - __i1, __n, __val); } 1703 1704 template<class _InputIterator> 1705 basic_string& 1706 _M_replace_dispatch(iterator __i1, iterator __i2, _InputIterator __k1, 1707 _InputIterator __k2, __false_type); 1708 1709 basic_string& 1710 _M_replace_aux(size_type __pos1, size_type __n1, size_type __n2, 1711 _CharT __c); 1712 1713 basic_string& 1714 _M_replace_safe(size_type __pos1, size_type __n1, const _CharT* __s, 1715 size_type __n2); 1716 1717 // _S_construct_aux is used to implement the 21.3.1 para 15 which 1718 // requires special behaviour if _InIter is an integral type 1719 template<class _InIterator> 1720 static _CharT* 1721 _S_construct_aux(_InIterator __beg, _InIterator __end, 1722 const _Alloc& __a, __false_type) 1723 { 1724 typedef typename iterator_traits<_InIterator>::iterator_category _Tag; 1725 return _S_construct(__beg, __end, __a, _Tag()); 1726 } 1727 1728 // _GLIBCXX_RESOLVE_LIB_DEFECTS 1729 // 438. Ambiguity in the "do the right thing" clause 1730 template<class _Integer> 1731 static _CharT* 1732 _S_construct_aux(_Integer __beg, _Integer __end, 1733 const _Alloc& __a, __true_type) 1734 { return _S_construct_aux_2(static_cast<size_type>(__beg), 1735 __end, __a); } 1736 1737 static _CharT* 1738 _S_construct_aux_2(size_type __req, _CharT __c, const _Alloc& __a) 1739 { return _S_construct(__req, __c, __a); } 1740 1741 template<class _InIterator> 1742 static _CharT* 1743 _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a) 1744 { 1745 typedef typename std::__is_integer<_InIterator>::__type _Integral; 1746 return _S_construct_aux(__beg, __end, __a, _Integral()); 1747 } 1748 1749 // For Input Iterators, used in istreambuf_iterators, etc. 1750 template<class _InIterator> 1751 static _CharT* 1752 _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a, 1753 input_iterator_tag); 1754 1755 // For forward_iterators up to random_access_iterators, used for 1756 // string::iterator, _CharT*, etc. 1757 template<class _FwdIterator> 1758 static _CharT* 1759 _S_construct(_FwdIterator __beg, _FwdIterator __end, const _Alloc& __a, 1760 forward_iterator_tag); 1761 1762 static _CharT* 1763 _S_construct(size_type __req, _CharT __c, const _Alloc& __a); 1764 1765 public: 1766 1767 /** 1768 * @brief Copy substring into C string. 1769 * @param __s C string to copy value into. 1770 * @param __n Number of characters to copy. 1771 * @param __pos Index of first character to copy. 1772 * @return Number of characters actually copied 1773 * @throw std::out_of_range If __pos > size(). 1774 * 1775 * Copies up to @a __n characters starting at @a __pos into the 1776 * C string @a __s. If @a __pos is %greater than size(), 1777 * out_of_range is thrown. 1778 */ 1779 size_type 1780 copy(_CharT* __s, size_type __n, size_type __pos = 0) const; 1781 1782 /** 1783 * @brief Swap contents with another string. 1784 * @param __s String to swap with. 1785 * 1786 * Exchanges the contents of this string with that of @a __s in constant 1787 * time. 1788 */ 1789 void 1790 swap(basic_string& __s); 1791 1792 // String operations: 1793 /** 1794 * @brief Return const pointer to null-terminated contents. 1795 * 1796 * This is a handle to internal data. Do not modify or dire things may 1797 * happen. 1798 */ 1799 const _CharT* 1800 c_str() const _GLIBCXX_NOEXCEPT 1801 { return _M_data(); } 1802 1803 /** 1804 * @brief Return const pointer to contents. 1805 * 1806 * This is a handle to internal data. Do not modify or dire things may 1807 * happen. 1808 */ 1809 const _CharT* 1810 data() const _GLIBCXX_NOEXCEPT 1811 { return _M_data(); } 1812 1813 /** 1814 * @brief Return copy of allocator used to construct this string. 1815 */ 1816 allocator_type 1817 get_allocator() const _GLIBCXX_NOEXCEPT 1818 { return _M_dataplus; } 1819 1820 /** 1821 * @brief Find position of a C substring. 1822 * @param __s C string to locate. 1823 * @param __pos Index of character to search from. 1824 * @param __n Number of characters from @a s to search for. 1825 * @return Index of start of first occurrence. 1826 * 1827 * Starting from @a __pos, searches forward for the first @a 1828 * __n characters in @a __s within this string. If found, 1829 * returns the index where it begins. If not found, returns 1830 * npos. 1831 */ 1832 size_type 1833 find(const _CharT* __s, size_type __pos, size_type __n) const; 1834 1835 /** 1836 * @brief Find position of a string. 1837 * @param __str String to locate. 1838 * @param __pos Index of character to search from (default 0). 1839 * @return Index of start of first occurrence. 1840 * 1841 * Starting from @a __pos, searches forward for value of @a __str within 1842 * this string. If found, returns the index where it begins. If not 1843 * found, returns npos. 1844 */ 1845 size_type 1846 find(const basic_string& __str, size_type __pos = 0) const 1847 _GLIBCXX_NOEXCEPT 1848 { return this->find(__str.data(), __pos, __str.size()); } 1849 1850 /** 1851 * @brief Find position of a C string. 1852 * @param __s C string to locate. 1853 * @param __pos Index of character to search from (default 0). 1854 * @return Index of start of first occurrence. 1855 * 1856 * Starting from @a __pos, searches forward for the value of @a 1857 * __s within this string. If found, returns the index where 1858 * it begins. If not found, returns npos. 1859 */ 1860 size_type 1861 find(const _CharT* __s, size_type __pos = 0) const 1862 { 1863 __glibcxx_requires_string(__s); 1864 return this->find(__s, __pos, traits_type::length(__s)); 1865 } 1866 1867 /** 1868 * @brief Find position of a character. 1869 * @param __c Character to locate. 1870 * @param __pos Index of character to search from (default 0). 1871 * @return Index of first occurrence. 1872 * 1873 * Starting from @a __pos, searches forward for @a __c within 1874 * this string. If found, returns the index where it was 1875 * found. If not found, returns npos. 1876 */ 1877 size_type 1878 find(_CharT __c, size_type __pos = 0) const _GLIBCXX_NOEXCEPT; 1879 1880 /** 1881 * @brief Find last position of a string. 1882 * @param __str String to locate. 1883 * @param __pos Index of character to search back from (default end). 1884 * @return Index of start of last occurrence. 1885 * 1886 * Starting from @a __pos, searches backward for value of @a 1887 * __str within this string. If found, returns the index where 1888 * it begins. If not found, returns npos. 1889 */ 1890 size_type 1891 rfind(const basic_string& __str, size_type __pos = npos) const 1892 _GLIBCXX_NOEXCEPT 1893 { return this->rfind(__str.data(), __pos, __str.size()); } 1894 1895 /** 1896 * @brief Find last position of a C substring. 1897 * @param __s C string to locate. 1898 * @param __pos Index of character to search back from. 1899 * @param __n Number of characters from s to search for. 1900 * @return Index of start of last occurrence. 1901 * 1902 * Starting from @a __pos, searches backward for the first @a 1903 * __n characters in @a __s within this string. If found, 1904 * returns the index where it begins. If not found, returns 1905 * npos. 1906 */ 1907 size_type 1908 rfind(const _CharT* __s, size_type __pos, size_type __n) const; 1909 1910 /** 1911 * @brief Find last position of a C string. 1912 * @param __s C string to locate. 1913 * @param __pos Index of character to start search at (default end). 1914 * @return Index of start of last occurrence. 1915 * 1916 * Starting from @a __pos, searches backward for the value of 1917 * @a __s within this string. If found, returns the index 1918 * where it begins. If not found, returns npos. 1919 */ 1920 size_type 1921 rfind(const _CharT* __s, size_type __pos = npos) const 1922 { 1923 __glibcxx_requires_string(__s); 1924 return this->rfind(__s, __pos, traits_type::length(__s)); 1925 } 1926 1927 /** 1928 * @brief Find last position of a character. 1929 * @param __c Character to locate. 1930 * @param __pos Index of character to search back from (default end). 1931 * @return Index of last occurrence. 1932 * 1933 * Starting from @a __pos, searches backward for @a __c within 1934 * this string. If found, returns the index where it was 1935 * found. If not found, returns npos. 1936 */ 1937 size_type 1938 rfind(_CharT __c, size_type __pos = npos) const _GLIBCXX_NOEXCEPT; 1939 1940 /** 1941 * @brief Find position of a character of string. 1942 * @param __str String containing characters to locate. 1943 * @param __pos Index of character to search from (default 0). 1944 * @return Index of first occurrence. 1945 * 1946 * Starting from @a __pos, searches forward for one of the 1947 * characters of @a __str within this string. If found, 1948 * returns the index where it was found. If not found, returns 1949 * npos. 1950 */ 1951 size_type 1952 find_first_of(const basic_string& __str, size_type __pos = 0) const 1953 _GLIBCXX_NOEXCEPT 1954 { return this->find_first_of(__str.data(), __pos, __str.size()); } 1955 1956 /** 1957 * @brief Find position of a character of C substring. 1958 * @param __s String containing characters to locate. 1959 * @param __pos Index of character to search from. 1960 * @param __n Number of characters from s to search for. 1961 * @return Index of first occurrence. 1962 * 1963 * Starting from @a __pos, searches forward for one of the 1964 * first @a __n characters of @a __s within this string. If 1965 * found, returns the index where it was found. If not found, 1966 * returns npos. 1967 */ 1968 size_type 1969 find_first_of(const _CharT* __s, size_type __pos, size_type __n) const; 1970 1971 /** 1972 * @brief Find position of a character of C string. 1973 * @param __s String containing characters to locate. 1974 * @param __pos Index of character to search from (default 0). 1975 * @return Index of first occurrence. 1976 * 1977 * Starting from @a __pos, searches forward for one of the 1978 * characters of @a __s within this string. If found, returns 1979 * the index where it was found. If not found, returns npos. 1980 */ 1981 size_type 1982 find_first_of(const _CharT* __s, size_type __pos = 0) const 1983 { 1984 __glibcxx_requires_string(__s); 1985 return this->find_first_of(__s, __pos, traits_type::length(__s)); 1986 } 1987 1988 /** 1989 * @brief Find position of a character. 1990 * @param __c Character to locate. 1991 * @param __pos Index of character to search from (default 0). 1992 * @return Index of first occurrence. 1993 * 1994 * Starting from @a __pos, searches forward for the character 1995 * @a __c within this string. If found, returns the index 1996 * where it was found. If not found, returns npos. 1997 * 1998 * Note: equivalent to find(__c, __pos). 1999 */ 2000 size_type 2001 find_first_of(_CharT __c, size_type __pos = 0) const _GLIBCXX_NOEXCEPT 2002 { return this->find(__c, __pos); } 2003 2004 /** 2005 * @brief Find last position of a character of string. 2006 * @param __str String containing characters to locate. 2007 * @param __pos Index of character to search back from (default end). 2008 * @return Index of last occurrence. 2009 * 2010 * Starting from @a __pos, searches backward for one of the 2011 * characters of @a __str within this string. If found, 2012 * returns the index where it was found. If not found, returns 2013 * npos. 2014 */ 2015 size_type 2016 find_last_of(const basic_string& __str, size_type __pos = npos) const 2017 _GLIBCXX_NOEXCEPT 2018 { return this->find_last_of(__str.data(), __pos, __str.size()); } 2019 2020 /** 2021 * @brief Find last position of a character of C substring. 2022 * @param __s C string containing characters to locate. 2023 * @param __pos Index of character to search back from. 2024 * @param __n Number of characters from s to search for. 2025 * @return Index of last occurrence. 2026 * 2027 * Starting from @a __pos, searches backward for one of the 2028 * first @a __n characters of @a __s within this string. If 2029 * found, returns the index where it was found. If not found, 2030 * returns npos. 2031 */ 2032 size_type 2033 find_last_of(const _CharT* __s, size_type __pos, size_type __n) const; 2034 2035 /** 2036 * @brief Find last position of a character of C string. 2037 * @param __s C string containing characters to locate. 2038 * @param __pos Index of character to search back from (default end). 2039 * @return Index of last occurrence. 2040 * 2041 * Starting from @a __pos, searches backward for one of the 2042 * characters of @a __s within this string. If found, returns 2043 * the index where it was found. If not found, returns npos. 2044 */ 2045 size_type 2046 find_last_of(const _CharT* __s, size_type __pos = npos) const 2047 { 2048 __glibcxx_requires_string(__s); 2049 return this->find_last_of(__s, __pos, traits_type::length(__s)); 2050 } 2051 2052 /** 2053 * @brief Find last position of a character. 2054 * @param __c Character to locate. 2055 * @param __pos Index of character to search back from (default end). 2056 * @return Index of last occurrence. 2057 * 2058 * Starting from @a __pos, searches backward for @a __c within 2059 * this string. If found, returns the index where it was 2060 * found. If not found, returns npos. 2061 * 2062 * Note: equivalent to rfind(__c, __pos). 2063 */ 2064 size_type 2065 find_last_of(_CharT __c, size_type __pos = npos) const _GLIBCXX_NOEXCEPT 2066 { return this->rfind(__c, __pos); } 2067 2068 /** 2069 * @brief Find position of a character not in string. 2070 * @param __str String containing characters to avoid. 2071 * @param __pos Index of character to search from (default 0). 2072 * @return Index of first occurrence. 2073 * 2074 * Starting from @a __pos, searches forward for a character not contained 2075 * in @a __str within this string. If found, returns the index where it 2076 * was found. If not found, returns npos. 2077 */ 2078 size_type 2079 find_first_not_of(const basic_string& __str, size_type __pos = 0) const 2080 _GLIBCXX_NOEXCEPT 2081 { return this->find_first_not_of(__str.data(), __pos, __str.size()); } 2082 2083 /** 2084 * @brief Find position of a character not in C substring. 2085 * @param __s C string containing characters to avoid. 2086 * @param __pos Index of character to search from. 2087 * @param __n Number of characters from __s to consider. 2088 * @return Index of first occurrence. 2089 * 2090 * Starting from @a __pos, searches forward for a character not 2091 * contained in the first @a __n characters of @a __s within 2092 * this string. If found, returns the index where it was 2093 * found. If not found, returns npos. 2094 */ 2095 size_type 2096 find_first_not_of(const _CharT* __s, size_type __pos, 2097 size_type __n) const; 2098 2099 /** 2100 * @brief Find position of a character not in C string. 2101 * @param __s C string containing characters to avoid. 2102 * @param __pos Index of character to search from (default 0). 2103 * @return Index of first occurrence. 2104 * 2105 * Starting from @a __pos, searches forward for a character not 2106 * contained in @a __s within this string. If found, returns 2107 * the index where it was found. If not found, returns npos. 2108 */ 2109 size_type 2110 find_first_not_of(const _CharT* __s, size_type __pos = 0) const 2111 { 2112 __glibcxx_requires_string(__s); 2113 return this->find_first_not_of(__s, __pos, traits_type::length(__s)); 2114 } 2115 2116 /** 2117 * @brief Find position of a different character. 2118 * @param __c Character to avoid. 2119 * @param __pos Index of character to search from (default 0). 2120 * @return Index of first occurrence. 2121 * 2122 * Starting from @a __pos, searches forward for a character 2123 * other than @a __c within this string. If found, returns the 2124 * index where it was found. If not found, returns npos. 2125 */ 2126 size_type 2127 find_first_not_of(_CharT __c, size_type __pos = 0) const 2128 _GLIBCXX_NOEXCEPT; 2129 2130 /** 2131 * @brief Find last position of a character not in string. 2132 * @param __str String containing characters to avoid. 2133 * @param __pos Index of character to search back from (default end). 2134 * @return Index of last occurrence. 2135 * 2136 * Starting from @a __pos, searches backward for a character 2137 * not contained in @a __str within this string. If found, 2138 * returns the index where it was found. If not found, returns 2139 * npos. 2140 */ 2141 size_type 2142 find_last_not_of(const basic_string& __str, size_type __pos = npos) const 2143 _GLIBCXX_NOEXCEPT 2144 { return this->find_last_not_of(__str.data(), __pos, __str.size()); } 2145 2146 /** 2147 * @brief Find last position of a character not in C substring. 2148 * @param __s C string containing characters to avoid. 2149 * @param __pos Index of character to search back from. 2150 * @param __n Number of characters from s to consider. 2151 * @return Index of last occurrence. 2152 * 2153 * Starting from @a __pos, searches backward for a character not 2154 * contained in the first @a __n characters of @a __s within this string. 2155 * If found, returns the index where it was found. If not found, 2156 * returns npos. 2157 */ 2158 size_type 2159 find_last_not_of(const _CharT* __s, size_type __pos, 2160 size_type __n) const; 2161 /** 2162 * @brief Find last position of a character not in C string. 2163 * @param __s C string containing characters to avoid. 2164 * @param __pos Index of character to search back from (default end). 2165 * @return Index of last occurrence. 2166 * 2167 * Starting from @a __pos, searches backward for a character 2168 * not contained in @a __s within this string. If found, 2169 * returns the index where it was found. If not found, returns 2170 * npos. 2171 */ 2172 size_type 2173 find_last_not_of(const _CharT* __s, size_type __pos = npos) const 2174 { 2175 __glibcxx_requires_string(__s); 2176 return this->find_last_not_of(__s, __pos, traits_type::length(__s)); 2177 } 2178 2179 /** 2180 * @brief Find last position of a different character. 2181 * @param __c Character to avoid. 2182 * @param __pos Index of character to search back from (default end). 2183 * @return Index of last occurrence. 2184 * 2185 * Starting from @a __pos, searches backward for a character other than 2186 * @a __c within this string. If found, returns the index where it was 2187 * found. If not found, returns npos. 2188 */ 2189 size_type 2190 find_last_not_of(_CharT __c, size_type __pos = npos) const 2191 _GLIBCXX_NOEXCEPT; 2192 2193 /** 2194 * @brief Get a substring. 2195 * @param __pos Index of first character (default 0). 2196 * @param __n Number of characters in substring (default remainder). 2197 * @return The new string. 2198 * @throw std::out_of_range If __pos > size(). 2199 * 2200 * Construct and return a new string using the @a __n 2201 * characters starting at @a __pos. If the string is too 2202 * short, use the remainder of the characters. If @a __pos is 2203 * beyond the end of the string, out_of_range is thrown. 2204 */ 2205 basic_string 2206 substr(size_type __pos = 0, size_type __n = npos) const 2207 { return basic_string(*this, 2208 _M_check(__pos, "basic_string::substr"), __n); } 2209 2210 /** 2211 * @brief Compare to a string. 2212 * @param __str String to compare against. 2213 * @return Integer < 0, 0, or > 0. 2214 * 2215 * Returns an integer < 0 if this string is ordered before @a 2216 * __str, 0 if their values are equivalent, or > 0 if this 2217 * string is ordered after @a __str. Determines the effective 2218 * length rlen of the strings to compare as the smallest of 2219 * size() and str.size(). The function then compares the two 2220 * strings by calling traits::compare(data(), str.data(),rlen). 2221 * If the result of the comparison is nonzero returns it, 2222 * otherwise the shorter one is ordered first. 2223 */ 2224 int 2225 compare(const basic_string& __str) const 2226 { 2227 const size_type __size = this->size(); 2228 const size_type __osize = __str.size(); 2229 const size_type __len = std::min(__size, __osize); 2230 2231 int __r = traits_type::compare(_M_data(), __str.data(), __len); 2232 if (!__r) 2233 __r = _S_compare(__size, __osize); 2234 return __r; 2235 } 2236 2237 /** 2238 * @brief Compare substring to a string. 2239 * @param __pos Index of first character of substring. 2240 * @param __n Number of characters in substring. 2241 * @param __str String to compare against. 2242 * @return Integer < 0, 0, or > 0. 2243 * 2244 * Form the substring of this string from the @a __n characters 2245 * starting at @a __pos. Returns an integer < 0 if the 2246 * substring is ordered before @a __str, 0 if their values are 2247 * equivalent, or > 0 if the substring is ordered after @a 2248 * __str. Determines the effective length rlen of the strings 2249 * to compare as the smallest of the length of the substring 2250 * and @a __str.size(). The function then compares the two 2251 * strings by calling 2252 * traits::compare(substring.data(),str.data(),rlen). If the 2253 * result of the comparison is nonzero returns it, otherwise 2254 * the shorter one is ordered first. 2255 */ 2256 int 2257 compare(size_type __pos, size_type __n, const basic_string& __str) const; 2258 2259 /** 2260 * @brief Compare substring to a substring. 2261 * @param __pos1 Index of first character of substring. 2262 * @param __n1 Number of characters in substring. 2263 * @param __str String to compare against. 2264 * @param __pos2 Index of first character of substring of str. 2265 * @param __n2 Number of characters in substring of str. 2266 * @return Integer < 0, 0, or > 0. 2267 * 2268 * Form the substring of this string from the @a __n1 2269 * characters starting at @a __pos1. Form the substring of @a 2270 * __str from the @a __n2 characters starting at @a __pos2. 2271 * Returns an integer < 0 if this substring is ordered before 2272 * the substring of @a __str, 0 if their values are equivalent, 2273 * or > 0 if this substring is ordered after the substring of 2274 * @a __str. Determines the effective length rlen of the 2275 * strings to compare as the smallest of the lengths of the 2276 * substrings. The function then compares the two strings by 2277 * calling 2278 * traits::compare(substring.data(),str.substr(pos2,n2).data(),rlen). 2279 * If the result of the comparison is nonzero returns it, 2280 * otherwise the shorter one is ordered first. 2281 */ 2282 int 2283 compare(size_type __pos1, size_type __n1, const basic_string& __str, 2284 size_type __pos2, size_type __n2) const; 2285 2286 /** 2287 * @brief Compare to a C string. 2288 * @param __s C string to compare against. 2289 * @return Integer < 0, 0, or > 0. 2290 * 2291 * Returns an integer < 0 if this string is ordered before @a __s, 0 if 2292 * their values are equivalent, or > 0 if this string is ordered after 2293 * @a __s. Determines the effective length rlen of the strings to 2294 * compare as the smallest of size() and the length of a string 2295 * constructed from @a __s. The function then compares the two strings 2296 * by calling traits::compare(data(),s,rlen). If the result of the 2297 * comparison is nonzero returns it, otherwise the shorter one is 2298 * ordered first. 2299 */ 2300 int 2301 compare(const _CharT* __s) const; 2302 2303 // _GLIBCXX_RESOLVE_LIB_DEFECTS 2304 // 5 String::compare specification questionable 2305 /** 2306 * @brief Compare substring to a C string. 2307 * @param __pos Index of first character of substring. 2308 * @param __n1 Number of characters in substring. 2309 * @param __s C string to compare against. 2310 * @return Integer < 0, 0, or > 0. 2311 * 2312 * Form the substring of this string from the @a __n1 2313 * characters starting at @a pos. Returns an integer < 0 if 2314 * the substring is ordered before @a __s, 0 if their values 2315 * are equivalent, or > 0 if the substring is ordered after @a 2316 * __s. Determines the effective length rlen of the strings to 2317 * compare as the smallest of the length of the substring and 2318 * the length of a string constructed from @a __s. The 2319 * function then compares the two string by calling 2320 * traits::compare(substring.data(),__s,rlen). If the result of 2321 * the comparison is nonzero returns it, otherwise the shorter 2322 * one is ordered first. 2323 */ 2324 int 2325 compare(size_type __pos, size_type __n1, const _CharT* __s) const; 2326 2327 /** 2328 * @brief Compare substring against a character %array. 2329 * @param __pos Index of first character of substring. 2330 * @param __n1 Number of characters in substring. 2331 * @param __s character %array to compare against. 2332 * @param __n2 Number of characters of s. 2333 * @return Integer < 0, 0, or > 0. 2334 * 2335 * Form the substring of this string from the @a __n1 2336 * characters starting at @a __pos. Form a string from the 2337 * first @a __n2 characters of @a __s. Returns an integer < 0 2338 * if this substring is ordered before the string from @a __s, 2339 * 0 if their values are equivalent, or > 0 if this substring 2340 * is ordered after the string from @a __s. Determines the 2341 * effective length rlen of the strings to compare as the 2342 * smallest of the length of the substring and @a __n2. The 2343 * function then compares the two strings by calling 2344 * traits::compare(substring.data(),s,rlen). If the result of 2345 * the comparison is nonzero returns it, otherwise the shorter 2346 * one is ordered first. 2347 * 2348 * NB: s must have at least n2 characters, '\\0' has 2349 * no special meaning. 2350 */ 2351 int 2352 compare(size_type __pos, size_type __n1, const _CharT* __s, 2353 size_type __n2) const; 2354 }; 2355 2356 // operator+ 2357 /** 2358 * @brief Concatenate two strings. 2359 * @param __lhs First string. 2360 * @param __rhs Last string. 2361 * @return New string with value of @a __lhs followed by @a __rhs. 2362 */ 2363 template<typename _CharT, typename _Traits, typename _Alloc> 2364 basic_string<_CharT, _Traits, _Alloc> 2365 operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2366 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2367 { 2368 basic_string<_CharT, _Traits, _Alloc> __str(__lhs); 2369 __str.append(__rhs); 2370 return __str; 2371 } 2372 2373 /** 2374 * @brief Concatenate C string and string. 2375 * @param __lhs First string. 2376 * @param __rhs Last string. 2377 * @return New string with value of @a __lhs followed by @a __rhs. 2378 */ 2379 template<typename _CharT, typename _Traits, typename _Alloc> 2380 basic_string<_CharT,_Traits,_Alloc> 2381 operator+(const _CharT* __lhs, 2382 const basic_string<_CharT,_Traits,_Alloc>& __rhs); 2383 2384 /** 2385 * @brief Concatenate character and string. 2386 * @param __lhs First string. 2387 * @param __rhs Last string. 2388 * @return New string with @a __lhs followed by @a __rhs. 2389 */ 2390 template<typename _CharT, typename _Traits, typename _Alloc> 2391 basic_string<_CharT,_Traits,_Alloc> 2392 operator+(_CharT __lhs, const basic_string<_CharT,_Traits,_Alloc>& __rhs); 2393 2394 /** 2395 * @brief Concatenate string and C string. 2396 * @param __lhs First string. 2397 * @param __rhs Last string. 2398 * @return New string with @a __lhs followed by @a __rhs. 2399 */ 2400 template<typename _CharT, typename _Traits, typename _Alloc> 2401 inline basic_string<_CharT, _Traits, _Alloc> 2402 operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2403 const _CharT* __rhs) 2404 { 2405 basic_string<_CharT, _Traits, _Alloc> __str(__lhs); 2406 __str.append(__rhs); 2407 return __str; 2408 } 2409 2410 /** 2411 * @brief Concatenate string and character. 2412 * @param __lhs First string. 2413 * @param __rhs Last string. 2414 * @return New string with @a __lhs followed by @a __rhs. 2415 */ 2416 template<typename _CharT, typename _Traits, typename _Alloc> 2417 inline basic_string<_CharT, _Traits, _Alloc> 2418 operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, _CharT __rhs) 2419 { 2420 typedef basic_string<_CharT, _Traits, _Alloc> __string_type; 2421 typedef typename __string_type::size_type __size_type; 2422 __string_type __str(__lhs); 2423 __str.append(__size_type(1), __rhs); 2424 return __str; 2425 } 2426 2427 #if __cplusplus >= 201103L 2428 template<typename _CharT, typename _Traits, typename _Alloc> 2429 inline basic_string<_CharT, _Traits, _Alloc> 2430 operator+(basic_string<_CharT, _Traits, _Alloc>&& __lhs, 2431 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2432 { return std::move(__lhs.append(__rhs)); } 2433 2434 template<typename _CharT, typename _Traits, typename _Alloc> 2435 inline basic_string<_CharT, _Traits, _Alloc> 2436 operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2437 basic_string<_CharT, _Traits, _Alloc>&& __rhs) 2438 { return std::move(__rhs.insert(0, __lhs)); } 2439 2440 template<typename _CharT, typename _Traits, typename _Alloc> 2441 inline basic_string<_CharT, _Traits, _Alloc> 2442 operator+(basic_string<_CharT, _Traits, _Alloc>&& __lhs, 2443 basic_string<_CharT, _Traits, _Alloc>&& __rhs) 2444 { 2445 const auto __size = __lhs.size() + __rhs.size(); 2446 const bool __cond = (__size > __lhs.capacity() 2447 && __size <= __rhs.capacity()); 2448 return __cond ? std::move(__rhs.insert(0, __lhs)) 2449 : std::move(__lhs.append(__rhs)); 2450 } 2451 2452 template<typename _CharT, typename _Traits, typename _Alloc> 2453 inline basic_string<_CharT, _Traits, _Alloc> 2454 operator+(const _CharT* __lhs, 2455 basic_string<_CharT, _Traits, _Alloc>&& __rhs) 2456 { return std::move(__rhs.insert(0, __lhs)); } 2457 2458 template<typename _CharT, typename _Traits, typename _Alloc> 2459 inline basic_string<_CharT, _Traits, _Alloc> 2460 operator+(_CharT __lhs, 2461 basic_string<_CharT, _Traits, _Alloc>&& __rhs) 2462 { return std::move(__rhs.insert(0, 1, __lhs)); } 2463 2464 template<typename _CharT, typename _Traits, typename _Alloc> 2465 inline basic_string<_CharT, _Traits, _Alloc> 2466 operator+(basic_string<_CharT, _Traits, _Alloc>&& __lhs, 2467 const _CharT* __rhs) 2468 { return std::move(__lhs.append(__rhs)); } 2469 2470 template<typename _CharT, typename _Traits, typename _Alloc> 2471 inline basic_string<_CharT, _Traits, _Alloc> 2472 operator+(basic_string<_CharT, _Traits, _Alloc>&& __lhs, 2473 _CharT __rhs) 2474 { return std::move(__lhs.append(1, __rhs)); } 2475 #endif 2476 2477 // operator == 2478 /** 2479 * @brief Test equivalence of two strings. 2480 * @param __lhs First string. 2481 * @param __rhs Second string. 2482 * @return True if @a __lhs.compare(@a __rhs) == 0. False otherwise. 2483 */ 2484 template<typename _CharT, typename _Traits, typename _Alloc> 2485 inline bool 2486 operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2487 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2488 { return __lhs.compare(__rhs) == 0; } 2489 2490 template<typename _CharT> 2491 inline 2492 typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, bool>::__type 2493 operator==(const basic_string<_CharT>& __lhs, 2494 const basic_string<_CharT>& __rhs) 2495 { return (__lhs.size() == __rhs.size() 2496 && !std::char_traits<_CharT>::compare(__lhs.data(), __rhs.data(), 2497 __lhs.size())); } 2498 2499 /** 2500 * @brief Test equivalence of C string and string. 2501 * @param __lhs C string. 2502 * @param __rhs String. 2503 * @return True if @a __rhs.compare(@a __lhs) == 0. False otherwise. 2504 */ 2505 template<typename _CharT, typename _Traits, typename _Alloc> 2506 inline bool 2507 operator==(const _CharT* __lhs, 2508 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2509 { return __rhs.compare(__lhs) == 0; } 2510 2511 /** 2512 * @brief Test equivalence of string and C string. 2513 * @param __lhs String. 2514 * @param __rhs C string. 2515 * @return True if @a __lhs.compare(@a __rhs) == 0. False otherwise. 2516 */ 2517 template<typename _CharT, typename _Traits, typename _Alloc> 2518 inline bool 2519 operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2520 const _CharT* __rhs) 2521 { return __lhs.compare(__rhs) == 0; } 2522 2523 // operator != 2524 /** 2525 * @brief Test difference of two strings. 2526 * @param __lhs First string. 2527 * @param __rhs Second string. 2528 * @return True if @a __lhs.compare(@a __rhs) != 0. False otherwise. 2529 */ 2530 template<typename _CharT, typename _Traits, typename _Alloc> 2531 inline bool 2532 operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2533 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2534 { return !(__lhs == __rhs); } 2535 2536 /** 2537 * @brief Test difference of C string and string. 2538 * @param __lhs C string. 2539 * @param __rhs String. 2540 * @return True if @a __rhs.compare(@a __lhs) != 0. False otherwise. 2541 */ 2542 template<typename _CharT, typename _Traits, typename _Alloc> 2543 inline bool 2544 operator!=(const _CharT* __lhs, 2545 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2546 { return !(__lhs == __rhs); } 2547 2548 /** 2549 * @brief Test difference of string and C string. 2550 * @param __lhs String. 2551 * @param __rhs C string. 2552 * @return True if @a __lhs.compare(@a __rhs) != 0. False otherwise. 2553 */ 2554 template<typename _CharT, typename _Traits, typename _Alloc> 2555 inline bool 2556 operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2557 const _CharT* __rhs) 2558 { return !(__lhs == __rhs); } 2559 2560 // operator < 2561 /** 2562 * @brief Test if string precedes string. 2563 * @param __lhs First string. 2564 * @param __rhs Second string. 2565 * @return True if @a __lhs precedes @a __rhs. False otherwise. 2566 */ 2567 template<typename _CharT, typename _Traits, typename _Alloc> 2568 inline bool 2569 operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2570 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2571 { return __lhs.compare(__rhs) < 0; } 2572 2573 /** 2574 * @brief Test if string precedes C string. 2575 * @param __lhs String. 2576 * @param __rhs C string. 2577 * @return True if @a __lhs precedes @a __rhs. False otherwise. 2578 */ 2579 template<typename _CharT, typename _Traits, typename _Alloc> 2580 inline bool 2581 operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2582 const _CharT* __rhs) 2583 { return __lhs.compare(__rhs) < 0; } 2584 2585 /** 2586 * @brief Test if C string precedes string. 2587 * @param __lhs C string. 2588 * @param __rhs String. 2589 * @return True if @a __lhs precedes @a __rhs. False otherwise. 2590 */ 2591 template<typename _CharT, typename _Traits, typename _Alloc> 2592 inline bool 2593 operator<(const _CharT* __lhs, 2594 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2595 { return __rhs.compare(__lhs) > 0; } 2596 2597 // operator > 2598 /** 2599 * @brief Test if string follows string. 2600 * @param __lhs First string. 2601 * @param __rhs Second string. 2602 * @return True if @a __lhs follows @a __rhs. False otherwise. 2603 */ 2604 template<typename _CharT, typename _Traits, typename _Alloc> 2605 inline bool 2606 operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2607 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2608 { return __lhs.compare(__rhs) > 0; } 2609 2610 /** 2611 * @brief Test if string follows C string. 2612 * @param __lhs String. 2613 * @param __rhs C string. 2614 * @return True if @a __lhs follows @a __rhs. False otherwise. 2615 */ 2616 template<typename _CharT, typename _Traits, typename _Alloc> 2617 inline bool 2618 operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2619 const _CharT* __rhs) 2620 { return __lhs.compare(__rhs) > 0; } 2621 2622 /** 2623 * @brief Test if C string follows string. 2624 * @param __lhs C string. 2625 * @param __rhs String. 2626 * @return True if @a __lhs follows @a __rhs. False otherwise. 2627 */ 2628 template<typename _CharT, typename _Traits, typename _Alloc> 2629 inline bool 2630 operator>(const _CharT* __lhs, 2631 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2632 { return __rhs.compare(__lhs) < 0; } 2633 2634 // operator <= 2635 /** 2636 * @brief Test if string doesn't follow string. 2637 * @param __lhs First string. 2638 * @param __rhs Second string. 2639 * @return True if @a __lhs doesn't follow @a __rhs. False otherwise. 2640 */ 2641 template<typename _CharT, typename _Traits, typename _Alloc> 2642 inline bool 2643 operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2644 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2645 { return __lhs.compare(__rhs) <= 0; } 2646 2647 /** 2648 * @brief Test if string doesn't follow C string. 2649 * @param __lhs String. 2650 * @param __rhs C string. 2651 * @return True if @a __lhs doesn't follow @a __rhs. False otherwise. 2652 */ 2653 template<typename _CharT, typename _Traits, typename _Alloc> 2654 inline bool 2655 operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2656 const _CharT* __rhs) 2657 { return __lhs.compare(__rhs) <= 0; } 2658 2659 /** 2660 * @brief Test if C string doesn't follow string. 2661 * @param __lhs C string. 2662 * @param __rhs String. 2663 * @return True if @a __lhs doesn't follow @a __rhs. False otherwise. 2664 */ 2665 template<typename _CharT, typename _Traits, typename _Alloc> 2666 inline bool 2667 operator<=(const _CharT* __lhs, 2668 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2669 { return __rhs.compare(__lhs) >= 0; } 2670 2671 // operator >= 2672 /** 2673 * @brief Test if string doesn't precede string. 2674 * @param __lhs First string. 2675 * @param __rhs Second string. 2676 * @return True if @a __lhs doesn't precede @a __rhs. False otherwise. 2677 */ 2678 template<typename _CharT, typename _Traits, typename _Alloc> 2679 inline bool 2680 operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2681 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2682 { return __lhs.compare(__rhs) >= 0; } 2683 2684 /** 2685 * @brief Test if string doesn't precede C string. 2686 * @param __lhs String. 2687 * @param __rhs C string. 2688 * @return True if @a __lhs doesn't precede @a __rhs. False otherwise. 2689 */ 2690 template<typename _CharT, typename _Traits, typename _Alloc> 2691 inline bool 2692 operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, 2693 const _CharT* __rhs) 2694 { return __lhs.compare(__rhs) >= 0; } 2695 2696 /** 2697 * @brief Test if C string doesn't precede string. 2698 * @param __lhs C string. 2699 * @param __rhs String. 2700 * @return True if @a __lhs doesn't precede @a __rhs. False otherwise. 2701 */ 2702 template<typename _CharT, typename _Traits, typename _Alloc> 2703 inline bool 2704 operator>=(const _CharT* __lhs, 2705 const basic_string<_CharT, _Traits, _Alloc>& __rhs) 2706 { return __rhs.compare(__lhs) <= 0; } 2707 2708 /** 2709 * @brief Swap contents of two strings. 2710 * @param __lhs First string. 2711 * @param __rhs Second string. 2712 * 2713 * Exchanges the contents of @a __lhs and @a __rhs in constant time. 2714 */ 2715 template<typename _CharT, typename _Traits, typename _Alloc> 2716 inline void 2717 swap(basic_string<_CharT, _Traits, _Alloc>& __lhs, 2718 basic_string<_CharT, _Traits, _Alloc>& __rhs) 2719 { __lhs.swap(__rhs); } 2720 2721 /** 2722 * @brief Read stream into a string. 2723 * @param __is Input stream. 2724 * @param __str Buffer to store into. 2725 * @return Reference to the input stream. 2726 * 2727 * Stores characters from @a __is into @a __str until whitespace is 2728 * found, the end of the stream is encountered, or str.max_size() 2729 * is reached. If is.width() is non-zero, that is the limit on the 2730 * number of characters stored into @a __str. Any previous 2731 * contents of @a __str are erased. 2732 */ 2733 template<typename _CharT, typename _Traits, typename _Alloc> 2734 basic_istream<_CharT, _Traits>& 2735 operator>>(basic_istream<_CharT, _Traits>& __is, 2736 basic_string<_CharT, _Traits, _Alloc>& __str); 2737 2738 template<> 2739 basic_istream<char>& 2740 operator>>(basic_istream<char>& __is, basic_string<char>& __str); 2741 2742 /** 2743 * @brief Write string to a stream. 2744 * @param __os Output stream. 2745 * @param __str String to write out. 2746 * @return Reference to the output stream. 2747 * 2748 * Output characters of @a __str into os following the same rules as for 2749 * writing a C string. 2750 */ 2751 template<typename _CharT, typename _Traits, typename _Alloc> 2752 inline basic_ostream<_CharT, _Traits>& 2753 operator<<(basic_ostream<_CharT, _Traits>& __os, 2754 const basic_string<_CharT, _Traits, _Alloc>& __str) 2755 { 2756 // _GLIBCXX_RESOLVE_LIB_DEFECTS 2757 // 586. string inserter not a formatted function 2758 return __ostream_insert(__os, __str.data(), __str.size()); 2759 } 2760 2761 /** 2762 * @brief Read a line from stream into a string. 2763 * @param __is Input stream. 2764 * @param __str Buffer to store into. 2765 * @param __delim Character marking end of line. 2766 * @return Reference to the input stream. 2767 * 2768 * Stores characters from @a __is into @a __str until @a __delim is 2769 * found, the end of the stream is encountered, or str.max_size() 2770 * is reached. Any previous contents of @a __str are erased. If 2771 * @a __delim is encountered, it is extracted but not stored into 2772 * @a __str. 2773 */ 2774 template<typename _CharT, typename _Traits, typename _Alloc> 2775 basic_istream<_CharT, _Traits>& 2776 getline(basic_istream<_CharT, _Traits>& __is, 2777 basic_string<_CharT, _Traits, _Alloc>& __str, _CharT __delim); 2778 2779 /** 2780 * @brief Read a line from stream into a string. 2781 * @param __is Input stream. 2782 * @param __str Buffer to store into. 2783 * @return Reference to the input stream. 2784 * 2785 * Stores characters from is into @a __str until '\n' is 2786 * found, the end of the stream is encountered, or str.max_size() 2787 * is reached. Any previous contents of @a __str are erased. If 2788 * end of line is encountered, it is extracted but not stored into 2789 * @a __str. 2790 */ 2791 template<typename _CharT, typename _Traits, typename _Alloc> 2792 inline basic_istream<_CharT, _Traits>& 2793 getline(basic_istream<_CharT, _Traits>& __is, 2794 basic_string<_CharT, _Traits, _Alloc>& __str) 2795 { return getline(__is, __str, __is.widen('\n')); } 2796 2797 template<> 2798 basic_istream<char>& 2799 getline(basic_istream<char>& __in, basic_string<char>& __str, 2800 char __delim); 2801 2802 #ifdef _GLIBCXX_USE_WCHAR_T 2803 template<> 2804 basic_istream<wchar_t>& 2805 getline(basic_istream<wchar_t>& __in, basic_string<wchar_t>& __str, 2806 wchar_t __delim); 2807 #endif 2808 2809 _GLIBCXX_END_NAMESPACE_VERSION 2810 } // namespace 2811 2812 #if ((__cplusplus >= 201103L) && defined(_GLIBCXX_USE_C99) \ 2813 && !defined(_GLIBCXX_HAVE_BROKEN_VSWPRINTF)) 2814 2815 #include <ext/string_conversions.h> 2816 2817 namespace std _GLIBCXX_VISIBILITY(default) 2818 { 2819 _GLIBCXX_BEGIN_NAMESPACE_VERSION 2820 2821 // 21.4 Numeric Conversions [string.conversions]. 2822 inline int 2823 stoi(const string& __str, size_t* __idx = 0, int __base = 10) 2824 { return __gnu_cxx::__stoa<long, int>(&std::strtol, "stoi", __str.c_str(), 2825 __idx, __base); } 2826 2827 inline long 2828 stol(const string& __str, size_t* __idx = 0, int __base = 10) 2829 { return __gnu_cxx::__stoa(&std::strtol, "stol", __str.c_str(), 2830 __idx, __base); } 2831 2832 inline unsigned long 2833 stoul(const string& __str, size_t* __idx = 0, int __base = 10) 2834 { return __gnu_cxx::__stoa(&std::strtoul, "stoul", __str.c_str(), 2835 __idx, __base); } 2836 2837 inline long long 2838 stoll(const string& __str, size_t* __idx = 0, int __base = 10) 2839 { return __gnu_cxx::__stoa(&std::strtoll, "stoll", __str.c_str(), 2840 __idx, __base); } 2841 2842 inline unsigned long long 2843 stoull(const string& __str, size_t* __idx = 0, int __base = 10) 2844 { return __gnu_cxx::__stoa(&std::strtoull, "stoull", __str.c_str(), 2845 __idx, __base); } 2846 2847 // NB: strtof vs strtod. 2848 inline float 2849 stof(const string& __str, size_t* __idx = 0) 2850 { return __gnu_cxx::__stoa(&std::strtof, "stof", __str.c_str(), __idx); } 2851 2852 inline double 2853 stod(const string& __str, size_t* __idx = 0) 2854 { return __gnu_cxx::__stoa(&std::strtod, "stod", __str.c_str(), __idx); } 2855 2856 inline long double 2857 stold(const string& __str, size_t* __idx = 0) 2858 { return __gnu_cxx::__stoa(&std::strtold, "stold", __str.c_str(), __idx); } 2859 2860 // NB: (v)snprintf vs sprintf. 2861 2862 // DR 1261. 2863 inline string 2864 to_string(int __val) 2865 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 4 * sizeof(int), 2866 "%d", __val); } 2867 2868 inline string 2869 to_string(unsigned __val) 2870 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 2871 4 * sizeof(unsigned), 2872 "%u", __val); } 2873 2874 inline string 2875 to_string(long __val) 2876 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 4 * sizeof(long), 2877 "%ld", __val); } 2878 2879 inline string 2880 to_string(unsigned long __val) 2881 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 2882 4 * sizeof(unsigned long), 2883 "%lu", __val); } 2884 2885 inline string 2886 to_string(long long __val) 2887 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 2888 4 * sizeof(long long), 2889 "%lld", __val); } 2890 2891 inline string 2892 to_string(unsigned long long __val) 2893 { return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, 2894 4 * sizeof(unsigned long long), 2895 "%llu", __val); } 2896 2897 inline string 2898 to_string(float __val) 2899 { 2900 const int __n = 2901 __gnu_cxx::__numeric_traits<float>::__max_exponent10 + 20; 2902 return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, __n, 2903 "%f", __val); 2904 } 2905 2906 inline string 2907 to_string(double __val) 2908 { 2909 const int __n = 2910 __gnu_cxx::__numeric_traits<double>::__max_exponent10 + 20; 2911 return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, __n, 2912 "%f", __val); 2913 } 2914 2915 inline string 2916 to_string(long double __val) 2917 { 2918 const int __n = 2919 __gnu_cxx::__numeric_traits<long double>::__max_exponent10 + 20; 2920 return __gnu_cxx::__to_xstring<string>(&std::vsnprintf, __n, 2921 "%Lf", __val); 2922 } 2923 2924 #ifdef _GLIBCXX_USE_WCHAR_T 2925 inline int 2926 stoi(const wstring& __str, size_t* __idx = 0, int __base = 10) 2927 { return __gnu_cxx::__stoa<long, int>(&std::wcstol, "stoi", __str.c_str(), 2928 __idx, __base); } 2929 2930 inline long 2931 stol(const wstring& __str, size_t* __idx = 0, int __base = 10) 2932 { return __gnu_cxx::__stoa(&std::wcstol, "stol", __str.c_str(), 2933 __idx, __base); } 2934 2935 inline unsigned long 2936 stoul(const wstring& __str, size_t* __idx = 0, int __base = 10) 2937 { return __gnu_cxx::__stoa(&std::wcstoul, "stoul", __str.c_str(), 2938 __idx, __base); } 2939 2940 inline long long 2941 stoll(const wstring& __str, size_t* __idx = 0, int __base = 10) 2942 { return __gnu_cxx::__stoa(&std::wcstoll, "stoll", __str.c_str(), 2943 __idx, __base); } 2944 2945 inline unsigned long long 2946 stoull(const wstring& __str, size_t* __idx = 0, int __base = 10) 2947 { return __gnu_cxx::__stoa(&std::wcstoull, "stoull", __str.c_str(), 2948 __idx, __base); } 2949 2950 // NB: wcstof vs wcstod. 2951 inline float 2952 stof(const wstring& __str, size_t* __idx = 0) 2953 { return __gnu_cxx::__stoa(&std::wcstof, "stof", __str.c_str(), __idx); } 2954 2955 inline double 2956 stod(const wstring& __str, size_t* __idx = 0) 2957 { return __gnu_cxx::__stoa(&std::wcstod, "stod", __str.c_str(), __idx); } 2958 2959 inline long double 2960 stold(const wstring& __str, size_t* __idx = 0) 2961 { return __gnu_cxx::__stoa(&std::wcstold, "stold", __str.c_str(), __idx); } 2962 2963 // DR 1261. 2964 inline wstring 2965 to_wstring(int __val) 2966 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 4 * sizeof(int), 2967 L"%d", __val); } 2968 2969 inline wstring 2970 to_wstring(unsigned __val) 2971 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 2972 4 * sizeof(unsigned), 2973 L"%u", __val); } 2974 2975 inline wstring 2976 to_wstring(long __val) 2977 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 4 * sizeof(long), 2978 L"%ld", __val); } 2979 2980 inline wstring 2981 to_wstring(unsigned long __val) 2982 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 2983 4 * sizeof(unsigned long), 2984 L"%lu", __val); } 2985 2986 inline wstring 2987 to_wstring(long long __val) 2988 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 2989 4 * sizeof(long long), 2990 L"%lld", __val); } 2991 2992 inline wstring 2993 to_wstring(unsigned long long __val) 2994 { return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, 2995 4 * sizeof(unsigned long long), 2996 L"%llu", __val); } 2997 2998 inline wstring 2999 to_wstring(float __val) 3000 { 3001 const int __n = 3002 __gnu_cxx::__numeric_traits<float>::__max_exponent10 + 20; 3003 return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, __n, 3004 L"%f", __val); 3005 } 3006 3007 inline wstring 3008 to_wstring(double __val) 3009 { 3010 const int __n = 3011 __gnu_cxx::__numeric_traits<double>::__max_exponent10 + 20; 3012 return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, __n, 3013 L"%f", __val); 3014 } 3015 3016 inline wstring 3017 to_wstring(long double __val) 3018 { 3019 const int __n = 3020 __gnu_cxx::__numeric_traits<long double>::__max_exponent10 + 20; 3021 return __gnu_cxx::__to_xstring<wstring>(&std::vswprintf, __n, 3022 L"%Lf", __val); 3023 } 3024 #endif 3025 3026 _GLIBCXX_END_NAMESPACE_VERSION 3027 } // namespace 3028 3029 #endif /* C++11 && _GLIBCXX_USE_C99 ... */ 3030 3031 #if __cplusplus >= 201103L 3032 3033 #include <bits/functional_hash.h> 3034 3035 namespace std _GLIBCXX_VISIBILITY(default) 3036 { 3037 _GLIBCXX_BEGIN_NAMESPACE_VERSION 3038 3039 // DR 1182. 3040 3041 #ifndef _GLIBCXX_COMPATIBILITY_CXX0X 3042 /// std::hash specialization for string. 3043 template<> 3044 struct hash<string> 3045 : public __hash_base<size_t, string> 3046 { 3047 size_t 3048 operator()(const string& __s) const noexcept 3049 { return std::_Hash_impl::hash(__s.data(), __s.length()); } 3050 }; 3051 3052 template<> 3053 struct __is_fast_hash<hash<string>> : std::false_type 3054 { }; 3055 3056 #ifdef _GLIBCXX_USE_WCHAR_T 3057 /// std::hash specialization for wstring. 3058 template<> 3059 struct hash<wstring> 3060 : public __hash_base<size_t, wstring> 3061 { 3062 size_t 3063 operator()(const wstring& __s) const noexcept 3064 { return std::_Hash_impl::hash(__s.data(), 3065 __s.length() * sizeof(wchar_t)); } 3066 }; 3067 3068 template<> 3069 struct __is_fast_hash<hash<wstring>> : std::false_type 3070 { }; 3071 #endif 3072 #endif /* _GLIBCXX_COMPATIBILITY_CXX0X */ 3073 3074 #ifdef _GLIBCXX_USE_C99_STDINT_TR1 3075 /// std::hash specialization for u16string. 3076 template<> 3077 struct hash<u16string> 3078 : public __hash_base<size_t, u16string> 3079 { 3080 size_t 3081 operator()(const u16string& __s) const noexcept 3082 { return std::_Hash_impl::hash(__s.data(), 3083 __s.length() * sizeof(char16_t)); } 3084 }; 3085 3086 template<> 3087 struct __is_fast_hash<hash<u16string>> : std::false_type 3088 { }; 3089 3090 /// std::hash specialization for u32string. 3091 template<> 3092 struct hash<u32string> 3093 : public __hash_base<size_t, u32string> 3094 { 3095 size_t 3096 operator()(const u32string& __s) const noexcept 3097 { return std::_Hash_impl::hash(__s.data(), 3098 __s.length() * sizeof(char32_t)); } 3099 }; 3100 3101 template<> 3102 struct __is_fast_hash<hash<u32string>> : std::false_type 3103 { }; 3104 #endif 3105 3106 _GLIBCXX_END_NAMESPACE_VERSION 3107 } // namespace 3108 3109 #endif // C++11 3110 3111 #endif /* _BASIC_STRING_H */ 3112