_string_workaround.h

来自「stl的源码」· C头文件 代码 · 共 600 行 · 第 1/2 页

H
600
字号
  _Self& assign(_InputIter __first, _InputIter __last) {    typedef typename _IsIntegral<_InputIter>::_Ret _Integral;    return _M_assign_dispatch(__first, __last, _Integral());  }#if !defined (_STLP_NO_METHOD_SPECIALIZATION) && !defined (_STLP_NO_EXTENSIONS)  /* This method is not part of the standard and is a specialization of the   * template method assign. It is only granted for convenience to call assign   * with mixed parameters iterator and const_iterator.   */  _Self& assign(const _CharT* __f, const _CharT* __l) {    _STLP_FIX_LITERAL_BUG(__f)_STLP_FIX_LITERAL_BUG(__l)    _Base::assign(__f, __l);    return *this;  }#endifpublic:                         // Insert  _Self& insert(size_type __pos, const _Self& __s) {    _Base::insert(__pos, __s);    return *this;  }  _Self& insert(size_type __pos, const _Self& __s,                size_type __beg, size_type __n) {    _Base::insert(__pos, __s, __beg, __n);    return *this;  }  _Self& insert(size_type __pos, const _CharT* __s, size_type __n) {    _STLP_FIX_LITERAL_BUG(__s)    _Base::insert(__pos, __s, __n);    return *this;  }  _Self& insert(size_type __pos, const _CharT* __s) {    _STLP_FIX_LITERAL_BUG(__s)    _Base::insert(__pos, __s);    return *this;  }  _Self& insert(size_type __pos, size_type __n, _CharT __c) {    _Base::insert(__pos, __n, __c);    return *this;  }  iterator insert(iterator __p, _CharT __c)  { return _Base::insert(__p, __c); }  void insert(iterator __p, size_t __n, _CharT __c)  { _Base::insert(__p, __n, __c); }  // Check to see if _InputIterator is an integer type.  If so, then  // it can't be an iterator.  template <class _InputIter>  void insert(iterator __p, _InputIter __first, _InputIter __last) {    typedef typename _IsIntegral<_InputIter>::_Ret _Integral;    _M_insert_dispatch(__p, __first, __last, _Integral());  }#if !defined (_STLP_NO_METHOD_SPECIALIZATION)public:  void insert(iterator __p, const _CharT* __f, const _CharT* __l) {    _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l)    _M_insert(__p, __f, __l, this->_M_inside(__f));  }#endifprivate:  // Helper functions for insert.  void _M_insert(iterator __p, const _CharT* __f, const _CharT* __l, bool __self_ref) {    _STLP_FIX_LITERAL_BUG(__f)_STLP_FIX_LITERAL_BUG(__l)    _Base::_M_insert(__p, __f, __l, __self_ref);  }  template <class _ForwardIter>  void _M_insert_overflow(iterator __pos, _ForwardIter __first, _ForwardIter __last,                          size_type __n) {    size_type __len = this->_M_compute_next_size(__n);    pointer __new_start = this->_M_start_of_storage.allocate(__len, __len);    pointer __new_finish = uninitialized_copy(this->_M_Start(), __pos, __new_start);    __new_finish = uninitialized_copy(__first, __last, __new_finish);    __new_finish = uninitialized_copy(__pos, this->_M_Finish(), __new_finish);    this->_M_construct_null(__new_finish);    this->_M_deallocate_block();    this->_M_reset(__new_start, __new_finish, __new_start + __len);  }  template <class _InputIter>  void _M_insertT(iterator __p, _InputIter __first, _InputIter __last,                  const input_iterator_tag &) {    for ( ; __first != __last; ++__first) {      __p = insert(__p, *__first);      ++__p;    }  }  template <class _ForwardIter>  void _M_insertT(iterator __pos, _ForwardIter __first, _ForwardIter __last,                  const forward_iterator_tag &) {    if (__first != __last) {      size_type __n = __STATIC_CAST(size_type, _STLP_STD::distance(__first, __last));      if (__n < this->_M_rest()) {        const size_type __elems_after = this->_M_finish - __pos;        if (__elems_after >= __n) {          uninitialized_copy((this->_M_Finish() - __n) + 1, this->_M_Finish() + 1, this->_M_Finish() + 1);          this->_M_finish += __n;          _Traits::move(__pos + __n, __pos, (__elems_after - __n) + 1);          _M_copyT(__first, __last, __pos);        }        else {          pointer __old_finish = this->_M_Finish();          _ForwardIter __mid = __first;          _STLP_STD::advance(__mid, __elems_after + 1);          _STLP_STD::uninitialized_copy(__mid, __last, this->_M_Finish() + 1);          this->_M_finish += __n - __elems_after;          uninitialized_copy(__pos, __old_finish + 1, this->_M_Finish());          this->_M_finish += __elems_after;          _M_copyT(__first, __mid, __pos);        }      }      else {        _M_insert_overflow(__pos, __first, __last, __n);      }    }  }  template <class _Integer>  void _M_insert_dispatch(iterator __p, _Integer __n, _Integer __x,                          const __true_type& /*Integral*/)  { insert(__p, (size_type) __n, (_CharT) __x); }  template <class _InputIter>  void _M_insert_dispatch(iterator __p, _InputIter __first, _InputIter __last,                          const __false_type& /*Integral*/) {    _STLP_FIX_LITERAL_BUG(__p)    /* We are forced to do a temporary string to avoid the self referencing issue. */    const _Self __self(__first, __last, this->get_allocator());    _M_insertT(__p, __self.begin(), __self.end(), _STLP_ITERATOR_CATEGORY(__first, _InputIter));  }  template <class _InputIterator>  void _M_copyT(_InputIterator __first, _InputIterator __last, pointer __result) {    _STLP_FIX_LITERAL_BUG(__p)    for ( ; __first != __last; ++__first, ++__result)      _Traits::assign(*__result, *__first);  }#if !defined (_STLP_NO_METHOD_SPECIALIZATION)  void _M_copyT(const _CharT* __f, const _CharT* __l, _CharT* __res) {    _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l) _STLP_FIX_LITERAL_BUG(__res)    _Base::_M_copy(__f, __l, __res);  }#endifpublic:                         // Erase.  _Self& erase(size_type __pos = 0, size_type __n = npos) {    _Base::erase(__pos, __n);    return *this;  }  iterator erase(iterator __pos) {    _STLP_FIX_LITERAL_BUG(__pos)    return _Base::erase(__pos);  }  iterator erase(iterator __first, iterator __last) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    return _Base::erase(__first, __last);  }public:                         // Replace.  (Conceptually equivalent                                // to erase followed by insert.)  _Self& replace(size_type __pos, size_type __n, const _Self& __s) {    _Base::replace(__pos, __n, __s);    return *this;  }  _Self& replace(size_type __pos1, size_type __n1, const _Self& __s,                 size_type __pos2, size_type __n2) {    _Base::replace(__pos1, __n1, __s, __pos2, __n2);    return *this;  }  _Self& replace(size_type __pos, size_type __n1,                 const _CharT* __s, size_type __n2) {    _STLP_FIX_LITERAL_BUG(__s)    _Base::replace(__pos, __n1, __s, __n2);    return *this;  }  _Self& replace(size_type __pos, size_type __n1, const _CharT* __s) {    _STLP_FIX_LITERAL_BUG(__s)    _Base::replace(__pos, __n1, __s);    return *this;  }  _Self& replace(size_type __pos, size_type __n1,                 size_type __n2, _CharT __c) {    _Base::replace(__pos, __n1, __n2, __c);    return *this;  }  _Self& replace(iterator __first, iterator __last, const _Self& __s) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _Base::replace(__first, __last, __s);    return *this;  }  _Self& replace(iterator __first, iterator __last,                 const _CharT* __s, size_type __n) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _STLP_FIX_LITERAL_BUG(__s)    _Base::replace(__first, __last, __s, __n);    return *this;  }  _Self& replace(iterator __first, iterator __last,                 const _CharT* __s) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _STLP_FIX_LITERAL_BUG(__s)    _Base::replace(__first, __last, __s);    return *this;  }  _Self& replace(iterator __first, iterator __last,                 size_type __n, _CharT __c) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _Base::replace(__first, __last, __n, __c);    return *this;  }  // Check to see if _InputIter is an integer type.  If so, then  // it can't be an iterator.  template <class _InputIter>  _Self& replace(iterator __first, iterator __last,                 _InputIter __f, _InputIter __l) {    _STLP_FIX_LITERAL_BUG(__first)_STLP_FIX_LITERAL_BUG(__last)    typedef typename _IsIntegral<_InputIter>::_Ret _Integral;    return _M_replace_dispatch(__first, __last, __f, __l, _Integral());  }#if !defined (_STLP_NO_METHOD_SPECIALIZATION)  _Self& replace(iterator __first, iterator __last,                 const _CharT* __f, const _CharT* __l) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l)    return _M_replace(__first, __last, __f, __l, this->_M_inside(__f));  }#endifprivate:                        // Helper functions for replace.  _Self& _M_replace(iterator __first, iterator __last,                    const _CharT* __f, const _CharT* __l, bool __self_ref) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l)    _Base::_M_replace(__first, __last, __f, __l, __self_ref);    return *this;  }  template <class _Integer>  _Self& _M_replace_dispatch(iterator __first, iterator __last,                             _Integer __n, _Integer __x, const __true_type& /*IsIntegral*/) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    return replace(__first, __last, (size_type) __n, (_CharT) __x);  }  template <class _InputIter>  _Self& _M_replace_dispatch(iterator __first, iterator __last,                             _InputIter __f, _InputIter __l, const __false_type& /*IsIntegral*/) {    _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last)    /* We are forced to do a temporary string to avoid the self referencing issue. */    const _Self __self(__f, __l, this->get_allocator());    return _M_replace(__first, __last, __self._M_Start(), __self._M_Finish(), false);  }public:                         // Other modifier member functions.  void swap(_Self& __s) { _Base::swap(__s); }#if defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND) && !defined (_STLP_FUNCTION_TMPL_PARTIAL_ORDER)  void _M_swap_workaround(_Self& __x) { swap(__x); }#endifpublic:                         // Substring.  _Self substr(size_type __pos = 0, size_type __n = npos) const  { return _Self(*this, __pos, __n, this->get_allocator()); }#if defined (_STLP_USE_TEMPLATE_EXPRESSION) && !defined (_STLP_DEBUG)#  define _STLP_STRING_SUM_BASE _STLP_NO_MEM_T_STRING_BASE#  include <stl/_string_sum_methods.h>#  undef _STLP_STRING_SUM_BASE#endif};#undef _STLP_NO_MEM_T_STRING_BASE#if defined (basic_string)_STLP_MOVE_TO_STD_NAMESPACE#  undef basic_string#endif_STLP_END_NAMESPACE

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?