epoc32/include/stdapis/stlport/stl/debug/_vector.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 0 061f57f2323e
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@2
     1
/*
williamr@2
     2
 *
williamr@2
     3
 * Copyright (c) 1994
williamr@2
     4
 * Hewlett-Packard Company
williamr@2
     5
 *
williamr@2
     6
 * Copyright (c) 1996,1997
williamr@2
     7
 * Silicon Graphics Computer Systems, Inc.
williamr@2
     8
 *
williamr@2
     9
 * Copyright (c) 1997
williamr@2
    10
 * Moscow Center for SPARC Technology
williamr@2
    11
 *
williamr@2
    12
 * Copyright (c) 1999 
williamr@2
    13
 * Boris Fomitchev
williamr@2
    14
 *
williamr@2
    15
 * This material is provided "as is", with absolutely no warranty expressed
williamr@2
    16
 * or implied. Any use is at your own risk.
williamr@2
    17
 *
williamr@2
    18
 * Permission to use or copy this software for any purpose is hereby granted 
williamr@2
    19
 * without fee, provided the above notices are retained on all copies.
williamr@2
    20
 * Permission to modify the code and to distribute modified code is granted,
williamr@2
    21
 * provided the above notices are retained, and a notice that the code was
williamr@2
    22
 * modified is included with the above copyright notice.
williamr@2
    23
 *
williamr@2
    24
 */
williamr@2
    25
williamr@2
    26
/* NOTE: This is an internal header file, included by other STL headers.
williamr@2
    27
 *   You should not attempt to use it directly.
williamr@2
    28
 */
williamr@2
    29
williamr@2
    30
#ifndef _STLP_INTERNAL_DBG_VECTOR_H
williamr@2
    31
#define _STLP_INTERNAL_DBG_VECTOR_H
williamr@2
    32
williamr@2
    33
#include <stl/debug/_iterator.h>
williamr@2
    34
williamr@2
    35
# ifndef _STLP_USE_WRAPPER_FOR_ALLOC_PARAM
williamr@2
    36
#  undef  _DBG_vector
williamr@2
    37
#  define _DBG_vector vector
williamr@2
    38
# endif
williamr@2
    39
williamr@2
    40
#  define _STLP_DBG_VECTOR_BASE __WORKAROUND_DBG_RENAME(vector) <_Tp, _Alloc>
williamr@2
    41
williamr@2
    42
_STLP_BEGIN_NAMESPACE
williamr@2
    43
williamr@2
    44
# ifdef _STLP_DEBUG_USE_DISTINCT_VALUE_TYPE_HELPERS
williamr@2
    45
template <class _Tp, class _Alloc>
williamr@2
    46
inline _Tp*
williamr@2
    47
value_type(const  _DBG_iter_base< _STLP_DBG_VECTOR_BASE >&) {
williamr@2
    48
  return (_Tp*)0;
williamr@2
    49
}
williamr@2
    50
template <class _Tp, class _Alloc>
williamr@2
    51
inline random_access_iterator_tag
williamr@2
    52
iterator_category(const  _DBG_iter_base< _STLP_DBG_VECTOR_BASE >&) {
williamr@2
    53
  return random_access_iterator_tag();
williamr@2
    54
}
williamr@2
    55
# endif
williamr@2
    56
williamr@2
    57
template <class _Tp, class _NcIt>
williamr@2
    58
struct _Vector_nonconst_traits
williamr@2
    59
{
williamr@2
    60
	typedef _Nonconst_traits<_Tp> _BaseT;
williamr@2
    61
	typedef _Tp value_type;
williamr@2
    62
	typedef _Tp& reference;
williamr@2
    63
	typedef _Tp* pointer;
williamr@2
    64
	typedef _Vector_nonconst_traits<_Tp, _NcIt> _Non_const_traits;
williamr@2
    65
};
williamr@2
    66
williamr@2
    67
template <class _Tp, class _NcIt>
williamr@2
    68
struct _Vector_const_traits
williamr@2
    69
{
williamr@2
    70
	typedef _Const_traits<_Tp> _BaseT;
williamr@2
    71
	typedef _Tp value_type;
williamr@2
    72
	typedef const _Tp& reference;
williamr@2
    73
	typedef const _Tp* pointer;
williamr@2
    74
	typedef _Vector_nonconst_traits<_Tp, _NcIt> _Non_const_traits;
williamr@2
    75
};
williamr@2
    76
williamr@2
    77
_STLP_TEMPLATE_NULL
williamr@2
    78
struct _Vector_nonconst_traits<bool, _Bit_iterator>
williamr@2
    79
{
williamr@2
    80
	typedef _Bit_iterator::value_type value_type;
williamr@2
    81
	typedef _Bit_iterator::reference reference;
williamr@2
    82
	typedef _Bit_iterator::pointer pointer;
williamr@2
    83
	typedef _Vector_nonconst_traits<bool, _Bit_iterator> _Non_const_traits;
williamr@2
    84
};
williamr@2
    85
williamr@2
    86
_STLP_TEMPLATE_NULL
williamr@2
    87
struct _Vector_const_traits<bool, _Bit_iterator>
williamr@2
    88
{
williamr@2
    89
	typedef _Bit_const_iterator::value_type value_type;
williamr@2
    90
	typedef _Bit_const_iterator::reference reference;
williamr@2
    91
	typedef _Bit_const_iterator::pointer pointer;
williamr@2
    92
	typedef _Vector_nonconst_traits<bool, _Bit_iterator> _Non_const_traits;
williamr@2
    93
};
williamr@2
    94
williamr@2
    95
template <class _Tp, _STLP_DBG_ALLOCATOR_SELECT(_Tp) >
williamr@2
    96
class _DBG_vector : public  _STLP_DBG_VECTOR_BASE {
williamr@2
    97
private:
williamr@2
    98
  typedef _STLP_DBG_VECTOR_BASE _Base;
williamr@2
    99
  typedef _DBG_vector<_Tp, _Alloc> _Self;
williamr@2
   100
  mutable __owned_list _M_iter_list;
williamr@2
   101
williamr@2
   102
public:
williamr@2
   103
williamr@2
   104
  __IMPORT_CONTAINER_TYPEDEFS(_Base)
williamr@2
   105
williamr@2
   106
  typedef _DBG_iter<_Base,
williamr@2
   107
      _Vector_nonconst_traits<value_type, typename _Base::iterator> > iterator;
williamr@2
   108
    
williamr@2
   109
  typedef _DBG_iter<_Base,
williamr@2
   110
      _Vector_const_traits<value_type, typename _Base::iterator> > const_iterator;
williamr@2
   111
williamr@2
   112
  _STLP_DECLARE_RANDOM_ACCESS_REVERSE_ITERATORS;
williamr@2
   113
williamr@2
   114
  iterator begin() { return iterator(&_M_iter_list, this->_M_start); }
williamr@2
   115
  const_iterator begin() const { return const_iterator(&_M_iter_list, this->_M_start); }
williamr@2
   116
  iterator end() { return iterator(&_M_iter_list, this->_M_finish); }
williamr@2
   117
  const_iterator end() const { return const_iterator(&_M_iter_list, this->_M_finish); }
williamr@2
   118
williamr@2
   119
  reverse_iterator rbegin()
williamr@2
   120
    { return reverse_iterator(end()); }
williamr@2
   121
  const_reverse_iterator rbegin() const
williamr@2
   122
    { return const_reverse_iterator(end()); }
williamr@2
   123
  reverse_iterator rend()
williamr@2
   124
    { return reverse_iterator(begin()); }
williamr@2
   125
  const_reverse_iterator rend() const
williamr@2
   126
    { return const_reverse_iterator(begin()); }
williamr@2
   127
williamr@2
   128
  reference operator[](size_type __n) {
williamr@2
   129
    _STLP_VERBOSE_ASSERT(__n < _Base::size(), _StlMsg_OUT_OF_BOUNDS)
williamr@2
   130
    return _Base::operator[](__n);
williamr@2
   131
  }
williamr@2
   132
williamr@2
   133
  const_reference operator[](size_type __n) const {
williamr@2
   134
    _STLP_VERBOSE_ASSERT(__n < _Base::size(), _StlMsg_OUT_OF_BOUNDS)
williamr@2
   135
    return _Base::operator[](__n);
williamr@2
   136
  }
williamr@2
   137
williamr@2
   138
  _Base* _Get_base() { return (_Base*)this; }
williamr@2
   139
  const _Base* _Get_base() const { return (const _Base*)this; }
williamr@2
   140
williamr@2
   141
  explicit _DBG_vector(const allocator_type& __a = allocator_type())
williamr@2
   142
    : _STLP_DBG_VECTOR_BASE(__a), _M_iter_list((const _Base*)this)  {}
williamr@2
   143
williamr@2
   144
  _DBG_vector(size_type __n, const _Tp& __value,
williamr@2
   145
         const allocator_type& __a = allocator_type()) 
williamr@2
   146
    : _STLP_DBG_VECTOR_BASE(__n, __value, __a), _M_iter_list((const _Base*)this) {}
williamr@2
   147
williamr@2
   148
  explicit _DBG_vector(size_type __n)
williamr@2
   149
    : _STLP_DBG_VECTOR_BASE(__n), _M_iter_list((const _Base*)this) {}
williamr@2
   150
williamr@2
   151
williamr@2
   152
  _DBG_vector(const _Self& __x) 
williamr@2
   153
    : _STLP_DBG_VECTOR_BASE(__x), _M_iter_list((const _Base*)this) {}
williamr@2
   154
williamr@2
   155
#if defined (_STLP_MEMBER_TEMPLATES)
williamr@2
   156
# ifdef _STLP_NEEDS_EXTRA_TEMPLATE_CONSTRUCTORS
williamr@2
   157
  template <class _InputIterator>
williamr@2
   158
  _DBG_vector(_InputIterator __first, _InputIterator __last):
williamr@2
   159
    _STLP_DBG_VECTOR_BASE(__first, __last), _M_iter_list((const _Base*)this) {}
williamr@2
   160
# endif
williamr@2
   161
  template <class _InputIterator>
williamr@2
   162
  _DBG_vector(_InputIterator __first, _InputIterator __last,
williamr@2
   163
         const allocator_type& __a _STLP_ALLOCATOR_TYPE_DFL) :
williamr@2
   164
    _STLP_DBG_VECTOR_BASE(__first, __last, __a), _M_iter_list((const _Base*)this) {}
williamr@2
   165
williamr@2
   166
#else
williamr@2
   167
  _DBG_vector(const _Tp* __first, const _Tp* __last,
williamr@2
   168
         const allocator_type& __a = allocator_type())
williamr@2
   169
    : _STLP_DBG_VECTOR_BASE(__first, __last, __a), _M_iter_list((const _Base*)this) {}
williamr@2
   170
williamr@2
   171
  // mysterious VC++ bug ?
williamr@2
   172
  _DBG_vector(const_iterator __first, const_iterator __last , 
williamr@2
   173
	      const allocator_type& __a = allocator_type())
williamr@2
   174
    : _STLP_DBG_VECTOR_BASE(__first._M_iterator, __last._M_iterator, __a),
williamr@2
   175
      _M_iter_list((const _Base*)this) { }
williamr@2
   176
williamr@2
   177
#endif /* _STLP_MEMBER_TEMPLATES */
williamr@2
   178
williamr@2
   179
  _Self& operator=(const _Self& __x) {
williamr@2
   180
    _M_iter_list._Invalidate_all();
williamr@2
   181
    (_Base&)*this = (const _Base&)__x;
williamr@2
   182
    return *this;
williamr@2
   183
  }
williamr@2
   184
williamr@2
   185
  reference front() { return *begin(); }
williamr@2
   186
  const_reference front() const { return *begin(); }
williamr@2
   187
williamr@2
   188
  reference back() {
williamr@2
   189
    iterator __tmp = end();
williamr@2
   190
    --__tmp;
williamr@2
   191
    return *__tmp;
williamr@2
   192
  }
williamr@2
   193
  const_reference back() const {
williamr@2
   194
    const_iterator __tmp = end();
williamr@2
   195
    --__tmp;
williamr@2
   196
    return *__tmp;
williamr@2
   197
  }
williamr@2
   198
williamr@2
   199
  void swap(_Self& __x) {
williamr@2
   200
    _M_iter_list._Swap_owners(__x._M_iter_list);
williamr@2
   201
    _Base::swap((_Base&)__x);
williamr@2
   202
  }
williamr@2
   203
williamr@2
   204
  iterator insert(iterator __position, const _Tp& __x) {
williamr@2
   205
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   206
    if (this->size()+1 > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   207
    return iterator(&_M_iter_list, _Base::insert(__position._M_iterator, __x));
williamr@2
   208
  }
williamr@2
   209
williamr@2
   210
  iterator insert(iterator __position) {
williamr@2
   211
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   212
    if (this->size()+1 > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   213
    return iterator(&_M_iter_list, _Base::insert(__position._M_iterator));    
williamr@2
   214
  }
williamr@2
   215
williamr@2
   216
#ifdef _STLP_MEMBER_TEMPLATES
williamr@2
   217
  // Check whether it's an integral type.  If so, it's not an iterator.
williamr@2
   218
  template <class _InputIterator>
williamr@2
   219
  void insert(iterator __position, _InputIterator __first, _InputIterator __last) {
williamr@2
   220
    _STLP_DEBUG_CHECK(__check_range(__first,__last))
williamr@2
   221
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   222
    size_type __n = distance(__first, __last);
williamr@2
   223
    if (this->size()+__n > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   224
    _Base::insert(__position._M_iterator, __first, __last);    
williamr@2
   225
  }
williamr@2
   226
#else /* _STLP_MEMBER_TEMPLATES */
williamr@2
   227
  void insert(iterator __position,
williamr@2
   228
              const_iterator __first, const_iterator __last) {
williamr@2
   229
    _STLP_DEBUG_CHECK(__check_range(__first,__last))
williamr@2
   230
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   231
    size_type __n = distance(__first, __last);
williamr@2
   232
    if (this->size()+__n > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   233
    _Base::insert(__position._M_iterator,
williamr@2
   234
		  __first._M_iterator, __last._M_iterator);        
williamr@2
   235
  }
williamr@2
   236
williamr@2
   237
  void insert (iterator __position, const_pointer __first, const_pointer __last) {
williamr@2
   238
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   239
    _STLP_DEBUG_CHECK(__check_range(__first,__last))
williamr@2
   240
    size_type __n = distance(__first, __last);
williamr@2
   241
    if (this->size()+__n > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   242
    _Base::insert(__position._M_iterator, __first, __last);  
williamr@2
   243
}
williamr@2
   244
#endif /* _STLP_MEMBER_TEMPLATES */
williamr@2
   245
williamr@2
   246
  void insert (iterator __position, size_type __n, const _Tp& __x){
williamr@2
   247
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   248
    if (this->size()+__n > this->capacity()) _M_iter_list._Invalidate_all();  
williamr@2
   249
    _Base::insert(__position._M_iterator, __n, __x);
williamr@2
   250
  }
williamr@2
   251
  
williamr@2
   252
  void pop_back() {
williamr@2
   253
    _STLP_VERBOSE_ASSERT(!this->empty(), _StlMsg_EMPTY_CONTAINER)
williamr@2
   254
    __invalidate_iterator(&_M_iter_list,end());
williamr@2
   255
    _Base::pop_back();
williamr@2
   256
  }
williamr@2
   257
  iterator erase(iterator __position) {
williamr@2
   258
    _STLP_DEBUG_CHECK(__check_if_owner(&_M_iter_list, __position))
williamr@2
   259
    _STLP_VERBOSE_ASSERT(__position._M_iterator !=this->_M_finish,_StlMsg_ERASE_PAST_THE_END)
williamr@2
   260
    __invalidate_range(&_M_iter_list, __position+1, end());
williamr@2
   261
    return iterator(&_M_iter_list,_Base::erase(__position._M_iterator));
williamr@2
   262
  }
williamr@2
   263
  iterator erase(iterator __first, iterator __last) {
williamr@2
   264
    _STLP_DEBUG_CHECK(__check_range(__first,__last, begin(), end()))
williamr@2
   265
    __invalidate_range(&_M_iter_list, __first._M_iterator == this->_M_finish ? 
williamr@2
   266
		       __first : __first+1, end());
williamr@2
   267
    return iterator(&_M_iter_list, _Base::erase(__first._M_iterator, __last._M_iterator));
williamr@2
   268
  }
williamr@2
   269
  void clear() { 
williamr@2
   270
    _M_iter_list._Invalidate_all();
williamr@2
   271
    _Base::clear();
williamr@2
   272
  }
williamr@2
   273
  void push_back(const _Tp& __x) {
williamr@2
   274
    if (this->size()+1 > this->capacity()) _M_iter_list._Invalidate_all();
williamr@2
   275
    _Base::push_back(__x);
williamr@2
   276
  }
williamr@2
   277
};
williamr@2
   278
williamr@2
   279
#define _STLP_TEMPLATE_HEADER template <class _Tp, class _Alloc>
williamr@2
   280
#define _STLP_TEMPLATE_CONTAINER _DBG_vector<_Tp, _Alloc>
williamr@2
   281
#define _STLP_TEMPLATE_CONTAINER_BASE _STLP_DBG_VECTOR_BASE
williamr@2
   282
#include <stl/debug/_relops_cont.h>
williamr@2
   283
#undef _STLP_TEMPLATE_CONTAINER_BASE
williamr@2
   284
#undef _STLP_TEMPLATE_CONTAINER
williamr@2
   285
#undef _STLP_TEMPLATE_HEADER
williamr@2
   286
williamr@2
   287
# if defined (_STLP_USE_TEMPLATE_EXPORT) 
williamr@2
   288
 _STLP_EXPORT_TEMPLATE_CLASS _DBG_vector <void*,allocator<void*> >;
williamr@2
   289
#  endif /* _STLP_USE_TEMPLATE_EXPORT */
williamr@2
   290
williamr@2
   291
_STLP_END_NAMESPACE
williamr@2
   292
williamr@2
   293
# undef _STLP_DBG_VECTOR_BASE
williamr@2
   294
# undef _DBG_vector
williamr@2
   295
williamr@2
   296
#endif /* _STLP_DBG_VECTOR_H */
williamr@2
   297
williamr@2
   298
// Local Variables:
williamr@2
   299
// mode:C++
williamr@2
   300
// End: