⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 basic_string.tcc

📁 gcc3.2.1源代码
💻 TCC
📖 第 1 页 / 共 3 页
字号:
  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    copy(_CharT* __s, size_type __n, size_type __pos) const    {      if (__pos > this->size())	__throw_out_of_range("basic_string::copy");            if (__n > this->size() - __pos)	__n = this->size() - __pos;            traits_type::copy(__s, _M_data() + __pos, __n);      // 21.3.5.7 par 3: do not append null.  (good.)      return __n;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find(const _CharT* __s, size_type __pos, size_type __n) const    {      size_type __size = this->size();      size_t __xpos = __pos;      const _CharT* __data = _M_data();      for (; __xpos + __n <= __size; ++__xpos)	if (traits_type::compare(__data + __xpos, __s, __n) == 0)	  return __xpos;      return npos;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find(_CharT __c, size_type __pos) const    {      size_type __size = this->size();      size_type __ret = npos;      if (__pos < __size)	{	  const _CharT* __data = _M_data();	  size_type __n = __size - __pos;	  const _CharT* __p = traits_type::find(__data + __pos, __n, __c);	  if (__p)	    __ret = __p - __data;	}      return __ret;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    rfind(const _CharT* __s, size_type __pos, size_type __n) const    {      size_type __size = this->size();      if (__n <= __size)	{	  __pos = std::min(__size - __n, __pos);	  const _CharT* __data = _M_data();	  do 	    {	      if (traits_type::compare(__data + __pos, __s, __n) == 0)		return __pos;	    } 	  while (__pos-- > 0);	}      return npos;    }    template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    rfind(_CharT __c, size_type __pos) const    {      size_type __size = this->size();      if (__size)	{	  size_t __xpos = __size - 1;	  if (__xpos > __pos)	    __xpos = __pos;      	  for (++__xpos; __xpos-- > 0; )	    if (traits_type::eq(_M_data()[__xpos], __c))	      return __xpos;	}      return npos;    }    template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_first_of(const _CharT* __s, size_type __pos, size_type __n) const    {      for (; __n && __pos < this->size(); ++__pos)	{	  const _CharT* __p = traits_type::find(__s, __n, _M_data()[__pos]);	  if (__p)	    return __pos;	}      return npos;    }   template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_last_of(const _CharT* __s, size_type __pos, size_type __n) const    {      size_type __size = this->size();      if (__size && __n)	{ 	  if (--__size > __pos) 	    __size = __pos;	  do	    {	      if (traits_type::find(__s, __n, _M_data()[__size]))		return __size;	    } 	  while (__size-- != 0);	}      return npos;    }    template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const    {      size_t __xpos = __pos;      for (; __xpos < this->size(); ++__xpos)	if (!traits_type::find(__s, __n, _M_data()[__xpos]))	  return __xpos;      return npos;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_first_not_of(_CharT __c, size_type __pos) const    {      size_t __xpos = __pos;      for (; __xpos < this->size(); ++__xpos)	if (!traits_type::eq(_M_data()[__xpos], __c))	  return __xpos;      return npos;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const    {      size_type __size = this->size();      if (__size)	{ 	  if (--__size > __pos) 	    __size = __pos;	  do	    {	      if (!traits_type::find(__s, __n, _M_data()[__size]))		return __size;	    } 	  while (__size--);	}      return npos;    }  template<typename _CharT, typename _Traits, typename _Alloc>    typename basic_string<_CharT, _Traits, _Alloc>::size_type    basic_string<_CharT, _Traits, _Alloc>::    find_last_not_of(_CharT __c, size_type __pos) const    {      size_type __size = this->size();      if (__size)	{ 	  if (--__size > __pos) 	    __size = __pos;	  do	    {	      if (!traits_type::eq(_M_data()[__size], __c))		return __size;	    } 	  while (__size--);	}      return npos;    }    template<typename _CharT, typename _Traits, typename _Alloc>    int    basic_string<_CharT, _Traits, _Alloc>::    compare(size_type __pos, size_type __n, const basic_string& __str) const    {      size_type __size = this->size();      size_type __osize = __str.size();      if (__pos > __size)	__throw_out_of_range("basic_string::compare");            size_type __rsize= min(__size - __pos, __n);      size_type __len = min(__rsize, __osize);      int __r = traits_type::compare(_M_data() + __pos, __str.data(), __len);      if (!__r)	__r = __rsize - __osize;      return __r;    }  template<typename _CharT, typename _Traits, typename _Alloc>    int    basic_string<_CharT, _Traits, _Alloc>::    compare(size_type __pos1, size_type __n1, const basic_string& __str,	    size_type __pos2, size_type __n2) const    {      size_type __size = this->size();      size_type __osize = __str.size();      if (__pos1 > __size || __pos2 > __osize)	__throw_out_of_range("basic_string::compare");            size_type __rsize = min(__size - __pos1, __n1);      size_type __rosize = min(__osize - __pos2, __n2);      size_type __len = min(__rsize, __rosize);      int __r = traits_type::compare(_M_data() + __pos1, 				     __str.data() + __pos2, __len);      if (!__r)	__r = __rsize - __rosize;      return __r;    }  template<typename _CharT, typename _Traits, typename _Alloc>    int    basic_string<_CharT, _Traits, _Alloc>::    compare(const _CharT* __s) const    {      size_type __size = this->size();      size_type __osize = traits_type::length(__s);      size_type __len = min(__size, __osize);      int __r = traits_type::compare(_M_data(), __s, __len);      if (!__r)	__r = __size - __osize;      return __r;    }  template<typename _CharT, typename _Traits, typename _Alloc>    int    basic_string <_CharT, _Traits, _Alloc>::    compare(size_type __pos, size_type __n1, const _CharT* __s) const    {      size_type __size = this->size();      if (__pos > __size)	__throw_out_of_range("basic_string::compare");            size_type __osize = traits_type::length(__s);      size_type __rsize = min(__size - __pos, __n1);      size_type __len = min(__rsize, __osize);      int __r = traits_type::compare(_M_data() + __pos, __s, __len);      if (!__r)	__r = __rsize - __osize;      return __r;    }  template<typename _CharT, typename _Traits, typename _Alloc>    int    basic_string <_CharT, _Traits, _Alloc>::    compare(size_type __pos, size_type __n1, const _CharT* __s, 	    size_type __n2) const    {      size_type __size = this->size();      if (__pos > __size)	__throw_out_of_range("basic_string::compare");            size_type __osize = min(traits_type::length(__s), __n2);      size_type __rsize = min(__size - __pos, __n1);      size_type __len = min(__rsize, __osize);      int __r = traits_type::compare(_M_data() + __pos, __s, __len);      if (!__r)	__r = __rsize - __osize;      return __r;    }  template <class _CharT, class _Traits, class _Alloc>    void    _S_string_copy(const basic_string<_CharT, _Traits, _Alloc>& __str,		   _CharT* __buf, typename _Alloc::size_type __bufsiz)    {      typedef typename _Alloc::size_type size_type;      size_type __strsize = __str.size();      size_type __bytes = min(__strsize, __bufsiz - 1);      _Traits::copy(__buf, __str.data(), __bytes);      __buf[__bytes] = _CharT();    }  // Inhibit implicit instantiations for required instantiations,  // which are defined via explicit instantiations elsewhere.    // NB: This syntax is a GNU extension.  extern template class basic_string<char>;  extern template     basic_istream<char>&     operator>>(basic_istream<char>&, string&);  extern template     basic_ostream<char>&     operator<<(basic_ostream<char>&, const string&);  extern template     basic_istream<char>&     getline(basic_istream<char>&, string&, char);  extern template     basic_istream<char>&     getline(basic_istream<char>&, string&);#ifdef _GLIBCPP_USE_WCHAR_T  extern template class basic_string<wchar_t>;  extern template     basic_istream<wchar_t>&     operator>>(basic_istream<wchar_t>&, wstring&);  extern template     basic_ostream<wchar_t>&     operator<<(basic_ostream<wchar_t>&, const wstring&);  extern template     basic_istream<wchar_t>&     getline(basic_istream<wchar_t>&, wstring&, wchar_t);  extern template     basic_istream<wchar_t>&     getline(basic_istream<wchar_t>&, wstring&);#endif} // namespace std#endif

⌨️ 快捷键说明

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