epoc32/include/tools/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
#ifndef _STLP_CARRAY_H
williamr@4
    34
#  include <stl/_carray.h>
williamr@4
    35
#endif
williamr@4
    36
williamr@4
    37
#ifndef _STLP_RANGE_ERRORS_H
williamr@4
    38
#  include <stl/_range_errors.h>
williamr@4
    39
#endif
williamr@4
    40
williamr@4
    41
_STLP_BEGIN_NAMESPACE
williamr@4
    42
williamr@4
    43
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
    44
williamr@4
    45
#if defined (_STLP_EXPOSE_GLOBALS_IMPLEMENTATION)
williamr@4
    46
template <class _Dummy>
williamr@4
    47
void _STLP_CALL
williamr@4
    48
_List_global<_Dummy>::_Transfer(_List_node_base* __position,
williamr@4
    49
                                _List_node_base* __first, _List_node_base* __last) {
williamr@4
    50
  if (__position != __last) {
williamr@4
    51
    // Remove [first, last) from its old position.
williamr@4
    52
    __last->_M_prev->_M_next     = __position;
williamr@4
    53
    __first->_M_prev->_M_next    = __last;
williamr@4
    54
    __position->_M_prev->_M_next = __first;
williamr@4
    55
williamr@4
    56
    // Splice [first, last) into its new position.
williamr@4
    57
    _Node_base* __tmp = __position->_M_prev;
williamr@4
    58
    __position->_M_prev = __last->_M_prev;
williamr@4
    59
    __last->_M_prev     = __first->_M_prev;
williamr@4
    60
    __first->_M_prev    = __tmp;
williamr@4
    61
  }
williamr@4
    62
}
williamr@4
    63
#endif /* _STLP_EXPOSE_GLOBALS_IMPLEMENTATION */
williamr@4
    64
williamr@4
    65
template <class _Tp, class _Alloc>
williamr@4
    66
void _List_base<_Tp,_Alloc>::clear() {
williamr@4
    67
  _Node* __cur = __STATIC_CAST(_Node*, _M_node._M_data._M_next);
williamr@4
    68
  while (__cur != &(_M_node._M_data)) {
williamr@4
    69
    _Node* __tmp = __cur;
williamr@4
    70
    __cur = __STATIC_CAST(_Node*, __cur->_M_next);
williamr@4
    71
    _STLP_STD::_Destroy(&__tmp->_M_data);
williamr@4
    72
    this->_M_node.deallocate(__tmp, 1);
williamr@4
    73
  }
williamr@4
    74
  _M_node._M_data._M_next = &_M_node._M_data;
williamr@4
    75
  _M_node._M_data._M_prev = &_M_node._M_data;
williamr@4
    76
}
williamr@4
    77
williamr@4
    78
#if defined (_STLP_NESTED_TYPE_PARAM_BUG)
williamr@4
    79
#  define size_type size_t
williamr@4
    80
#endif
williamr@4
    81
williamr@4
    82
#if defined (_STLP_USE_PTR_SPECIALIZATIONS)
williamr@4
    83
#  define list _STLP_PTR_IMPL_NAME(list)
williamr@4
    84
#elif defined (_STLP_DEBUG)
williamr@4
    85
#  define list _STLP_NON_DBG_NAME(list)
williamr@4
    86
#else
williamr@4
    87
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
    88
#endif
williamr@4
    89
williamr@4
    90
template <class _Tp, class _Alloc>
williamr@4
    91
void list<_Tp, _Alloc>::resize(size_type __new_size, const _Tp& __x) {
williamr@4
    92
  iterator __i = begin();
williamr@4
    93
  size_type __len = 0;
williamr@4
    94
  for ( ; __i != end() && __len < __new_size; ++__i, ++__len);
williamr@4
    95
williamr@4
    96
  if (__len == __new_size)
williamr@4
    97
    erase(__i, end());
williamr@4
    98
  else // __i == end()
williamr@4
    99
    insert(end(), __new_size - __len, __x);
williamr@4
   100
}
williamr@4
   101
williamr@4
   102
template <class _Tp, class _Alloc>
williamr@4
   103
list<_Tp, _Alloc>& list<_Tp, _Alloc>::operator=(const list<_Tp, _Alloc>& __x) {
williamr@4
   104
  if (this != &__x) {
williamr@4
   105
    iterator __first1 = begin();
williamr@4
   106
    iterator __last1 = end();
williamr@4
   107
    const_iterator __first2 = __x.begin();
williamr@4
   108
    const_iterator __last2 = __x.end();
williamr@4
   109
    while (__first1 != __last1 && __first2 != __last2)
williamr@4
   110
      *__first1++ = *__first2++;
williamr@4
   111
    if (__first2 == __last2)
williamr@4
   112
      erase(__first1, __last1);
williamr@4
   113
    else
williamr@4
   114
      insert(__last1, __first2, __last2);
williamr@4
   115
  }
williamr@4
   116
  return *this;
williamr@4
   117
}
williamr@4
   118
williamr@4
   119
template <class _Tp, class _Alloc>
williamr@4
   120
void list<_Tp, _Alloc>::_M_fill_assign(size_type __n, const _Tp& __val) {
williamr@4
   121
  iterator __i = begin();
williamr@4
   122
  for ( ; __i != end() && __n > 0; ++__i, --__n)
williamr@4
   123
    *__i = __val;
williamr@4
   124
  if (__n > 0)
williamr@4
   125
    insert(end(), __n, __val);
williamr@4
   126
  else
williamr@4
   127
    erase(__i, end());
williamr@4
   128
}
williamr@4
   129
williamr@4
   130
#if !defined (list)
williamr@4
   131
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   132
#endif
williamr@4
   133
williamr@4
   134
template <class _Tp, class _Alloc, class _Predicate>
williamr@4
   135
void _S_remove_if(list<_Tp, _Alloc>& __that, _Predicate __pred)  {
williamr@4
   136
  typedef typename list<_Tp, _Alloc>::iterator _Literator;
williamr@4
   137
  _Literator __first = __that.begin();
williamr@4
   138
  _Literator __last = __that.end();
williamr@4
   139
  while (__first != __last) {
williamr@4
   140
    _Literator __next = __first;
williamr@4
   141
    ++__next;
williamr@4
   142
    if (__pred(*__first)) __that.erase(__first);
williamr@4
   143
    __first = __next;
williamr@4
   144
  }
williamr@4
   145
}
williamr@4
   146
williamr@4
   147
template <class _Tp, class _Alloc, class _BinaryPredicate>
williamr@4
   148
void _S_unique(list<_Tp, _Alloc>& __that, _BinaryPredicate __binary_pred) {
williamr@4
   149
  typedef typename list<_Tp, _Alloc>::iterator _Literator;
williamr@4
   150
  _Literator __first = __that.begin();
williamr@4
   151
  _Literator __last = __that.end();
williamr@4
   152
  if (__first == __last) return;
williamr@4
   153
  _Literator __next = __first;
williamr@4
   154
  while (++__next != __last) {
williamr@4
   155
    if (__binary_pred(*__first, *__next))
williamr@4
   156
      __that.erase(__next);
williamr@4
   157
    else
williamr@4
   158
      __first = __next;
williamr@4
   159
    __next = __first;
williamr@4
   160
  }
williamr@4
   161
}
williamr@4
   162
williamr@4
   163
template <class _Tp, class _Alloc, class _StrictWeakOrdering>
williamr@4
   164
void _S_merge(list<_Tp, _Alloc>& __that, list<_Tp, _Alloc>& __x,
williamr@4
   165
              _StrictWeakOrdering __comp) {
williamr@4
   166
  typedef typename list<_Tp, _Alloc>::iterator _Literator;
williamr@4
   167
  _Literator __first1 = __that.begin();
williamr@4
   168
  _Literator __last1 = __that.end();
williamr@4
   169
  _Literator __first2 = __x.begin();
williamr@4
   170
  _Literator __last2 = __x.end();
williamr@4
   171
  if (__that.get_allocator() == __x.get_allocator()) {
williamr@4
   172
    while (__first1 != __last1 && __first2 != __last2) {
williamr@4
   173
      if (__comp(*__first2, *__first1)) {
williamr@4
   174
        _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   175
        _Literator __next = __first2;
williamr@4
   176
        _List_global_inst::_Transfer(__first1._M_node, __first2._M_node, (++__next)._M_node);
williamr@4
   177
        __first2 = __next;
williamr@4
   178
      }
williamr@4
   179
      else
williamr@4
   180
        ++__first1;
williamr@4
   181
    }
williamr@4
   182
    if (__first2 != __last2)
williamr@4
   183
      _List_global_inst::_Transfer(__last1._M_node, __first2._M_node, __last2._M_node);
williamr@4
   184
  }
williamr@4
   185
  else {
williamr@4
   186
    while (__first1 != __last1 && __first2 != __last2) {
williamr@4
   187
      if (__comp(*__first2, *__first1)) {
williamr@4
   188
        _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   189
        __first1 = __that.insert(__first1, *__first2);
williamr@4
   190
      }
williamr@4
   191
      else
williamr@4
   192
        ++__first1;
williamr@4
   193
    }
williamr@4
   194
    if (__first2 != __last2) {
williamr@4
   195
      __that.insert(__first1, __first2, __last2);
williamr@4
   196
    }
williamr@4
   197
    __x.clear();
williamr@4
   198
  }
williamr@4
   199
}
williamr@4
   200
williamr@4
   201
template <class _Tp, class _Alloc, class _StrictWeakOrdering>
williamr@4
   202
void _S_sort(list<_Tp, _Alloc>& __that, _StrictWeakOrdering __comp) {
williamr@4
   203
  // Do nothing if the list has length 0 or 1.
williamr@4
   204
  if (__that._M_node._M_data._M_next == &__that._M_node._M_data ||
williamr@4
   205
      __that._M_node._M_data._M_next->_M_next == &__that._M_node._M_data)
williamr@4
   206
    return;
williamr@4
   207
williamr@4
   208
  list<_Tp, _Alloc> __carry(__that.get_allocator());
williamr@4
   209
  const int NB = 64;
williamr@4
   210
  _STLP_PRIV _CArray<list<_Tp, _Alloc>, NB> __counter(__carry);
williamr@4
   211
  int __fill = 0;
williamr@4
   212
  while (!__that.empty()) {
williamr@4
   213
    __carry.splice(__carry.begin(), __that, __that.begin());
williamr@4
   214
    int __i = 0;
williamr@4
   215
    while (__i < __fill && !__counter[__i].empty()) {
williamr@4
   216
      _S_merge(__counter[__i], __carry, __comp);
williamr@4
   217
      __carry.swap(__counter[__i++]);
williamr@4
   218
    }
williamr@4
   219
    __carry.swap(__counter[__i]);
williamr@4
   220
    if (__i == __fill) {
williamr@4
   221
      ++__fill;
williamr@4
   222
      if (__fill >= NB) {
williamr@4
   223
        //Looks like the list has too many elements to be sorted with this algorithm:
williamr@4
   224
        __stl_throw_overflow_error("list::sort");
williamr@4
   225
      }
williamr@4
   226
    }
williamr@4
   227
  }
williamr@4
   228
williamr@4
   229
  for (int __i = 1; __i < __fill; ++__i)
williamr@4
   230
    _S_merge(__counter[__i], __counter[__i - 1], __comp);
williamr@4
   231
  __that.swap(__counter[__fill - 1]);
williamr@4
   232
}
williamr@4
   233
williamr@4
   234
#if defined (list)
williamr@4
   235
#  undef list
williamr@4
   236
#endif
williamr@4
   237
williamr@4
   238
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   239
williamr@4
   240
_STLP_END_NAMESPACE
williamr@4
   241
williamr@4
   242
#endif /*  _STLP_LIST_C */
williamr@4
   243
williamr@4
   244
// Local Variables:
williamr@4
   245
// mode:C++
williamr@4
   246
// End: