/* * Copyright (c) 1997-1999 * Silicon Graphics Computer Systems, Inc. * * Copyright (c) 1999 * Boris Fomitchev * * This material is provided "as is", with absolutely no warranty expressed * or implied. Any use is at your own risk. * * Permission to use or copy this software for any purpose is hereby granted * without fee, provided the above notices are retained on all copies. * Permission to modify the code and to distribute modified code is granted, * provided the above notices are retained, and a notice that the code was * modified is included with the above copyright notice. */ #ifndef _STLP_DBG_STRING_H #define _STLP_DBG_STRING_H #ifndef _STLP_DBG_ITERATOR_H # include #endif _STLP_BEGIN_NAMESPACE #define _STLP_NON_DBG_STRING_NAME _STLP_NON_DBG_NAME(str) #define _STLP_NON_DBG_STRING _STLP_PRIV _STLP_NON_DBG_STRING_NAME <_CharT, _Traits, _Alloc> #if defined (_STLP_DEBUG_USE_DISTINCT_VALUE_TYPE_HELPERS) template inline _CharT* value_type(const _STLP_PRIV _DBG_iter_base< _STLP_NON_DBG_STRING >&) { return (_CharT*)0; } template inline random_access_iterator_tag iterator_category(const _STLP_PRIV _DBG_iter_base< _STLP_NON_DBG_STRING >&) { return random_access_iterator_tag(); } #endif template class basic_string : #if !defined (__DMC__) private #else public #endif _STLP_PRIV __construct_checker<_STLP_NON_DBG_STRING > #if defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND) && !defined (basic_string) , public __stlport_class > #endif { protected: typedef _STLP_NON_DBG_STRING _Base; typedef basic_string<_CharT, _Traits, _Alloc> _Self; typedef _STLP_PRIV __construct_checker<_STLP_NON_DBG_STRING > _ConstructCheck; typedef typename _IsPOD<_CharT>::_Type _Char_Is_POD; public: __IMPORT_CONTAINER_TYPEDEFS(_Base) typedef typename _Base::traits_type traits_type; typedef _STLP_PRIV _DBG_iter<_Base, _STLP_PRIV _DbgTraits<_Nonconst_traits > > iterator; typedef _STLP_PRIV _DBG_iter<_Base, _STLP_PRIV _DbgTraits<_Const_traits > > const_iterator; _STLP_DECLARE_RANDOM_ACCESS_REVERSE_ITERATORS; public: // Constructor, destructor, assignment. typedef typename _Base::_Reserve_t _Reserve_t; private: _Base _M_non_dbg_impl; _STLP_PRIV __owned_list _M_iter_list; void _Invalidate_all() { _M_iter_list._Invalidate_all(); } void _Compare_Capacity (size_type __old_capacity) { if (this->capacity() > __old_capacity) { _Invalidate_all(); } } void _Invalidate_iterator(const iterator& __it) { _STLP_PRIV __invalidate_iterator(&_M_iter_list, __it); } void _Invalidate_iterators(const iterator& __f, const iterator& __l) { _STLP_PRIV __invalidate_range(&_M_iter_list, __f, __l); } public: #include allocator_type get_allocator() const { return _M_non_dbg_impl.get_allocator(); } explicit basic_string(const allocator_type& __a = allocator_type()) : _M_non_dbg_impl(__a), _M_iter_list(&_M_non_dbg_impl) {} basic_string(_Reserve_t __r, size_t __n, const allocator_type& __a = allocator_type()) : _M_non_dbg_impl(__r, __n, __a), _M_iter_list(&_M_non_dbg_impl) {} basic_string(const _Self& __s) : _ConstructCheck(__s), _M_non_dbg_impl(__s._M_non_dbg_impl), _M_iter_list(&_M_non_dbg_impl) {} basic_string(const _Self& __s, size_type __pos, size_type __n = npos, const allocator_type& __a = allocator_type()) : _M_non_dbg_impl(__s._M_non_dbg_impl, __pos, __n, __a), _M_iter_list(&_M_non_dbg_impl) {} basic_string(const _CharT* __s, size_type __n, const allocator_type& __a = allocator_type()) : _ConstructCheck(__s), _M_non_dbg_impl(__s, __n, __a), _M_iter_list(&_M_non_dbg_impl) {} basic_string(const _CharT* __s, const allocator_type& __a = allocator_type()) : _ConstructCheck(__s), _M_non_dbg_impl(__s, __a), _M_iter_list(&_M_non_dbg_impl) {} basic_string(size_type __n, _CharT __c, const allocator_type& __a = allocator_type()) : _M_non_dbg_impl(__n, __c, __a), _M_iter_list(&_M_non_dbg_impl) {} #if !defined (_STLP_NO_MOVE_SEMANTIC) basic_string(__move_source<_Self> src) : _M_non_dbg_impl(__move_source<_Base >(src.get()._M_non_dbg_impl)), _M_iter_list(&_M_non_dbg_impl) { # if defined (_STLP_NO_EXTENSIONS) || (_STLP_DEBUG_LEVEL == _STLP_STANDARD_DBG_LEVEL) src.get()._M_iter_list._Invalidate_all(); # else src.get()._M_iter_list._Set_owner(_M_iter_list); # endif } #endif #if !defined (_STLP_MEMBER_TEMPLATES) basic_string(const _CharT* __f, const _CharT* __l, const allocator_type& __a = allocator_type()) : _ConstructCheck(__f, __l), _M_non_dbg_impl(__f, __l, __a), _M_iter_list(&_M_non_dbg_impl) { } basic_string(const_iterator __f, const_iterator __l, const allocator_type & __a = allocator_type()) : _ConstructCheck(__f, __l), _M_non_dbg_impl(__f._M_iterator, __l._M_iterator, __a), _M_iter_list(&_M_non_dbg_impl) { } #else template basic_string(_InputIterator __f, _InputIterator __l, const allocator_type & __a _STLP_ALLOCATOR_TYPE_DFL) : _ConstructCheck(__f, __l), _M_non_dbg_impl(_STLP_PRIV _Non_Dbg_iter(__f), _STLP_PRIV _Non_Dbg_iter(__l), __a), _M_iter_list(&_M_non_dbg_impl) {} # if defined (_STLP_NEEDS_EXTRA_TEMPLATE_CONSTRUCTORS) template basic_string(_InputIterator __f, _InputIterator __l) : _ConstructCheck(__f, __l), _M_non_dbg_impl(_STLP_PRIV _Non_Dbg_iter(__f), _STLP_PRIV _Non_Dbg_iter(__l)), _M_iter_list(&_M_non_dbg_impl) {} # endif #endif private: // constructor from non-debug version for substr basic_string (const _Base& __x) : _M_non_dbg_impl(__x), _M_iter_list(&_M_non_dbg_impl) {} public: _Self& operator=(const _Self& __s) { if (this != &__s) { assign(__s); } return *this; } _Self& operator=(const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return assign(__s); } _Self& operator=(_CharT __c) { return assign(1, __c); } // Iterators. iterator begin() { return iterator(&_M_iter_list, _M_non_dbg_impl.begin()); } const_iterator begin() const { return const_iterator(&_M_iter_list, _M_non_dbg_impl.begin()); } iterator end() { return iterator(&_M_iter_list, _M_non_dbg_impl.end()); } const_iterator end() const { return const_iterator(&_M_iter_list, _M_non_dbg_impl.end()); } reverse_iterator rbegin() { return reverse_iterator(end()); } const_reverse_iterator rbegin() const { return const_reverse_iterator(end()); } reverse_iterator rend() { return reverse_iterator(begin()); } const_reverse_iterator rend() const { return const_reverse_iterator(begin()); } // Size, capacity, etc. size_type size() const { return _M_non_dbg_impl.size(); } size_type length() const { return _M_non_dbg_impl.length(); } size_t max_size() const { return _M_non_dbg_impl.max_size(); } void resize(size_type __n, _CharT __c) { if (__n > capacity()) _Invalidate_all(); else if (__n < size()) _Invalidate_iterators(begin() + __n, end()); _M_non_dbg_impl.resize(__n, __c); } void resize(size_type __n) { resize(__n, _STLP_DEFAULT_CONSTRUCTED(_CharT)); } size_type capacity() const { return _M_non_dbg_impl.capacity(); } void reserve(size_type __s = 0) { if (__s > capacity()) _Invalidate_all(); _M_non_dbg_impl.reserve(__s); } void clear() { _Invalidate_all(); _M_non_dbg_impl.clear(); } bool empty() const { return _M_non_dbg_impl.empty(); } const_reference operator[](size_type __n) const { _STLP_VERBOSE_ASSERT(__n <= this->size(), _StlMsg_OUT_OF_BOUNDS); return _M_non_dbg_impl[__n]; } reference operator[](size_type __n) { _STLP_VERBOSE_ASSERT(__n < this->size(), _StlMsg_OUT_OF_BOUNDS) return _M_non_dbg_impl[__n]; } const_reference at(size_type __n) const { return _M_non_dbg_impl.at(__n); } reference at(size_type __n) { return _M_non_dbg_impl.at(__n); } // Append, operator+=, push_back. _Self& operator+=(const _Self& __s) { return append(__s); } _Self& operator+=(const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return append(__s); } _Self& operator+=(_CharT __c) { return append(1, __c); } #if defined (_STLP_MEMBER_TEMPLATES) template _Self& append(_InputIter __first, _InputIter __last) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last)) size_type __old_capacity = capacity(); _M_non_dbg_impl.append(_STLP_PRIV _Non_Dbg_iter(__first), _STLP_PRIV _Non_Dbg_iter(__last)); _Compare_Capacity(__old_capacity); return *this; } #endif #if !defined (_STLP_MEMBER_TEMPLATES) || \ !defined (_STLP_NO_METHOD_SPECIALIZATION) && !defined (_STLP_NO_EXTENSIONS) _Self& append(const _CharT* __f, const _CharT* __l) { _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l) _STLP_DEBUG_CHECK(_STLP_PRIV __check_ptr_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__f, __l); _Compare_Capacity(__old_capacity); return *this; } _Self& append(const_iterator __f, const_iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__f._M_iterator, __l._M_iterator); _Compare_Capacity(__old_capacity); return *this; } #endif _Self& append(const _Self& __s) { size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__s._M_non_dbg_impl); _Compare_Capacity(__old_capacity); return *this; } _Self& append(const _Self& __s, size_type __pos, size_type __n) { size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__s._M_non_dbg_impl, __pos, __n); _Compare_Capacity(__old_capacity); return *this; } _Self& append(const _CharT* __s, size_type __n) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__s, __n); _Compare_Capacity(__old_capacity); return *this; } _Self& append(const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.append(__s); _Compare_Capacity(__old_capacity); return *this; } _Self& append(size_type __n, _CharT __c) { size_type __old_capacity = this->capacity(); _M_non_dbg_impl.append(__n, __c); _Compare_Capacity(__old_capacity); return *this; } void push_back(_CharT __c) { size_type __old_capacity = this->capacity(); _M_non_dbg_impl.push_back(__c); _Compare_Capacity(__old_capacity); } void pop_back() { _Invalidate_iterator(this->end()); _M_non_dbg_impl.pop_back(); } // Assign _Self& assign(const _Self& __s) { _Invalidate_all(); _M_non_dbg_impl.assign(__s._M_non_dbg_impl); return *this; } _Self& assign(const _Self& __s, size_type __pos, size_type __n) { if (__pos < __s.size()) { _Invalidate_all(); } _M_non_dbg_impl.assign(__s._M_non_dbg_impl, __pos, __n); return *this; } _Self& assign(const _CharT* __s, size_type __n) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) _Invalidate_all(); _M_non_dbg_impl.assign(__s, __s + __n); return *this; } _Self& assign(const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) _Invalidate_all(); _M_non_dbg_impl.assign(__s); return *this; } _Self& assign(size_type __n, _CharT __c) { _Invalidate_all(); _M_non_dbg_impl.assign(__n, __c); return *this; } #if defined(_STLP_MEMBER_TEMPLATES) template inline _Self& assign(_InputIter __first, _InputIter __last) { _STLP_FIX_LITERAL_BUG(__first) _STLP_FIX_LITERAL_BUG(__last) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last)) _Invalidate_all(); _M_non_dbg_impl.assign(_STLP_PRIV _Non_Dbg_iter(__first), _STLP_PRIV _Non_Dbg_iter(__last)); return *this; } #endif #if !defined (_STLP_MEMBER_TEMPLATES) || \ !defined (_STLP_NO_METHOD_SPECIALIZATION) && !defined (_STLP_NO_EXTENSIONS) _Self& assign(const _CharT* __f, const _CharT* __l) { _STLP_FIX_LITERAL_BUG(__f) _STLP_FIX_LITERAL_BUG(__l) _STLP_DEBUG_CHECK(_STLP_PRIV __check_ptr_range(__f, __l)) _Invalidate_all(); _M_non_dbg_impl.assign(__f, __l); return *this; } _Self& assign(const_iterator __f, const_iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l)) _Invalidate_all(); _M_non_dbg_impl.assign(__f._M_iterator, __l._M_iterator); return *this; } #endif // Insert _Self& insert(size_type __pos, const _Self& __s) { size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__pos, __s._M_non_dbg_impl); _Compare_Capacity(__old_capacity); return *this; } _Self& insert(size_type __pos, const _Self& __s, size_type __beg, size_type __n) { size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__pos, __s._M_non_dbg_impl, __beg, __n); _Compare_Capacity(__old_capacity); return *this; } _Self& insert(size_type __pos, const _CharT* __s, size_type __n) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__pos, __s, __n); _Compare_Capacity(__old_capacity); return *this; } _Self& insert(size_type __pos, const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return insert(__pos, __s, _Traits::length(__s)); } _Self& insert(size_type __pos, size_type __n, _CharT __c) { size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__pos, __n, __c); _Compare_Capacity(__old_capacity); return *this; } iterator insert(iterator __p, _CharT __c) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) size_type __old_capacity = capacity(); typename _Base::iterator __ret = _M_non_dbg_impl.insert(__p._M_iterator, __c); _Compare_Capacity(__old_capacity); return iterator(&_M_iter_list, __ret); } void insert(iterator __p, size_t __n, _CharT __c) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__p._M_iterator, __n, __c); _Compare_Capacity(__old_capacity); } #if defined (_STLP_MEMBER_TEMPLATES) template void insert(iterator __p, _InputIter __first, _InputIter __last) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first,__last)) size_type __old_capacity = this->capacity(); _M_non_dbg_impl.insert(__p._M_iterator, _STLP_PRIV _Non_Dbg_iter(__first), _STLP_PRIV _Non_Dbg_iter(__last)); _Compare_Capacity(__old_capacity); } #endif #if !defined (_STLP_MEMBER_TEMPLATES) void insert(iterator __p, const _CharT* __f, const _CharT* __l) { _STLP_FIX_LITERAL_BUG(__f)_STLP_FIX_LITERAL_BUG(__l) _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) _STLP_DEBUG_CHECK(_STLP_PRIV __check_ptr_range(__f,__l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__p._M_iterator, __f, __l); _Compare_Capacity(__old_capacity); } #endif #if !defined (_STLP_MEMBER_TEMPLATES) || !defined (_STLP_NO_METHOD_SPECIALIZATION) // Those overloads are necessary to check self referencing correctly in non debug // basic_string implementation void insert(iterator __p, const_iterator __f, const_iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f,__l)) # if (_STLP_DEBUG_LEVEL == _STLP_STANDARD_DBG_LEVEL) _STLP_STD_DEBUG_CHECK(__check_if_not_owner(&_M_iter_list, __f)) # endif size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__p._M_iterator, __f._M_iterator, __l._M_iterator); _Compare_Capacity(__old_capacity); } void insert(iterator __p, iterator __f, iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__p)) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f,__l)) # if (_STLP_DEBUG_LEVEL == _STLP_STANDARD_DBG_LEVEL) _STLP_STD_DEBUG_CHECK(__check_if_not_owner(&_M_iter_list, __f)) # endif size_type __old_capacity = capacity(); _M_non_dbg_impl.insert(__p._M_iterator, __f._M_iterator, __l._M_iterator); _Compare_Capacity(__old_capacity); } #endif // Erase. _Self& erase(size_type __pos = 0, size_type __n = npos) { if (__pos < size()) { _Invalidate_iterators(begin() + __pos, end()); } _M_non_dbg_impl.erase(__pos, __n); return *this; } iterator erase(iterator __pos) { _STLP_DEBUG_CHECK(_STLP_PRIV _Dereferenceable(__pos)) _STLP_DEBUG_CHECK(_STLP_PRIV __check_if_owner(&_M_iter_list,__pos)) _Invalidate_iterators(__pos, end()); return iterator(&_M_iter_list, _M_non_dbg_impl.erase(__pos._M_iterator)); } iterator erase(iterator __f, iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l, begin(), end())) _Invalidate_iterators(__f, end()); return iterator(&_M_iter_list, _M_non_dbg_impl.erase(__f._M_iterator, __l._M_iterator)); } // Substring. _Self substr(size_type __pos = 0, size_type __n = npos) const { return _M_non_dbg_impl.substr(__pos, __n); } // Replace. (Conceptually equivalent to erase followed by insert.) _Self& replace(size_type __pos, size_type __n, const _Self& __s) { size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__pos, __n, __s._M_non_dbg_impl); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(size_type __pos1, size_type __n1, const _Self& __s, size_type __pos2, size_type __n2) { size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__pos1, __n1, __s._M_non_dbg_impl, __pos2, __n2); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(size_type __pos, size_type __n1, const _CharT* __s, size_type __n2) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__pos, __n1, __s, __n2); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(size_type __pos, size_type __n1, const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__pos, __n1, __s); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(size_type __pos, size_type __n1, size_type __n2, _CharT __c) { size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__pos, __n1, __n2, __c); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(iterator __f, iterator __l, const _Self& __s) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l, begin(), end())) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__f._M_iterator, __l._M_iterator, __s._M_non_dbg_impl); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(iterator __f, iterator __l, const _CharT* __s, size_type __n) { _STLP_FIX_LITERAL_BUG(__s) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l, begin(), end())) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__f._M_iterator, __l._M_iterator, __s, __n); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(iterator __f, iterator __l, const _CharT* __s) { _STLP_FIX_LITERAL_BUG(__s) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l, begin(), end())) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__f._M_iterator, __l._M_iterator, __s); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(iterator __f, iterator __l, size_type __n, _CharT __c) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l, begin(), end())) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__f._M_iterator, __l._M_iterator, __n, __c); _Compare_Capacity(__old_capacity); return *this; } #if defined (_STLP_MEMBER_TEMPLATES) template _Self& replace(iterator __first, iterator __last, _InputIter __f, _InputIter __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last, begin(), end())) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__first._M_iterator, __last._M_iterator, _STLP_PRIV _Non_Dbg_iter(__f), _STLP_PRIV _Non_Dbg_iter(__l)); _Compare_Capacity(__old_capacity); return *this; } #endif #if !defined (_STLP_MEMBER_TEMPLATES) _Self& replace(iterator __first, iterator __last, const _CharT* __f, const _CharT* __l) { _STLP_FIX_LITERAL_BUG(__f)_STLP_FIX_LITERAL_BUG(__l) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last, begin(), end())) _STLP_DEBUG_CHECK(_STLP_PRIV __check_ptr_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__first._M_iterator, __last._M_iterator, __f, __l); _Compare_Capacity(__old_capacity); return *this; } #endif #if !defined (_STLP_MEMBER_TEMPLATES) || !defined (_STLP_NO_METHOD_SPECIALIZATION) _Self& replace(iterator __first, iterator __last, const_iterator __f, const_iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last, begin(), end())) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__first._M_iterator, __last._M_iterator, __f._M_iterator, __l._M_iterator); _Compare_Capacity(__old_capacity); return *this; } _Self& replace(iterator __first, iterator __last, iterator __f, iterator __l) { _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last, begin(), end())) _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__f, __l)) size_type __old_capacity = capacity(); _M_non_dbg_impl.replace(__first._M_iterator, __last._M_iterator, __f._M_iterator, __l._M_iterator); _Compare_Capacity(__old_capacity); return *this; } #endif // Other modifier member functions. void swap(_Self& __s) { _M_iter_list._Swap_owners(__s._M_iter_list); _M_non_dbg_impl.swap(__s._M_non_dbg_impl); } #if defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND) && !defined (_STLP_FUNCTION_TMPL_PARTIAL_ORDER) void _M_swap_workaround(_Self& __x) { swap(__x); } #endif int compare(const _Self& __s) const { return _M_non_dbg_impl.compare(__s._M_non_dbg_impl); } int compare(size_type __pos, size_type __n, const _Self& __s) const { return _M_non_dbg_impl.compare(__pos, __n, __s._M_non_dbg_impl); } int compare(size_type __pos1, size_type __n1, const _Self& __s, size_type __pos2, size_type __n2) const { return _M_non_dbg_impl.compare(__pos1, __n1, __s._M_non_dbg_impl, __pos2, __n2); } int compare(const _CharT* __s) const { _STLP_FIX_LITERAL_BUG(__s) return _M_non_dbg_impl.compare(__s); } int compare(size_type __pos, size_type __n, const _CharT* __s) const { _STLP_FIX_LITERAL_BUG(__s) return _M_non_dbg_impl.compare(__pos, __n, __s); } int compare(size_type __pos1, size_type __n1, const _CharT* __s, size_type __n2) const { _STLP_FIX_LITERAL_BUG(__s) return _M_non_dbg_impl.compare(__pos1, __n1, __s, __n2); } // Helper functions for compare. static int _STLP_CALL _M_compare(const _CharT* __f1, const _CharT* __l1, const _CharT* __f2, const _CharT* __l2) { return _Base::_M_compare(__f1, __l1, __f2, __l2); } static int _STLP_CALL _M_compare(const_iterator __f1, const_iterator __l1, const _CharT* __f2, const _CharT* __l2) { return _Base::_M_compare(__f1._M_iterator, __l1._M_iterator, __f2, __l2); } static int _STLP_CALL _M_compare(const _CharT* __f1, const _CharT* __l1, const_iterator __f2, const_iterator __l2) { return _Base::_M_compare(__f1, __l1, __f2._M_iterator, __l2._M_iterator); } static int _STLP_CALL _M_compare(const_iterator __f1, const_iterator __l1, const_iterator __f2, const_iterator __l2) { return _Base::_M_compare(__f1._M_iterator, __l1._M_iterator, __f2._M_iterator, __l2._M_iterator); } const _CharT* c_str() const { return _M_non_dbg_impl.c_str(); } const _CharT* data() const { return _M_non_dbg_impl.data(); } size_type copy(_CharT* __s, size_type __n, size_type __pos = 0) const { return _M_non_dbg_impl.copy(__s, __n, __pos); } // find. size_type find(const _Self& __s, size_type __pos = 0) const { return _M_non_dbg_impl.find(__s._M_non_dbg_impl, __pos); } size_type find(const _CharT* __s, size_type __pos = 0) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find(__s, __pos); } size_type find(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find(__s, __pos, __n); } // WIE: Versant schema compiler 5.2.2 ICE workaround size_type find(_CharT __c) const { return find(__c, 0); } size_type find(_CharT __c, size_type __pos /* = 0 */) const { return _M_non_dbg_impl.find(__c, __pos); } // rfind. size_type rfind(const _Self& __s, size_type __pos = npos) const { return _M_non_dbg_impl.rfind(__s._M_non_dbg_impl, __pos); } size_type rfind(const _CharT* __s, size_type __pos = npos) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.rfind(__s, __pos); } size_type rfind(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.rfind(__s, __pos, __n); } size_type rfind(_CharT __c, size_type __pos = npos) const { return _M_non_dbg_impl.rfind(__c, __pos); } // find_first_of size_type find_first_of(const _Self& __s, size_type __pos = 0) const { return _M_non_dbg_impl.find_first_of(__s._M_non_dbg_impl, __pos); } size_type find_first_of(const _CharT* __s, size_type __pos = 0) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_first_of(__s, __pos); } size_type find_first_of(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_first_of(__s, __pos, __n); } size_type find_first_of(_CharT __c, size_type __pos = 0) const { return _M_non_dbg_impl.find_first_of(__c, __pos); } // find_last_of size_type find_last_of(const _Self& __s, size_type __pos = npos) const { return _M_non_dbg_impl.find_last_of(__s._M_non_dbg_impl, __pos); } size_type find_last_of(const _CharT* __s, size_type __pos = npos) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_last_of(__s, __pos); } size_type find_last_of(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_last_of(__s, __pos, __n); } size_type find_last_of(_CharT __c, size_type __pos = npos) const { return _M_non_dbg_impl.rfind(__c, __pos); } // find_first_not_of size_type find_first_not_of(const _Self& __s, size_type __pos = 0) const { return _M_non_dbg_impl.find_first_not_of(__s._M_non_dbg_impl, __pos); } size_type find_first_not_of(const _CharT* __s, size_type __pos = 0) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_first_not_of(__s, __pos); } size_type find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_first_not_of(__s, __pos, __n); } size_type find_first_not_of(_CharT __c, size_type __pos = 0) const { return _M_non_dbg_impl.find_first_not_of(__c, __pos); } // find_last_not_of size_type find_last_not_of(const _Self& __s, size_type __pos = npos) const { return _M_non_dbg_impl.find_last_not_of(__s._M_non_dbg_impl, __pos); } size_type find_last_not_of(const _CharT* __s, size_type __pos = npos) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_last_not_of(__s, __pos); } size_type find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const { _STLP_FIX_LITERAL_BUG(__s) _STLP_VERBOSE_ASSERT((__s != 0), _StlMsg_INVALID_ARGUMENT) return _M_non_dbg_impl.find_last_not_of(__s, __pos, __n); } size_type find_last_not_of(_CharT __c, size_type __pos = npos) const { return _M_non_dbg_impl.find_last_not_of(__c, __pos); } #if defined (_STLP_USE_TEMPLATE_EXPRESSION) # include #endif }; // This is a hook to instantiate STLport exports in a designated DLL #if defined (_STLP_USE_TEMPLATE_EXPORT) && !defined (_STLP_USE_MSVC6_MEM_T_BUG_WORKAROUND) _STLP_MOVE_TO_PRIV_NAMESPACE _STLP_EXPORT_TEMPLATE_CLASS __construct_checker<_STLP_NON_DBG_STRING_NAME , allocator > >; _STLP_MOVE_TO_STD_NAMESPACE _STLP_EXPORT_TEMPLATE_CLASS basic_string, allocator >; # if defined (_STLP_HAS_WCHAR_T) _STLP_MOVE_TO_PRIV_NAMESPACE _STLP_EXPORT_TEMPLATE_CLASS __construct_checker<_STLP_NON_DBG_STRING_NAME , allocator > >; _STLP_MOVE_TO_STD_NAMESPACE _STLP_EXPORT_TEMPLATE_CLASS basic_string, allocator >; # endif #endif #undef _STLP_NON_DBG_STRING #undef _STLP_NON_DBG_STRING_NAME #if defined (__GNUC__) && (__GNUC__ == 2) && (__GNUC_MINOR__ == 96) template const size_t basic_string<_CharT, _Traits, _Alloc>::npos = ~(size_t) 0; #endif #if defined (basic_string) _STLP_MOVE_TO_STD_NAMESPACE #undef basic_string #endif _STLP_END_NAMESPACE #endif /* _STLP_DBG_STRING */ // Local Variables: // mode:C++ // End: