epoc32/include/stdapis/stlport/stl/_list.c
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
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@4
     1
/*
williamr@4
     2
 *
williamr@4
     3
 *
williamr@4
     4
 * Copyright (c) 1994
williamr@4
     5
 * Hewlett-Packard Company
williamr@4
     6
 *
williamr@4
     7
 * Copyright (c) 1996,1997
williamr@4
     8
 * Silicon Graphics Computer Systems, Inc.
williamr@4
     9
 *
williamr@4
    10
 * Copyright (c) 1997
williamr@4
    11
 * Moscow Center for SPARC Technology
williamr@4
    12
 *
williamr@4
    13
 * Copyright (c) 1999 
williamr@4
    14
 * Boris Fomitchev
williamr@4
    15
 *
williamr@4
    16
 * This material is provided "as is", with absolutely no warranty expressed
williamr@4
    17
 * or implied. Any use is at your own risk.
williamr@4
    18
 *
williamr@4
    19
 * Permission to use or copy this software for any purpose is hereby granted 
williamr@4
    20
 * without fee, provided the above notices are retained on all copies.
williamr@4
    21
 * Permission to modify the code and to distribute modified code is granted,
williamr@4
    22
 * provided the above notices are retained, and a notice that the code was
williamr@4
    23
 * modified is included with the above copyright notice.
williamr@4
    24
 *
williamr@4
    25
 */
williamr@4
    26
#ifndef _STLP_LIST_C
williamr@4
    27
#define _STLP_LIST_C
williamr@4
    28
williamr@4
    29
#ifndef _STLP_INTERNAL_LIST_H
williamr@4
    30
# include <stl/_list.h>
williamr@4
    31
#endif
williamr@4
    32
williamr@4
    33
#if defined (__WATCOMC__) || defined (_STLP_USE_TRAP_LEAVE)
williamr@4
    34
#include <vector>
williamr@4
    35
#endif
williamr@4
    36
williamr@4
    37
# undef list
williamr@4
    38
# define  list  __WORKAROUND_DBG_RENAME(list)
williamr@4
    39
williamr@4
    40
_STLP_BEGIN_NAMESPACE
williamr@4
    41
williamr@4
    42
# if defined (_STLP_EXPOSE_GLOBALS_IMPLEMENTATION)
williamr@4
    43
williamr@4
    44
template <class _Dummy>
williamr@4
    45
void _STLP_CALL
williamr@4
    46
_List_global<_Dummy>::_Transfer(_List_node_base* __position, 
williamr@4
    47
				_List_node_base* __first, _List_node_base* __last) {
williamr@4
    48
  if (__position != __last) {
williamr@4
    49
    // Remove [first, last) from its old position.
williamr@4
    50
    ((_Node*) (__last->_M_prev))->_M_next = __position;
williamr@4
    51
    ((_Node*) (__first->_M_prev))->_M_next    = __last;
williamr@4
    52
    ((_Node*) (__position->_M_prev))->_M_next = __first; 
williamr@4
    53
    
williamr@4
    54
    // Splice [first, last) into its new position.
williamr@4
    55
    _Node* __tmp = (_Node*) (__position->_M_prev);
williamr@4
    56
    __position->_M_prev = __last->_M_prev;
williamr@4
    57
    __last->_M_prev      = __first->_M_prev; 
williamr@4
    58
    __first->_M_prev    = __tmp;
williamr@4
    59
  }
williamr@4
    60
}
williamr@4
    61
williamr@4
    62
#endif /* defined (__BUILDING_STLPORT) || ! defined (_STLP_OWN_IOSTREAMS) */
williamr@4
    63
williamr@4
    64
williamr@4
    65
template <class _Tp, class _Alloc>
williamr@4
    66
void 
williamr@4
    67
_List_base<_Tp,_Alloc>::clear() 
williamr@4
    68
{
williamr@4
    69
  _List_node<_Tp>* __cur = this->_M_node._M_data;
williamr@4
    70
  if (!__cur)
williamr@4
    71
	return;
williamr@4
    72
  __cur = (_List_node<_Tp>*)__cur->_M_next;
williamr@4
    73
  while (__cur != this->_M_node._M_data) {
williamr@4
    74
    _List_node<_Tp>* __tmp = __cur;
williamr@4
    75
    __cur = (_List_node<_Tp>*) __cur->_M_next;
williamr@4
    76
    _STLP_STD::_Destroy(&__tmp->_M_data);
williamr@4
    77
    this->_M_node.deallocate(__tmp, 1);
williamr@4
    78
  }
williamr@4
    79
  this->_M_node._M_data->_M_next = this->_M_node._M_data;
williamr@4
    80
  this->_M_node._M_data->_M_prev = this->_M_node._M_data;
williamr@4
    81
}
williamr@4
    82
williamr@4
    83
# if defined (_STLP_NESTED_TYPE_PARAM_BUG) 
williamr@4
    84
#  define size_type      size_t
williamr@4
    85
# endif
williamr@4
    86
williamr@4
    87
template <class _Tp, class _Alloc>
williamr@4
    88
void list<_Tp, _Alloc>::resize(size_type __new_size, _Tp __x)
williamr@4
    89
{
williamr@4
    90
  iterator __i = begin();
williamr@4
    91
  size_type __len = 0;
williamr@4
    92
  for ( ; __i != end() && __len < __new_size; ++__i, ++__len);
williamr@4
    93
williamr@4
    94
  if (__len == __new_size)
williamr@4
    95
    erase(__i, end());
williamr@4
    96
  else                          // __i == end()
williamr@4
    97
    insert(end(), __new_size - __len, __x);
williamr@4
    98
}
williamr@4
    99
williamr@4
   100
template <class _Tp, class _Alloc>
williamr@4
   101
list<_Tp, _Alloc>& list<_Tp, _Alloc>::operator=(const list<_Tp, _Alloc>& __x)
williamr@4
   102
{
williamr@4
   103
  if (this != &__x) {
williamr@4
   104
    iterator __first1 = begin();
williamr@4
   105
    iterator __last1 = end();
williamr@4
   106
    const_iterator __first2 = __x.begin();
williamr@4
   107
    const_iterator __last2 = __x.end();
williamr@4
   108
    while (__first1 != __last1 && __first2 != __last2) 
williamr@4
   109
      *__first1++ = *__first2++;
williamr@4
   110
    if (__first2 == __last2)
williamr@4
   111
      erase(__first1, __last1);
williamr@4
   112
    else
williamr@4
   113
      insert(__last1, __first2, __last2);
williamr@4
   114
  }
williamr@4
   115
  return *this;
williamr@4
   116
}
williamr@4
   117
williamr@4
   118
template <class _Tp, class _Alloc>
williamr@4
   119
void list<_Tp, _Alloc>::_M_fill_assign(size_type __n, const _Tp& __val) {
williamr@4
   120
  iterator __i = begin();
williamr@4
   121
  for ( ; __i != end() && __n > 0; ++__i, --__n)
williamr@4
   122
    *__i = __val;
williamr@4
   123
  if (__n > 0)
williamr@4
   124
    insert(end(), __n, __val);
williamr@4
   125
  else
williamr@4
   126
    erase(__i, end());
williamr@4
   127
}
williamr@4
   128
williamr@4
   129
template <class _Tp, class _Alloc, class _Predicate> 
williamr@4
   130
void _S_remove_if(list<_Tp, _Alloc>& __that, _Predicate __pred)  {
williamr@4
   131
  typename list<_Tp, _Alloc>::iterator __first = __that.begin();
williamr@4
   132
  typename list<_Tp, _Alloc>::iterator __last = __that.end();
williamr@4
   133
  while (__first != __last) {
williamr@4
   134
    typename list<_Tp, _Alloc>::iterator __next = __first;
williamr@4
   135
    ++__next;
williamr@4
   136
    if (__pred(*__first)) __that.erase(__first);
williamr@4
   137
    __first = __next;
williamr@4
   138
  }
williamr@4
   139
}
williamr@4
   140
williamr@4
   141
template <class _Tp, class _Alloc, class _BinaryPredicate>
williamr@4
   142
void _S_unique(list<_Tp, _Alloc>& __that, _BinaryPredicate __binary_pred) {
williamr@4
   143
  typename list<_Tp, _Alloc>::iterator __first = __that.begin();
williamr@4
   144
  typename list<_Tp, _Alloc>::iterator __last = __that.end();
williamr@4
   145
  if (__first == __last) return;
williamr@4
   146
  typename list<_Tp, _Alloc>::iterator __next = __first;
williamr@4
   147
  while (++__next != __last) {
williamr@4
   148
    if (__binary_pred(*__first, *__next))
williamr@4
   149
      __that.erase(__next);
williamr@4
   150
    else
williamr@4
   151
      __first = __next;
williamr@4
   152
    __next = __first;
williamr@4
   153
  }
williamr@4
   154
}
williamr@4
   155
williamr@4
   156
template <class _Tp, class _Alloc, class _StrictWeakOrdering>
williamr@4
   157
void _S_merge(list<_Tp, _Alloc>& __that, list<_Tp, _Alloc>& __x,
williamr@4
   158
	      _StrictWeakOrdering __comp) {
williamr@4
   159
  typedef typename list<_Tp, _Alloc>::iterator _Literator;
williamr@4
   160
  _Literator __first1 = __that.begin();
williamr@4
   161
  _Literator __last1 = __that.end();
williamr@4
   162
  _Literator __first2 = __x.begin();
williamr@4
   163
  _Literator __last2 = __x.end();
williamr@4
   164
  while (__first1 != __last1 && __first2 != __last2)
williamr@4
   165
    if (__comp(*__first2, *__first1)) {
williamr@4
   166
      _Literator __next = __first2;
williamr@4
   167
      _List_global_inst::_Transfer(__first1._M_node, __first2._M_node, (++__next)._M_node);
williamr@4
   168
      __first2 = __next;
williamr@4
   169
    }
williamr@4
   170
    else
williamr@4
   171
      ++__first1;
williamr@4
   172
  if (__first2 != __last2) _List_global_inst::_Transfer(__last1._M_node, __first2._M_node, __last2._M_node);
williamr@4
   173
}
williamr@4
   174
williamr@4
   175
template <class _Tp, class _Alloc, class _StrictWeakOrdering>
williamr@4
   176
void _S_sort(list<_Tp, _Alloc>& __that, _StrictWeakOrdering __comp) {
williamr@4
   177
  // Do nothing if the list has length 0 or 1.
williamr@4
   178
  if (__that._M_node._M_data->_M_next != __that._M_node._M_data &&
williamr@4
   179
      (__that._M_node._M_data->_M_next)->_M_next != __that._M_node._M_data) {
williamr@4
   180
williamr@4
   181
#if !defined (__WATCOMC__)
williamr@4
   182
#ifdef _STLP_USE_TRAP_LEAVE
williamr@4
   183
    typedef vector<list<_Tp, _Alloc>*, _Alloc>  _TmpVec;
williamr@4
   184
    _TmpVec* __pTmp = new _TmpVec();
williamr@4
   185
    _TmpVec& __counter = *__pTmp;
williamr@4
   186
    for (int i = 0; 1< 64; ++i) {
williamr@4
   187
      list<_Tp, _Alloc>* __pTmp2 = new list<_Tp, _Alloc>;
williamr@4
   188
      __counter.push_back (__pTmp2);
williamr@4
   189
    }
williamr@4
   190
    list<_Tp, _Alloc>* __pcarry = new list<_Tp, _Alloc>;
williamr@4
   191
    list<_Tp, _Alloc>& __carry = *__pcarry;
williamr@4
   192
#else
williamr@4
   193
    list<_Tp, _Alloc> __counter[64];
williamr@4
   194
    list<_Tp, _Alloc> __carry;
williamr@4
   195
#endif
williamr@4
   196
#else
williamr@4
   197
    list<_Tp, _Alloc> __carry;
williamr@4
   198
    __vector__<list<_Tp, _Alloc>, _Alloc> __counter(64);		
williamr@4
   199
#endif
williamr@4
   200
    int __fill = 0;
williamr@4
   201
#ifdef _STLP_USE_TRAP_LEAVE
williamr@4
   202
    while (!__that.empty()) {
williamr@4
   203
      __carry.splice(__carry.begin(), __that, __that.begin());
williamr@4
   204
      int __i = 0;
williamr@4
   205
williamr@4
   206
      while(__i < __fill && !__counter[__i]->empty()) {
williamr@4
   207
	_S_merge(*__counter[__i], __carry, __comp);
williamr@4
   208
	__carry.swap(*__counter[__i++]);
williamr@4
   209
      }
williamr@4
   210
      __carry.swap(*__counter[__i]);         
williamr@4
   211
      if (__i == __fill) ++__fill;
williamr@4
   212
    } 
williamr@4
   213
    
williamr@4
   214
    for (int __i = 1; __i < __fill; ++__i) 
williamr@4
   215
      _S_merge(*__counter[__i], *__counter[__i-1], __comp);
williamr@4
   216
    __that.swap(*__counter[__fill-1]);
williamr@4
   217
williamr@4
   218
    // those objects won't just go away
williamr@4
   219
    __counter.clear();
williamr@4
   220
    CleanupStack::Pop(66);
williamr@4
   221
  }    
williamr@4
   222
# else
williamr@4
   223
    while (!__that.empty()) {
williamr@4
   224
      __carry.splice(__carry.begin(), __that, __that.begin());
williamr@4
   225
      int __i = 0;
williamr@4
   226
williamr@4
   227
      while(__i < __fill && !__counter[__i].empty()) {
williamr@4
   228
	_S_merge(__counter[__i], __carry, __comp);
williamr@4
   229
	__carry.swap(__counter[__i++]);
williamr@4
   230
      }
williamr@4
   231
      __carry.swap(__counter[__i]);         
williamr@4
   232
      if (__i == __fill) ++__fill;
williamr@4
   233
    } 
williamr@4
   234
    
williamr@4
   235
    for (int __i = 1; __i < __fill; ++__i) 
williamr@4
   236
      _S_merge(__counter[__i], __counter[__i-1], __comp);
williamr@4
   237
    __that.swap(__counter[__fill-1]);
williamr@4
   238
  }
williamr@4
   239
# endif
williamr@4
   240
williamr@4
   241
}
williamr@4
   242
williamr@4
   243
# undef  list
williamr@4
   244
# undef  size_type
williamr@4
   245
williamr@4
   246
_STLP_END_NAMESPACE
williamr@4
   247
williamr@4
   248
#endif /*  _STLP_LIST_C */
williamr@4
   249
williamr@4
   250
// Local Variables:
williamr@4
   251
// mode:C++
williamr@4
   252
// End: