epoc32/include/tools/stlport/stl/_algo.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
 * Copyright (c) 1994
williamr@4
     4
 * Hewlett-Packard Company
williamr@4
     5
 *
williamr@4
     6
 * Copyright (c) 1996,1997
williamr@4
     7
 * Silicon Graphics Computer Systems, Inc.
williamr@4
     8
 *
williamr@4
     9
 * Copyright (c) 1997
williamr@4
    10
 * Moscow Center for SPARC Technology
williamr@4
    11
 *
williamr@4
    12
 * Copyright (c) 1999
williamr@4
    13
 * Boris Fomitchev
williamr@4
    14
 *
williamr@4
    15
 * This material is provided "as is", with absolutely no warranty expressed
williamr@4
    16
 * or implied. Any use is at your own risk.
williamr@4
    17
 *
williamr@4
    18
 * Permission to use or copy this software for any purpose is hereby granted
williamr@4
    19
 * without fee, provided the above notices are retained on all copies.
williamr@4
    20
 * Permission to modify the code and to distribute modified code is granted,
williamr@4
    21
 * provided the above notices are retained, and a notice that the code was
williamr@4
    22
 * modified is included with the above copyright notice.
williamr@4
    23
 *
williamr@4
    24
 */
williamr@4
    25
williamr@4
    26
#ifndef _STLP_ALGO_C
williamr@4
    27
#define _STLP_ALGO_C
williamr@4
    28
williamr@4
    29
#if !defined (_STLP_INTERNAL_ALGO_H)
williamr@4
    30
#  include <stl/_algo.h>
williamr@4
    31
#endif
williamr@4
    32
williamr@4
    33
#ifndef _STLP_INTERNAL_TEMPBUF_H
williamr@4
    34
#  include <stl/_tempbuf.h>
williamr@4
    35
#endif
williamr@4
    36
williamr@4
    37
_STLP_BEGIN_NAMESPACE
williamr@4
    38
williamr@4
    39
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
    40
williamr@4
    41
template <class _BidirectionalIter, class _Distance, class _Compare>
williamr@4
    42
void __merge_without_buffer(_BidirectionalIter __first,
williamr@4
    43
                            _BidirectionalIter __middle,
williamr@4
    44
                            _BidirectionalIter __last,
williamr@4
    45
                            _Distance __len1, _Distance __len2,
williamr@4
    46
                            _Compare __comp);
williamr@4
    47
williamr@4
    48
williamr@4
    49
template <class _BidirectionalIter1, class _BidirectionalIter2,
williamr@4
    50
          class _BidirectionalIter3, class _Compare>
williamr@4
    51
_BidirectionalIter3 __merge_backward(_BidirectionalIter1 __first1,
williamr@4
    52
                                     _BidirectionalIter1 __last1,
williamr@4
    53
                                     _BidirectionalIter2 __first2,
williamr@4
    54
                                     _BidirectionalIter2 __last2,
williamr@4
    55
                                     _BidirectionalIter3 __result,
williamr@4
    56
                                     _Compare __comp);
williamr@4
    57
williamr@4
    58
template <class _Tp>
williamr@4
    59
#if !(defined (__SUNPRO_CC) && (__SUNPRO_CC < 0x420 ))
williamr@4
    60
inline
williamr@4
    61
#endif
williamr@4
    62
const _Tp& __median(const _Tp& __a, const _Tp& __b, const _Tp& __c) {
williamr@4
    63
  if (__a < __b)
williamr@4
    64
    if (__b < __c)
williamr@4
    65
      return __b;
williamr@4
    66
    else if (__a < __c)
williamr@4
    67
      return __c;
williamr@4
    68
    else
williamr@4
    69
      return __a;
williamr@4
    70
  else if (__a < __c)
williamr@4
    71
    return __a;
williamr@4
    72
  else if (__b < __c)
williamr@4
    73
    return __c;
williamr@4
    74
  else
williamr@4
    75
    return __b;
williamr@4
    76
}
williamr@4
    77
williamr@4
    78
template <class _Tp, class _Compare>
williamr@4
    79
#if !(defined (__SUNPRO_CC) && (__SUNPRO_CC < 0x420 ))
williamr@4
    80
inline
williamr@4
    81
#endif
williamr@4
    82
const _Tp&
williamr@4
    83
__median(const _Tp& __a, const _Tp& __b, const _Tp& __c, _Compare __comp) {
williamr@4
    84
  if (__comp(__a, __b)) {
williamr@4
    85
    _STLP_VERBOSE_ASSERT(!__comp(__b, __a), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
    86
    if (__comp(__b, __c)) {
williamr@4
    87
      _STLP_VERBOSE_ASSERT(!__comp(__c, __b), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
    88
      return __b;
williamr@4
    89
    }
williamr@4
    90
    else if (__comp(__a, __c)) {
williamr@4
    91
      _STLP_VERBOSE_ASSERT(!__comp(__c, __a), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
    92
      return __c;
williamr@4
    93
    }
williamr@4
    94
    else
williamr@4
    95
      return __a;
williamr@4
    96
  }
williamr@4
    97
  else if (__comp(__a, __c)) {
williamr@4
    98
    _STLP_VERBOSE_ASSERT(!__comp(__c, __a), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
    99
    return __a;
williamr@4
   100
  }
williamr@4
   101
  else if (__comp(__b, __c)) {
williamr@4
   102
    _STLP_VERBOSE_ASSERT(!__comp(__c, __b), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   103
    return __c;
williamr@4
   104
  }
williamr@4
   105
  else
williamr@4
   106
    return __b;
williamr@4
   107
}
williamr@4
   108
williamr@4
   109
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   110
williamr@4
   111
template <class _ForwardIter1, class _ForwardIter2>
williamr@4
   112
_ForwardIter1 search(_ForwardIter1 __first1, _ForwardIter1 __last1,
williamr@4
   113
                     _ForwardIter2 __first2, _ForwardIter2 __last2) {
williamr@4
   114
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
   115
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
   116
  // Test for empty ranges
williamr@4
   117
  if (__first1 == __last1 || __first2 == __last2)
williamr@4
   118
    return __first1;
williamr@4
   119
williamr@4
   120
  // Test for a pattern of length 1.
williamr@4
   121
  _ForwardIter2 __tmp(__first2);
williamr@4
   122
  ++__tmp;
williamr@4
   123
  if (__tmp == __last2)
williamr@4
   124
    return find(__first1, __last1, *__first2);
williamr@4
   125
williamr@4
   126
  // General case.
williamr@4
   127
  _ForwardIter2 __p1 = __first2;
williamr@4
   128
  ++__p1;
williamr@4
   129
williamr@4
   130
  _ForwardIter1 __current;// = __first1;
williamr@4
   131
williamr@4
   132
  while (__first1 != __last1) {
williamr@4
   133
    __first1 = find(__first1, __last1, *__first2);
williamr@4
   134
    if (__first1 == __last1)
williamr@4
   135
      return __last1;
williamr@4
   136
williamr@4
   137
    _ForwardIter2 __p = __p1;
williamr@4
   138
    __current = __first1;
williamr@4
   139
    if (++__current == __last1)
williamr@4
   140
      return __last1;
williamr@4
   141
williamr@4
   142
    while (*__current == *__p) {
williamr@4
   143
      if (++__p == __last2)
williamr@4
   144
        return __first1;
williamr@4
   145
      if (++__current == __last1)
williamr@4
   146
        return __last1;
williamr@4
   147
    }
williamr@4
   148
williamr@4
   149
    ++__first1;
williamr@4
   150
  }
williamr@4
   151
  return __first1;
williamr@4
   152
}
williamr@4
   153
williamr@4
   154
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   155
williamr@4
   156
template <class _RandomAccessIter, class _Integer, class _Tp,
williamr@4
   157
          class _BinaryPred, class _Distance>
williamr@4
   158
_RandomAccessIter __search_n(_RandomAccessIter __first, _RandomAccessIter __last,
williamr@4
   159
                             _Integer __count, const _Tp& __val, _BinaryPred __pred,
williamr@4
   160
                             _Distance*, const random_access_iterator_tag &)
williamr@4
   161
{
williamr@4
   162
  _Distance __tailSize = __last - __first;
williamr@4
   163
  const _Distance __pattSize = __count;
williamr@4
   164
  const _Distance __skipOffset = __pattSize - 1;
williamr@4
   165
  _RandomAccessIter __backTrack;
williamr@4
   166
  _Distance __remainder, __prevRemainder;
williamr@4
   167
williamr@4
   168
  for ( _RandomAccessIter __lookAhead = __first + __skipOffset; __tailSize >= __pattSize; __lookAhead += __pattSize ) { // the main loop...
williamr@4
   169
    //__lookAhead here is always pointing to the last element of next possible match.
williamr@4
   170
    __tailSize -= __pattSize;
williamr@4
   171
williamr@4
   172
    while ( !__pred(*__lookAhead, __val) ) { // the skip loop...
williamr@4
   173
      if (__tailSize < __pattSize)
williamr@4
   174
        return __last;
williamr@4
   175
williamr@4
   176
      __lookAhead += __pattSize;
williamr@4
   177
      __tailSize -= __pattSize;
williamr@4
   178
    }
williamr@4
   179
williamr@4
   180
    if ( __skipOffset == 0 ) {
williamr@4
   181
      return (__lookAhead - __skipOffset); //Success
williamr@4
   182
    }
williamr@4
   183
williamr@4
   184
    __remainder = __skipOffset;
williamr@4
   185
williamr@4
   186
    for (__backTrack = __lookAhead; __pred(*--__backTrack, __val); ) {
williamr@4
   187
      if (--__remainder == 0)
williamr@4
   188
        return (__lookAhead - __skipOffset); //Success
williamr@4
   189
    }
williamr@4
   190
williamr@4
   191
    if (__remainder > __tailSize)
williamr@4
   192
      return __last; //failure
williamr@4
   193
williamr@4
   194
    __lookAhead += __remainder;
williamr@4
   195
    __tailSize -= __remainder;
williamr@4
   196
williamr@4
   197
    while ( __pred(*__lookAhead, __val) ) {
williamr@4
   198
      __prevRemainder = __remainder;
williamr@4
   199
      __backTrack = __lookAhead;
williamr@4
   200
williamr@4
   201
      do {
williamr@4
   202
        if (--__remainder == 0)
williamr@4
   203
          return (__lookAhead - __skipOffset); //Success
williamr@4
   204
      } while (__pred(*--__backTrack, __val));
williamr@4
   205
williamr@4
   206
      //adjust remainder for next comparison
williamr@4
   207
      __remainder += __pattSize - __prevRemainder;
williamr@4
   208
williamr@4
   209
      if (__remainder > __tailSize)
williamr@4
   210
        return __last; //failure
williamr@4
   211
williamr@4
   212
      __lookAhead += __remainder;
williamr@4
   213
      __tailSize -= __remainder;
williamr@4
   214
    }
williamr@4
   215
williamr@4
   216
    //__lookAhead here is always pointing to the element of the last mismatch.
williamr@4
   217
  }
williamr@4
   218
williamr@4
   219
  return __last; //failure
williamr@4
   220
}
williamr@4
   221
williamr@4
   222
template <class _ForwardIter, class _Integer, class _Tp,
williamr@4
   223
          class _Distance, class _BinaryPred>
williamr@4
   224
_ForwardIter __search_n(_ForwardIter __first, _ForwardIter __last,
williamr@4
   225
                        _Integer __count, const _Tp& __val, _BinaryPred __pred,
williamr@4
   226
                        _Distance*, const forward_iterator_tag &) {
williamr@4
   227
  for (; (__first != __last) && !__pred(*__first, __val); ++__first) {}
williamr@4
   228
  while (__first != __last) {
williamr@4
   229
    _Integer __n = __count - 1;
williamr@4
   230
    _ForwardIter __i = __first;
williamr@4
   231
    ++__i;
williamr@4
   232
    while (__i != __last && __n != 0 && __pred(*__i, __val)) {
williamr@4
   233
      ++__i;
williamr@4
   234
      --__n;
williamr@4
   235
    }
williamr@4
   236
    if (__n == 0)
williamr@4
   237
      return __first;
williamr@4
   238
    else if (__i != __last)
williamr@4
   239
      for (__first = ++__i; (__first != __last) && !__pred(*__first, __val); ++__first) {}
williamr@4
   240
    else
williamr@4
   241
      break;
williamr@4
   242
  }
williamr@4
   243
  return __last;
williamr@4
   244
}
williamr@4
   245
williamr@4
   246
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   247
williamr@4
   248
// search_n.  Search for __count consecutive copies of __val.
williamr@4
   249
template <class _ForwardIter, class _Integer, class _Tp>
williamr@4
   250
_ForwardIter search_n(_ForwardIter __first, _ForwardIter __last,
williamr@4
   251
                      _Integer __count, const _Tp& __val) {
williamr@4
   252
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   253
  if (__count <= 0)
williamr@4
   254
    return __first;
williamr@4
   255
  if (__count == 1)
williamr@4
   256
    //We use find when __count == 1 to use potential find overload.
williamr@4
   257
    return find(__first, __last, __val);
williamr@4
   258
  return _STLP_PRIV __search_n(__first, __last, __count, __val, equal_to<_Tp>(),
williamr@4
   259
                               _STLP_DISTANCE_TYPE(__first, _ForwardIter),
williamr@4
   260
                               _STLP_ITERATOR_CATEGORY(__first, _ForwardIter));
williamr@4
   261
}
williamr@4
   262
williamr@4
   263
template <class _ForwardIter, class _Integer, class _Tp, class _BinaryPred>
williamr@4
   264
_ForwardIter search_n(_ForwardIter __first, _ForwardIter __last,
williamr@4
   265
                      _Integer __count, const _Tp& __val,
williamr@4
   266
                      _BinaryPred __binary_pred) {
williamr@4
   267
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   268
  if (__count <= 0)
williamr@4
   269
    return __first;
williamr@4
   270
  return _STLP_PRIV __search_n(__first, __last, __count, __val, __binary_pred,
williamr@4
   271
                               _STLP_DISTANCE_TYPE(__first, _ForwardIter),
williamr@4
   272
                               _STLP_ITERATOR_CATEGORY(__first, _ForwardIter));
williamr@4
   273
}
williamr@4
   274
williamr@4
   275
template <class _ForwardIter1, class _ForwardIter2>
williamr@4
   276
_ForwardIter1
williamr@4
   277
find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
williamr@4
   278
         _ForwardIter2 __first2, _ForwardIter2 __last2) {
williamr@4
   279
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
   280
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
   281
  return _STLP_PRIV __find_end(__first1, __last1, __first2, __last2,
williamr@4
   282
#if defined (_STLP_CLASS_PARTIAL_SPECIALIZATION)
williamr@4
   283
                               _STLP_ITERATOR_CATEGORY(__first1, _ForwardIter1),
williamr@4
   284
                               _STLP_ITERATOR_CATEGORY(__first2, _ForwardIter2),
williamr@4
   285
#else
williamr@4
   286
                               forward_iterator_tag(),
williamr@4
   287
                               forward_iterator_tag(),
williamr@4
   288
#endif
williamr@4
   289
                               _STLP_PRIV __equal_to(_STLP_VALUE_TYPE(__first1, _ForwardIter1))
williamr@4
   290
    );
williamr@4
   291
}
williamr@4
   292
williamr@4
   293
// unique and unique_copy
williamr@4
   294
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   295
williamr@4
   296
template <class _InputIterator, class _OutputIterator, class _BinaryPredicate,
williamr@4
   297
          class _Tp>
williamr@4
   298
_STLP_INLINE_LOOP _OutputIterator
williamr@4
   299
__unique_copy(_InputIterator __first, _InputIterator __last,
williamr@4
   300
              _OutputIterator __result,
williamr@4
   301
              _BinaryPredicate __binary_pred, _Tp*) {
williamr@4
   302
  _Tp __val = *__first;
williamr@4
   303
  *__result = __val;
williamr@4
   304
  while (++__first != __last)
williamr@4
   305
    if (!__binary_pred(__val, *__first)) {
williamr@4
   306
      __val = *__first;
williamr@4
   307
      *++__result = __val;
williamr@4
   308
    }
williamr@4
   309
  return ++__result;
williamr@4
   310
}
williamr@4
   311
williamr@4
   312
template <class _InputIter, class _OutputIter, class _BinaryPredicate>
williamr@4
   313
inline _OutputIter
williamr@4
   314
__unique_copy(_InputIter __first, _InputIter __last,_OutputIter __result,
williamr@4
   315
              _BinaryPredicate __binary_pred, const output_iterator_tag &) {
williamr@4
   316
  return __unique_copy(__first, __last, __result, __binary_pred, _STLP_VALUE_TYPE(__first, _InputIter));
williamr@4
   317
}
williamr@4
   318
williamr@4
   319
template <class _InputIter, class _ForwardIter, class _BinaryPredicate>
williamr@4
   320
_STLP_INLINE_LOOP _ForwardIter
williamr@4
   321
__unique_copy(_InputIter __first, _InputIter __last, _ForwardIter __result,
williamr@4
   322
              _BinaryPredicate __binary_pred, const forward_iterator_tag &) {
williamr@4
   323
  *__result = *__first;
williamr@4
   324
  while (++__first != __last)
williamr@4
   325
    if (!__binary_pred(*__result, *__first)) *++__result = *__first;
williamr@4
   326
  return ++__result;
williamr@4
   327
}
williamr@4
   328
williamr@4
   329
#if defined (_STLP_NONTEMPL_BASE_MATCH_BUG)
williamr@4
   330
template <class _InputIterator, class _BidirectionalIterator, class _BinaryPredicate>
williamr@4
   331
inline _BidirectionalIterator
williamr@4
   332
__unique_copy(_InputIterator __first, _InputIterator __last,
williamr@4
   333
              _BidirectionalIterator __result, _BinaryPredicate __binary_pred,
williamr@4
   334
              const bidirectional_iterator_tag &) {
williamr@4
   335
  return __unique_copy(__first, __last, __result, __binary_pred, forward_iterator_tag());
williamr@4
   336
}
williamr@4
   337
williamr@4
   338
template <class _InputIterator, class _RandomAccessIterator, class _BinaryPredicate>
williamr@4
   339
inline _RandomAccessIterator
williamr@4
   340
__unique_copy(_InputIterator __first, _InputIterator __last,
williamr@4
   341
              _RandomAccessIterator __result, _BinaryPredicate __binary_pred,
williamr@4
   342
              const random_access_iterator_tag &) {
williamr@4
   343
  return __unique_copy(__first, __last, __result, __binary_pred, forward_iterator_tag());
williamr@4
   344
}
williamr@4
   345
#endif /* _STLP_NONTEMPL_BASE_MATCH_BUG */
williamr@4
   346
williamr@4
   347
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   348
williamr@4
   349
template <class _InputIter, class _OutputIter>
williamr@4
   350
_OutputIter
williamr@4
   351
unique_copy(_InputIter __first, _InputIter __last, _OutputIter __result) {
williamr@4
   352
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   353
  if (__first == __last) return __result;
williamr@4
   354
  return _STLP_PRIV __unique_copy(__first, __last, __result,
williamr@4
   355
                                  _STLP_PRIV __equal_to(_STLP_VALUE_TYPE(__first, _InputIter)),
williamr@4
   356
                                  _STLP_ITERATOR_CATEGORY(__result, _OutputIter));
williamr@4
   357
}
williamr@4
   358
williamr@4
   359
template <class _InputIter, class _OutputIter, class _BinaryPredicate>
williamr@4
   360
_OutputIter
williamr@4
   361
unique_copy(_InputIter __first, _InputIter __last,_OutputIter __result,
williamr@4
   362
            _BinaryPredicate __binary_pred) {
williamr@4
   363
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   364
  if (__first == __last) return __result;
williamr@4
   365
  return _STLP_PRIV __unique_copy(__first, __last, __result, __binary_pred,
williamr@4
   366
                                  _STLP_ITERATOR_CATEGORY(__result, _OutputIter));
williamr@4
   367
}
williamr@4
   368
williamr@4
   369
// rotate and rotate_copy, and their auxiliary functions
williamr@4
   370
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   371
williamr@4
   372
template <class _ForwardIter, class _Distance>
williamr@4
   373
_ForwardIter __rotate_aux(_ForwardIter __first,
williamr@4
   374
                          _ForwardIter __middle,
williamr@4
   375
                          _ForwardIter __last,
williamr@4
   376
                          _Distance*,
williamr@4
   377
                          const forward_iterator_tag &) {
williamr@4
   378
  if (__first == __middle)
williamr@4
   379
    return __last;
williamr@4
   380
  if (__last  == __middle)
williamr@4
   381
    return __first;
williamr@4
   382
williamr@4
   383
  _ForwardIter __first2 = __middle;
williamr@4
   384
  do {
williamr@4
   385
    swap(*__first++, *__first2++);
williamr@4
   386
    if (__first == __middle)
williamr@4
   387
      __middle = __first2;
williamr@4
   388
  } while (__first2 != __last);
williamr@4
   389
williamr@4
   390
  _ForwardIter __new_middle = __first;
williamr@4
   391
williamr@4
   392
  __first2 = __middle;
williamr@4
   393
williamr@4
   394
  while (__first2 != __last) {
williamr@4
   395
    swap (*__first++, *__first2++);
williamr@4
   396
    if (__first == __middle)
williamr@4
   397
      __middle = __first2;
williamr@4
   398
    else if (__first2 == __last)
williamr@4
   399
      __first2 = __middle;
williamr@4
   400
  }
williamr@4
   401
williamr@4
   402
  return __new_middle;
williamr@4
   403
}
williamr@4
   404
williamr@4
   405
template <class _BidirectionalIter, class _Distance>
williamr@4
   406
_BidirectionalIter __rotate_aux(_BidirectionalIter __first,
williamr@4
   407
                                _BidirectionalIter __middle,
williamr@4
   408
                                _BidirectionalIter __last,
williamr@4
   409
                                _Distance*,
williamr@4
   410
                                const bidirectional_iterator_tag &) {
williamr@4
   411
  if (__first == __middle)
williamr@4
   412
    return __last;
williamr@4
   413
  if (__last  == __middle)
williamr@4
   414
    return __first;
williamr@4
   415
williamr@4
   416
  __reverse(__first,  __middle, bidirectional_iterator_tag());
williamr@4
   417
  __reverse(__middle, __last,   bidirectional_iterator_tag());
williamr@4
   418
williamr@4
   419
  while (__first != __middle && __middle != __last)
williamr@4
   420
    swap (*__first++, *--__last);
williamr@4
   421
williamr@4
   422
  if (__first == __middle) {
williamr@4
   423
    __reverse(__middle, __last,   bidirectional_iterator_tag());
williamr@4
   424
    return __last;
williamr@4
   425
  }
williamr@4
   426
  else {
williamr@4
   427
    __reverse(__first,  __middle, bidirectional_iterator_tag());
williamr@4
   428
    return __first;
williamr@4
   429
  }
williamr@4
   430
}
williamr@4
   431
williamr@4
   432
template <class _RandomAccessIter, class _Distance, class _Tp>
williamr@4
   433
_RandomAccessIter __rotate_aux(_RandomAccessIter __first,
williamr@4
   434
                               _RandomAccessIter __middle,
williamr@4
   435
                               _RandomAccessIter __last,
williamr@4
   436
                               _Distance *, _Tp *) {
williamr@4
   437
williamr@4
   438
  _Distance __n = __last   - __first;
williamr@4
   439
  _Distance __k = __middle - __first;
williamr@4
   440
  _Distance __l = __n - __k;
williamr@4
   441
  _RandomAccessIter __result = __first + (__last - __middle);
williamr@4
   442
williamr@4
   443
  if (__k == 0)  /* __first == middle */
williamr@4
   444
    return __last;
williamr@4
   445
williamr@4
   446
  if (__k == __l) {
williamr@4
   447
    swap_ranges(__first, __middle, __middle);
williamr@4
   448
    return __result;
williamr@4
   449
  }
williamr@4
   450
williamr@4
   451
  _Distance __d = __gcd(__n, __k);
williamr@4
   452
williamr@4
   453
  for (_Distance __i = 0; __i < __d; __i++) {
williamr@4
   454
    _Tp __tmp = *__first;
williamr@4
   455
    _RandomAccessIter __p = __first;
williamr@4
   456
williamr@4
   457
    if (__k < __l) {
williamr@4
   458
      for (_Distance __j = 0; __j < __l/__d; __j++) {
williamr@4
   459
        if (__p > __first + __l) {
williamr@4
   460
          *__p = *(__p - __l);
williamr@4
   461
          __p -= __l;
williamr@4
   462
        }
williamr@4
   463
williamr@4
   464
        *__p = *(__p + __k);
williamr@4
   465
        __p += __k;
williamr@4
   466
      }
williamr@4
   467
    }
williamr@4
   468
williamr@4
   469
    else {
williamr@4
   470
      for (_Distance __j = 0; __j < __k/__d - 1; __j ++) {
williamr@4
   471
        if (__p < __last - __k) {
williamr@4
   472
          *__p = *(__p + __k);
williamr@4
   473
          __p += __k;
williamr@4
   474
        }
williamr@4
   475
williamr@4
   476
        *__p = * (__p - __l);
williamr@4
   477
        __p -= __l;
williamr@4
   478
      }
williamr@4
   479
    }
williamr@4
   480
williamr@4
   481
    *__p = __tmp;
williamr@4
   482
    ++__first;
williamr@4
   483
  }
williamr@4
   484
williamr@4
   485
  return __result;
williamr@4
   486
}
williamr@4
   487
williamr@4
   488
template <class _RandomAccessIter, class _Distance>
williamr@4
   489
inline _RandomAccessIter
williamr@4
   490
__rotate_aux(_RandomAccessIter __first, _RandomAccessIter __middle, _RandomAccessIter __last,
williamr@4
   491
             _Distance * __dis, const random_access_iterator_tag &) {
williamr@4
   492
  return __rotate_aux(__first, __middle, __last,
williamr@4
   493
                      __dis, _STLP_VALUE_TYPE(__first, _RandomAccessIter));
williamr@4
   494
}
williamr@4
   495
williamr@4
   496
template <class _ForwardIter>
williamr@4
   497
_ForwardIter
williamr@4
   498
__rotate(_ForwardIter __first, _ForwardIter __middle, _ForwardIter __last) {
williamr@4
   499
  _STLP_DEBUG_CHECK(__check_range(__first, __middle))
williamr@4
   500
  _STLP_DEBUG_CHECK(__check_range(__middle, __last))
williamr@4
   501
  return __rotate_aux(__first, __middle, __last,
williamr@4
   502
                      _STLP_DISTANCE_TYPE(__first, _ForwardIter),
williamr@4
   503
                      _STLP_ITERATOR_CATEGORY(__first, _ForwardIter));
williamr@4
   504
}
williamr@4
   505
williamr@4
   506
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   507
williamr@4
   508
template <class _ForwardIter>
williamr@4
   509
void rotate(_ForwardIter __first, _ForwardIter __middle, _ForwardIter __last) {
williamr@4
   510
  _STLP_PRIV __rotate(__first, __middle, __last);
williamr@4
   511
}
williamr@4
   512
williamr@4
   513
// Return a random number in the range [0, __n).  This function encapsulates
williamr@4
   514
// whether we're using rand (part of the standard C library) or lrand48
williamr@4
   515
// (not standard, but a much better choice whenever it's available).
williamr@4
   516
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   517
williamr@4
   518
template <class _Distance>
williamr@4
   519
inline _Distance __random_number(_Distance __n) {
williamr@4
   520
#ifdef _STLP_NO_DRAND48
williamr@4
   521
  return rand() % __n;
williamr@4
   522
#else
williamr@4
   523
  return lrand48() % __n;
williamr@4
   524
#endif
williamr@4
   525
}
williamr@4
   526
williamr@4
   527
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   528
williamr@4
   529
template <class _RandomAccessIter>
williamr@4
   530
void random_shuffle(_RandomAccessIter __first,
williamr@4
   531
                    _RandomAccessIter __last) {
williamr@4
   532
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   533
  if (__first == __last) return;
williamr@4
   534
  for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
williamr@4
   535
    iter_swap(__i, __first + _STLP_PRIV __random_number((__i - __first) + 1));
williamr@4
   536
}
williamr@4
   537
williamr@4
   538
template <class _RandomAccessIter, class _RandomNumberGenerator>
williamr@4
   539
void random_shuffle(_RandomAccessIter __first, _RandomAccessIter __last,
williamr@4
   540
                    _RandomNumberGenerator &__rand) {
williamr@4
   541
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   542
  if (__first == __last) return;
williamr@4
   543
  for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
williamr@4
   544
    iter_swap(__i, __first + __rand((__i - __first) + 1));
williamr@4
   545
}
williamr@4
   546
williamr@4
   547
#if !defined (_STLP_NO_EXTENSIONS)
williamr@4
   548
// random_sample and random_sample_n (extensions, not part of the standard).
williamr@4
   549
template <class _ForwardIter, class _OutputIter, class _Distance>
williamr@4
   550
_OutputIter random_sample_n(_ForwardIter __first, _ForwardIter __last,
williamr@4
   551
                            _OutputIter __out_ite, const _Distance __n) {
williamr@4
   552
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   553
  _Distance __remaining = distance(__first, __last);
williamr@4
   554
  _Distance __m = (min) (__n, __remaining);
williamr@4
   555
williamr@4
   556
  while (__m > 0) {
williamr@4
   557
    if (_STLP_PRIV __random_number(__remaining) < __m) {
williamr@4
   558
      *__out_ite = *__first;
williamr@4
   559
      ++__out_ite;
williamr@4
   560
      --__m;
williamr@4
   561
    }
williamr@4
   562
williamr@4
   563
    --__remaining;
williamr@4
   564
    ++__first;
williamr@4
   565
  }
williamr@4
   566
  return __out_ite;
williamr@4
   567
}
williamr@4
   568
williamr@4
   569
williamr@4
   570
template <class _ForwardIter, class _OutputIter, class _Distance,
williamr@4
   571
          class _RandomNumberGenerator>
williamr@4
   572
_OutputIter random_sample_n(_ForwardIter __first, _ForwardIter __last,
williamr@4
   573
                            _OutputIter __out_ite, const _Distance __n,
williamr@4
   574
                            _RandomNumberGenerator& __rand) {
williamr@4
   575
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   576
  _Distance __remaining = distance(__first, __last);
williamr@4
   577
  _Distance __m = (min) (__n, __remaining);
williamr@4
   578
williamr@4
   579
  while (__m > 0) {
williamr@4
   580
    if (__rand(__remaining) < __m) {
williamr@4
   581
      *__out_ite = *__first;
williamr@4
   582
      ++__out_ite;
williamr@4
   583
      --__m;
williamr@4
   584
    }
williamr@4
   585
williamr@4
   586
    --__remaining;
williamr@4
   587
    ++__first;
williamr@4
   588
  }
williamr@4
   589
  return __out_ite;
williamr@4
   590
}
williamr@4
   591
williamr@4
   592
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   593
williamr@4
   594
template <class _InputIter, class _RandomAccessIter, class _Distance>
williamr@4
   595
_RandomAccessIter __random_sample(_InputIter __first, _InputIter __last,
williamr@4
   596
                                  _RandomAccessIter __out_ite,
williamr@4
   597
                                  const _Distance __n) {
williamr@4
   598
  _Distance __m = 0;
williamr@4
   599
  _Distance __t = __n;
williamr@4
   600
  for ( ; __first != __last && __m < __n; ++__m, ++__first)
williamr@4
   601
    __out_ite[__m] = *__first;
williamr@4
   602
williamr@4
   603
  while (__first != __last) {
williamr@4
   604
    ++__t;
williamr@4
   605
    _Distance __M = __random_number(__t);
williamr@4
   606
    if (__M < __n)
williamr@4
   607
      __out_ite[__M] = *__first;
williamr@4
   608
    ++__first;
williamr@4
   609
  }
williamr@4
   610
williamr@4
   611
  return __out_ite + __m;
williamr@4
   612
}
williamr@4
   613
williamr@4
   614
template <class _InputIter, class _RandomAccessIter,
williamr@4
   615
          class _RandomNumberGenerator, class _Distance>
williamr@4
   616
_RandomAccessIter __random_sample(_InputIter __first, _InputIter __last,
williamr@4
   617
                                  _RandomAccessIter __out_ite,
williamr@4
   618
                                  _RandomNumberGenerator& __rand,
williamr@4
   619
                                  const _Distance __n) {
williamr@4
   620
  _Distance __m = 0;
williamr@4
   621
  _Distance __t = __n;
williamr@4
   622
  for ( ; __first != __last && __m < __n; ++__m, ++__first)
williamr@4
   623
    __out_ite[__m] = *__first;
williamr@4
   624
williamr@4
   625
  while (__first != __last) {
williamr@4
   626
    ++__t;
williamr@4
   627
    _Distance __M = __rand(__t);
williamr@4
   628
    if (__M < __n)
williamr@4
   629
      __out_ite[__M] = *__first;
williamr@4
   630
    ++__first;
williamr@4
   631
  }
williamr@4
   632
williamr@4
   633
  return __out_ite + __m;
williamr@4
   634
}
williamr@4
   635
williamr@4
   636
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   637
williamr@4
   638
template <class _InputIter, class _RandomAccessIter>
williamr@4
   639
_RandomAccessIter
williamr@4
   640
random_sample(_InputIter __first, _InputIter __last,
williamr@4
   641
              _RandomAccessIter __out_first, _RandomAccessIter __out_last) {
williamr@4
   642
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   643
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__out_first, __out_last))
williamr@4
   644
  return _STLP_PRIV __random_sample(__first, __last,
williamr@4
   645
                                    __out_first, __out_last - __out_first);
williamr@4
   646
}
williamr@4
   647
williamr@4
   648
template <class _InputIter, class _RandomAccessIter, class _RandomNumberGenerator>
williamr@4
   649
_RandomAccessIter
williamr@4
   650
random_sample(_InputIter __first, _InputIter __last,
williamr@4
   651
              _RandomAccessIter __out_first, _RandomAccessIter __out_last,
williamr@4
   652
              _RandomNumberGenerator& __rand) {
williamr@4
   653
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   654
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__out_first, __out_last))
williamr@4
   655
  return _STLP_PRIV __random_sample(__first, __last,
williamr@4
   656
                                    __out_first, __rand,
williamr@4
   657
                                    __out_last - __out_first);
williamr@4
   658
}
williamr@4
   659
williamr@4
   660
#endif /* _STLP_NO_EXTENSIONS */
williamr@4
   661
williamr@4
   662
// partition, stable_partition, and their auxiliary functions
williamr@4
   663
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   664
williamr@4
   665
template <class _ForwardIter, class _Predicate>
williamr@4
   666
_STLP_INLINE_LOOP _ForwardIter __partition(_ForwardIter __first,
williamr@4
   667
                                           _ForwardIter __last,
williamr@4
   668
                                           _Predicate   __pred,
williamr@4
   669
                                           const forward_iterator_tag &) {
williamr@4
   670
  if (__first == __last) return __first;
williamr@4
   671
williamr@4
   672
  while (__pred(*__first))
williamr@4
   673
    if (++__first == __last) return __first;
williamr@4
   674
williamr@4
   675
  _ForwardIter __next = __first;
williamr@4
   676
williamr@4
   677
  while (++__next != __last) {
williamr@4
   678
    if (__pred(*__next)) {
williamr@4
   679
      swap(*__first, *__next);
williamr@4
   680
      ++__first;
williamr@4
   681
    }
williamr@4
   682
  }
williamr@4
   683
  return __first;
williamr@4
   684
}
williamr@4
   685
williamr@4
   686
template <class _BidirectionalIter, class _Predicate>
williamr@4
   687
_STLP_INLINE_LOOP _BidirectionalIter __partition(_BidirectionalIter __first,
williamr@4
   688
                                                 _BidirectionalIter __last,
williamr@4
   689
                                                 _Predicate __pred,
williamr@4
   690
                                                 const bidirectional_iterator_tag &) {
williamr@4
   691
  for (;;) {
williamr@4
   692
    for (;;) {
williamr@4
   693
      if (__first == __last)
williamr@4
   694
        return __first;
williamr@4
   695
      else if (__pred(*__first))
williamr@4
   696
        ++__first;
williamr@4
   697
      else
williamr@4
   698
        break;
williamr@4
   699
    }
williamr@4
   700
    --__last;
williamr@4
   701
    for (;;) {
williamr@4
   702
      if (__first == __last)
williamr@4
   703
        return __first;
williamr@4
   704
      else if (!__pred(*__last))
williamr@4
   705
        --__last;
williamr@4
   706
      else
williamr@4
   707
        break;
williamr@4
   708
    }
williamr@4
   709
    iter_swap(__first, __last);
williamr@4
   710
    ++__first;
williamr@4
   711
  }
williamr@4
   712
}
williamr@4
   713
williamr@4
   714
#if defined (_STLP_NONTEMPL_BASE_MATCH_BUG)
williamr@4
   715
template <class _BidirectionalIter, class _Predicate>
williamr@4
   716
inline
williamr@4
   717
_BidirectionalIter __partition(_BidirectionalIter __first,
williamr@4
   718
                               _BidirectionalIter __last,
williamr@4
   719
                               _Predicate __pred,
williamr@4
   720
                               const random_access_iterator_tag &) {
williamr@4
   721
  return __partition(__first, __last, __pred, bidirectional_iterator_tag());
williamr@4
   722
}
williamr@4
   723
#endif
williamr@4
   724
williamr@4
   725
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   726
williamr@4
   727
template <class _ForwardIter, class _Predicate>
williamr@4
   728
_ForwardIter partition(_ForwardIter __first, _ForwardIter __last, _Predicate   __pred) {
williamr@4
   729
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   730
  return _STLP_PRIV __partition(__first, __last, __pred, _STLP_ITERATOR_CATEGORY(__first, _ForwardIter));
williamr@4
   731
}
williamr@4
   732
williamr@4
   733
williamr@4
   734
/* __pred_of_first: false if we know that __pred(*__first) is false,
williamr@4
   735
 *                  true when we don't know the result of __pred(*__first).
williamr@4
   736
 * __not_pred_of_before_last: true if we know that __pred(*--__last) is true,
williamr@4
   737
 *                            false when we don't know the result of __pred(*--__last).
williamr@4
   738
 */
williamr@4
   739
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   740
williamr@4
   741
template <class _ForwardIter, class _Predicate, class _Distance>
williamr@4
   742
_ForwardIter __inplace_stable_partition(_ForwardIter __first,
williamr@4
   743
                                        _ForwardIter __last,
williamr@4
   744
                                        _Predicate __pred, _Distance __len,
williamr@4
   745
                                        bool __pred_of_first, bool __pred_of_before_last) {
williamr@4
   746
  if (__len == 1)
williamr@4
   747
    return (__pred_of_first && (__pred_of_before_last || __pred(*__first))) ? __last : __first;
williamr@4
   748
  _ForwardIter __middle = __first;
williamr@4
   749
  _Distance __half_len = __len / 2;
williamr@4
   750
  advance(__middle, __half_len);
williamr@4
   751
  return __rotate(__inplace_stable_partition(__first, __middle, __pred, __half_len, __pred_of_first, false),
williamr@4
   752
                  __middle,
williamr@4
   753
                  __inplace_stable_partition(__middle, __last, __pred, __len - __half_len, true, __pred_of_before_last));
williamr@4
   754
}
williamr@4
   755
williamr@4
   756
template <class _ForwardIter, class _Pointer, class _Predicate,
williamr@4
   757
          class _Distance>
williamr@4
   758
_ForwardIter __stable_partition_adaptive(_ForwardIter __first,
williamr@4
   759
                                         _ForwardIter __last,
williamr@4
   760
                                         _Predicate __pred, _Distance __len,
williamr@4
   761
                                         _Pointer __buffer, _Distance __buffer_size,
williamr@4
   762
                                         bool __pred_of_first, bool __pred_of_before_last) {
williamr@4
   763
  if (__len <= __buffer_size) {
williamr@4
   764
    _ForwardIter __result1 = __first;
williamr@4
   765
    _Pointer __result2 = __buffer;
williamr@4
   766
    if ((__first != __last) && (!__pred_of_first || __pred(*__first))) {
williamr@4
   767
      *__result2 = *__first;
williamr@4
   768
      ++__result2; ++__first; --__len;
williamr@4
   769
    }
williamr@4
   770
    for (; __first != __last ; ++__first, --__len) {
williamr@4
   771
      if (((__len == 1) && (__pred_of_before_last || __pred(*__first))) ||
williamr@4
   772
          ((__len != 1) && __pred(*__first))){
williamr@4
   773
        *__result1 = *__first;
williamr@4
   774
        ++__result1;
williamr@4
   775
      }
williamr@4
   776
      else {
williamr@4
   777
        *__result2 = *__first;
williamr@4
   778
        ++__result2;
williamr@4
   779
      }
williamr@4
   780
    }
williamr@4
   781
    copy(__buffer, __result2, __result1);
williamr@4
   782
    return __result1;
williamr@4
   783
  }
williamr@4
   784
  else {
williamr@4
   785
    _ForwardIter __middle = __first;
williamr@4
   786
    _Distance __half_len = __len / 2;
williamr@4
   787
    advance(__middle, __half_len);
williamr@4
   788
    return __rotate(__stable_partition_adaptive(
williamr@4
   789
                          __first, __middle, __pred,
williamr@4
   790
                          __half_len, __buffer, __buffer_size,
williamr@4
   791
                          __pred_of_first, false),
williamr@4
   792
                    __middle,
williamr@4
   793
                    __stable_partition_adaptive(
williamr@4
   794
                          __middle, __last, __pred,
williamr@4
   795
                          __len - __half_len, __buffer, __buffer_size,
williamr@4
   796
                          true, __pred_of_before_last));
williamr@4
   797
  }
williamr@4
   798
}
williamr@4
   799
williamr@4
   800
template <class _ForwardIter, class _Predicate, class _Tp, class _Distance>
williamr@4
   801
inline _ForwardIter
williamr@4
   802
__stable_partition_aux_aux(_ForwardIter __first, _ForwardIter __last,
williamr@4
   803
                           _Predicate __pred, _Tp*, _Distance*, bool __pred_of_before_last = false) {
williamr@4
   804
  _Temporary_buffer<_ForwardIter, _Tp> __buf(__first, __last);
williamr@4
   805
  _STLP_MPWFIX_TRY    //*TY 06/01/2000 - they forget to call dtor for _Temporary_buffer if no try/catch block is present
williamr@4
   806
  return (__buf.size() > 0) ?
williamr@4
   807
    __stable_partition_adaptive(__first, __last, __pred,
williamr@4
   808
                                _Distance(__buf.requested_size()),
williamr@4
   809
                                __buf.begin(), __buf.size(),
williamr@4
   810
                                false, __pred_of_before_last)  :
williamr@4
   811
    __inplace_stable_partition(__first, __last, __pred,
williamr@4
   812
                               _Distance(__buf.requested_size()),
williamr@4
   813
                               false, __pred_of_before_last);
williamr@4
   814
  _STLP_MPWFIX_CATCH  //*TY 06/01/2000 - they forget to call dtor for _Temporary_buffer if no try/catch block is present
williamr@4
   815
}
williamr@4
   816
williamr@4
   817
template <class _ForwardIter, class _Predicate>
williamr@4
   818
_ForwardIter
williamr@4
   819
__stable_partition_aux(_ForwardIter __first, _ForwardIter __last, _Predicate __pred,
williamr@4
   820
                       const forward_iterator_tag &) {
williamr@4
   821
  return __stable_partition_aux_aux(__first, __last, __pred,
williamr@4
   822
                                    _STLP_VALUE_TYPE(__first, _ForwardIter),
williamr@4
   823
                                    _STLP_DISTANCE_TYPE(__first, _ForwardIter));
williamr@4
   824
}
williamr@4
   825
williamr@4
   826
template <class _BidirectIter, class _Predicate>
williamr@4
   827
_BidirectIter
williamr@4
   828
__stable_partition_aux(_BidirectIter __first, _BidirectIter __last, _Predicate __pred,
williamr@4
   829
                       const bidirectional_iterator_tag &) {
williamr@4
   830
  for (--__last;;) {
williamr@4
   831
    if (__first == __last)
williamr@4
   832
      return __first;
williamr@4
   833
    else if (!__pred(*__last))
williamr@4
   834
      --__last;
williamr@4
   835
    else
williamr@4
   836
      break;
williamr@4
   837
  }
williamr@4
   838
  ++__last;
williamr@4
   839
  //Here we know that __pred(*--__last) is true
williamr@4
   840
  return __stable_partition_aux_aux(__first, __last, __pred,
williamr@4
   841
                                    _STLP_VALUE_TYPE(__first, _BidirectIter),
williamr@4
   842
                                    _STLP_DISTANCE_TYPE(__first, _BidirectIter), true);
williamr@4
   843
}
williamr@4
   844
williamr@4
   845
#if defined (_STLP_NONTEMPL_BASE_MATCH_BUG)
williamr@4
   846
template <class _BidirectIter, class _Predicate>
williamr@4
   847
_BidirectIter
williamr@4
   848
__stable_partition_aux(_BidirectIter __first, _BidirectIter __last, _Predicate __pred,
williamr@4
   849
                       const random_access_iterator_tag &) {
williamr@4
   850
  return __stable_partition_aux(__first, __last, __pred, bidirectional_iterator_tag());
williamr@4
   851
}
williamr@4
   852
#endif
williamr@4
   853
williamr@4
   854
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   855
williamr@4
   856
template <class _ForwardIter, class _Predicate>
williamr@4
   857
_ForwardIter
williamr@4
   858
stable_partition(_ForwardIter __first, _ForwardIter __last, _Predicate __pred) {
williamr@4
   859
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   860
  for (;;) {
williamr@4
   861
    if (__first == __last)
williamr@4
   862
      return __first;
williamr@4
   863
    else if (__pred(*__first))
williamr@4
   864
      ++__first;
williamr@4
   865
    else
williamr@4
   866
      break;
williamr@4
   867
  }
williamr@4
   868
  return _STLP_PRIV __stable_partition_aux(__first, __last, __pred,
williamr@4
   869
                                           _STLP_ITERATOR_CATEGORY(__first, _ForwardIter));
williamr@4
   870
}
williamr@4
   871
williamr@4
   872
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   873
williamr@4
   874
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
   875
_RandomAccessIter __unguarded_partition(_RandomAccessIter __first,
williamr@4
   876
                                        _RandomAccessIter __last,
williamr@4
   877
                                        _Tp __pivot, _Compare __comp) {
williamr@4
   878
  for (;;) {
williamr@4
   879
    while (__comp(*__first, __pivot)) {
williamr@4
   880
      _STLP_VERBOSE_ASSERT(!__comp(__pivot, *__first), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   881
      ++__first;
williamr@4
   882
    }
williamr@4
   883
    --__last;
williamr@4
   884
    while (__comp(__pivot, *__last)) {
williamr@4
   885
      _STLP_VERBOSE_ASSERT(!__comp(*__last, __pivot), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   886
      --__last;
williamr@4
   887
    }
williamr@4
   888
    if (!(__first < __last))
williamr@4
   889
      return __first;
williamr@4
   890
    iter_swap(__first, __last);
williamr@4
   891
    ++__first;
williamr@4
   892
  }
williamr@4
   893
}
williamr@4
   894
williamr@4
   895
// sort() and its auxiliary functions.
williamr@4
   896
#define __stl_threshold  16
williamr@4
   897
williamr@4
   898
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
   899
void __unguarded_linear_insert(_RandomAccessIter __last, _Tp __val,
williamr@4
   900
                               _Compare __comp) {
williamr@4
   901
  _RandomAccessIter __next = __last;
williamr@4
   902
  --__next;
williamr@4
   903
  while (__comp(__val, *__next)) {
williamr@4
   904
    _STLP_VERBOSE_ASSERT(!__comp(*__next, __val), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   905
    *__last = *__next;
williamr@4
   906
    __last = __next;
williamr@4
   907
    --__next;
williamr@4
   908
  }
williamr@4
   909
  *__last = __val;
williamr@4
   910
}
williamr@4
   911
williamr@4
   912
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
   913
inline void __linear_insert(_RandomAccessIter __first,
williamr@4
   914
                            _RandomAccessIter __last, _Tp __val, _Compare __comp) {
williamr@4
   915
  //*TY 12/26/1998 - added __val as a paramter
williamr@4
   916
  //  _Tp __val = *__last;        //*TY 12/26/1998 - __val supplied by caller
williamr@4
   917
  if (__comp(__val, *__first)) {
williamr@4
   918
    _STLP_VERBOSE_ASSERT(!__comp(*__first, __val), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
   919
    copy_backward(__first, __last, __last + 1);
williamr@4
   920
    *__first = __val;
williamr@4
   921
  }
williamr@4
   922
  else
williamr@4
   923
    __unguarded_linear_insert(__last, __val, __comp);
williamr@4
   924
}
williamr@4
   925
williamr@4
   926
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
   927
void __insertion_sort(_RandomAccessIter __first,
williamr@4
   928
                      _RandomAccessIter __last,
williamr@4
   929
                      _Tp *, _Compare __comp) {
williamr@4
   930
  if (__first == __last) return;
williamr@4
   931
  for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
williamr@4
   932
    __linear_insert<_RandomAccessIter, _Tp, _Compare>(__first, __i, *__i, __comp);  //*TY 12/26/1998 - supply *__i as __val
williamr@4
   933
}
williamr@4
   934
williamr@4
   935
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
   936
void __unguarded_insertion_sort_aux(_RandomAccessIter __first,
williamr@4
   937
                                    _RandomAccessIter __last,
williamr@4
   938
                                    _Tp*, _Compare __comp) {
williamr@4
   939
  for (_RandomAccessIter __i = __first; __i != __last; ++__i)
williamr@4
   940
    __unguarded_linear_insert<_RandomAccessIter, _Tp, _Compare>(__i, *__i, __comp);
williamr@4
   941
}
williamr@4
   942
williamr@4
   943
template <class _RandomAccessIter, class _Compare>
williamr@4
   944
inline void __unguarded_insertion_sort(_RandomAccessIter __first,
williamr@4
   945
                                       _RandomAccessIter __last,
williamr@4
   946
                                       _Compare __comp) {
williamr@4
   947
  __unguarded_insertion_sort_aux(__first, __last, _STLP_VALUE_TYPE(__first, _RandomAccessIter), __comp);
williamr@4
   948
}
williamr@4
   949
williamr@4
   950
template <class _RandomAccessIter, class _Compare>
williamr@4
   951
void __final_insertion_sort(_RandomAccessIter __first,
williamr@4
   952
                            _RandomAccessIter __last, _Compare __comp) {
williamr@4
   953
  if (__last - __first > __stl_threshold) {
williamr@4
   954
    __insertion_sort(__first, __first + __stl_threshold, _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
   955
    __unguarded_insertion_sort(__first + __stl_threshold, __last, __comp);
williamr@4
   956
  }
williamr@4
   957
  else
williamr@4
   958
    __insertion_sort(__first, __last, _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
   959
}
williamr@4
   960
williamr@4
   961
template <class _RandomAccessIter, class _Tp, class _Size, class _Compare>
williamr@4
   962
void __introsort_loop(_RandomAccessIter __first,
williamr@4
   963
                      _RandomAccessIter __last, _Tp*,
williamr@4
   964
                      _Size __depth_limit, _Compare __comp) {
williamr@4
   965
  while (__last - __first > __stl_threshold) {
williamr@4
   966
    if (__depth_limit == 0) {
williamr@4
   967
      partial_sort(__first, __last, __last, __comp);
williamr@4
   968
      return;
williamr@4
   969
    }
williamr@4
   970
    --__depth_limit;
williamr@4
   971
    _RandomAccessIter __cut =
williamr@4
   972
      __unguarded_partition(__first, __last,
williamr@4
   973
                            _Tp(__median(*__first,
williamr@4
   974
                                         *(__first + (__last - __first)/2),
williamr@4
   975
                                         *(__last - 1), __comp)),
williamr@4
   976
       __comp);
williamr@4
   977
    __introsort_loop(__cut, __last, (_Tp*) 0, __depth_limit, __comp);
williamr@4
   978
    __last = __cut;
williamr@4
   979
  }
williamr@4
   980
}
williamr@4
   981
williamr@4
   982
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   983
williamr@4
   984
template <class _RandomAccessIter>
williamr@4
   985
void sort(_RandomAccessIter __first, _RandomAccessIter __last) {
williamr@4
   986
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   987
  if (__first != __last) {
williamr@4
   988
    _STLP_PRIV __introsort_loop(__first, __last,
williamr@4
   989
                                _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
   990
                                _STLP_PRIV __lg(__last - __first) * 2,
williamr@4
   991
                                _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)));
williamr@4
   992
    _STLP_PRIV __final_insertion_sort(__first, __last,
williamr@4
   993
                                      _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)));
williamr@4
   994
  }
williamr@4
   995
}
williamr@4
   996
williamr@4
   997
template <class _RandomAccessIter, class _Compare>
williamr@4
   998
void sort(_RandomAccessIter __first, _RandomAccessIter __last, _Compare __comp) {
williamr@4
   999
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1000
  if (__first != __last) {
williamr@4
  1001
    _STLP_PRIV __introsort_loop(__first, __last,
williamr@4
  1002
                                _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
  1003
                                _STLP_PRIV __lg(__last - __first) * 2, __comp);
williamr@4
  1004
    _STLP_PRIV __final_insertion_sort(__first, __last, __comp);
williamr@4
  1005
  }
williamr@4
  1006
}
williamr@4
  1007
williamr@4
  1008
// stable_sort() and its auxiliary functions.
williamr@4
  1009
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1010
williamr@4
  1011
template <class _RandomAccessIter, class _Compare>
williamr@4
  1012
void __inplace_stable_sort(_RandomAccessIter __first,
williamr@4
  1013
                           _RandomAccessIter __last, _Compare __comp) {
williamr@4
  1014
  if (__last - __first < 15) {
williamr@4
  1015
    __insertion_sort(__first, __last, _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
  1016
    return;
williamr@4
  1017
  }
williamr@4
  1018
  _RandomAccessIter __middle = __first + (__last - __first) / 2;
williamr@4
  1019
  __inplace_stable_sort(__first, __middle, __comp);
williamr@4
  1020
  __inplace_stable_sort(__middle, __last, __comp);
williamr@4
  1021
  __merge_without_buffer(__first, __middle, __last,
williamr@4
  1022
                         __middle - __first,
williamr@4
  1023
                         __last - __middle,
williamr@4
  1024
                         __comp);
williamr@4
  1025
}
williamr@4
  1026
williamr@4
  1027
template <class _RandomAccessIter1, class _RandomAccessIter2,
williamr@4
  1028
          class _Distance, class _Compare>
williamr@4
  1029
void __merge_sort_loop(_RandomAccessIter1 __first,
williamr@4
  1030
                       _RandomAccessIter1 __last,
williamr@4
  1031
                       _RandomAccessIter2 __result, _Distance __step_size,
williamr@4
  1032
                       _Compare __comp) {
williamr@4
  1033
  _Distance __two_step = 2 * __step_size;
williamr@4
  1034
williamr@4
  1035
  while (__last - __first >= __two_step) {
williamr@4
  1036
    __result = merge(__first, __first + __step_size,
williamr@4
  1037
                     __first + __step_size, __first + __two_step,
williamr@4
  1038
                     __result,
williamr@4
  1039
                     __comp);
williamr@4
  1040
    __first += __two_step;
williamr@4
  1041
  }
williamr@4
  1042
  __step_size = (min) (_Distance(__last - __first), __step_size);
williamr@4
  1043
williamr@4
  1044
  merge(__first, __first + __step_size,
williamr@4
  1045
        __first + __step_size, __last,
williamr@4
  1046
        __result,
williamr@4
  1047
        __comp);
williamr@4
  1048
}
williamr@4
  1049
williamr@4
  1050
const int __stl_chunk_size = 7;
williamr@4
  1051
williamr@4
  1052
template <class _RandomAccessIter, class _Distance, class _Compare>
williamr@4
  1053
void __chunk_insertion_sort(_RandomAccessIter __first,
williamr@4
  1054
                            _RandomAccessIter __last,
williamr@4
  1055
                            _Distance __chunk_size, _Compare __comp) {
williamr@4
  1056
  while (__last - __first >= __chunk_size) {
williamr@4
  1057
    __insertion_sort(__first, __first + __chunk_size,
williamr@4
  1058
                     _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
  1059
    __first += __chunk_size;
williamr@4
  1060
  }
williamr@4
  1061
  __insertion_sort(__first, __last, _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
  1062
}
williamr@4
  1063
williamr@4
  1064
template <class _RandomAccessIter, class _Pointer, class _Distance,
williamr@4
  1065
          class _Compare>
williamr@4
  1066
void __merge_sort_with_buffer(_RandomAccessIter __first,
williamr@4
  1067
                              _RandomAccessIter __last, _Pointer __buffer,
williamr@4
  1068
                              _Distance*, _Compare __comp) {
williamr@4
  1069
  _Distance __len = __last - __first;
williamr@4
  1070
  _Pointer __buffer_last = __buffer + __len;
williamr@4
  1071
williamr@4
  1072
  _Distance __step_size = __stl_chunk_size;
williamr@4
  1073
  __chunk_insertion_sort(__first, __last, __step_size, __comp);
williamr@4
  1074
williamr@4
  1075
  while (__step_size < __len) {
williamr@4
  1076
    __merge_sort_loop(__first, __last, __buffer, __step_size, __comp);
williamr@4
  1077
    __step_size *= 2;
williamr@4
  1078
    __merge_sort_loop(__buffer, __buffer_last, __first, __step_size, __comp);
williamr@4
  1079
    __step_size *= 2;
williamr@4
  1080
  }
williamr@4
  1081
}
williamr@4
  1082
williamr@4
  1083
template <class _BidirectionalIter1, class _BidirectionalIter2,
williamr@4
  1084
          class _Distance>
williamr@4
  1085
_BidirectionalIter1 __rotate_adaptive(_BidirectionalIter1 __first,
williamr@4
  1086
                                      _BidirectionalIter1 __middle,
williamr@4
  1087
                                      _BidirectionalIter1 __last,
williamr@4
  1088
                                      _Distance __len1, _Distance __len2,
williamr@4
  1089
                                      _BidirectionalIter2 __buffer,
williamr@4
  1090
                                      _Distance __buffer_size) {
williamr@4
  1091
  if (__len1 > __len2 && __len2 <= __buffer_size) {
williamr@4
  1092
    _BidirectionalIter2 __buffer_end = copy(__middle, __last, __buffer);
williamr@4
  1093
    copy_backward(__first, __middle, __last);
williamr@4
  1094
    return copy(__buffer, __buffer_end, __first);
williamr@4
  1095
  }
williamr@4
  1096
  else if (__len1 <= __buffer_size) {
williamr@4
  1097
    _BidirectionalIter2 __buffer_end = copy(__first, __middle, __buffer);
williamr@4
  1098
    copy(__middle, __last, __first);
williamr@4
  1099
    return copy_backward(__buffer, __buffer_end, __last);
williamr@4
  1100
  }
williamr@4
  1101
  else
williamr@4
  1102
    return __rotate(__first, __middle, __last);
williamr@4
  1103
}
williamr@4
  1104
williamr@4
  1105
template <class _BidirectionalIter, class _Distance, class _Pointer,
williamr@4
  1106
          class _Compare>
williamr@4
  1107
void __merge_adaptive(_BidirectionalIter __first,
williamr@4
  1108
                      _BidirectionalIter __middle,
williamr@4
  1109
                      _BidirectionalIter __last,
williamr@4
  1110
                      _Distance __len1, _Distance __len2,
williamr@4
  1111
                      _Pointer __buffer, _Distance __buffer_size,
williamr@4
  1112
                      _Compare __comp) {
williamr@4
  1113
  if (__len1 <= __len2 && __len1 <= __buffer_size) {
williamr@4
  1114
    _Pointer __buffer_end = copy(__first, __middle, __buffer);
williamr@4
  1115
    merge(__buffer, __buffer_end, __middle, __last, __first, __comp);
williamr@4
  1116
  }
williamr@4
  1117
  else if (__len2 <= __buffer_size) {
williamr@4
  1118
    _Pointer __buffer_end = copy(__middle, __last, __buffer);
williamr@4
  1119
    __merge_backward(__first, __middle, __buffer, __buffer_end, __last,
williamr@4
  1120
                     __comp);
williamr@4
  1121
  }
williamr@4
  1122
  else {
williamr@4
  1123
    _BidirectionalIter __first_cut = __first;
williamr@4
  1124
    _BidirectionalIter __second_cut = __middle;
williamr@4
  1125
    _Distance __len11 = 0;
williamr@4
  1126
    _Distance __len22 = 0;
williamr@4
  1127
    if (__len1 > __len2) {
williamr@4
  1128
      __len11 = __len1 / 2;
williamr@4
  1129
      advance(__first_cut, __len11);
williamr@4
  1130
      __second_cut = lower_bound(__middle, __last, *__first_cut, __comp);
williamr@4
  1131
      __len22 += distance(__middle, __second_cut);
williamr@4
  1132
    }
williamr@4
  1133
    else {
williamr@4
  1134
      __len22 = __len2 / 2;
williamr@4
  1135
      advance(__second_cut, __len22);
williamr@4
  1136
      __first_cut = upper_bound(__first, __middle, *__second_cut, __comp);
williamr@4
  1137
      __len11 += distance(__first, __first_cut);
williamr@4
  1138
    }
williamr@4
  1139
    _BidirectionalIter __new_middle =
williamr@4
  1140
      __rotate_adaptive(__first_cut, __middle, __second_cut, __len1 - __len11,
williamr@4
  1141
                        __len22, __buffer, __buffer_size);
williamr@4
  1142
    __merge_adaptive(__first, __first_cut, __new_middle, __len11,
williamr@4
  1143
                     __len22, __buffer, __buffer_size, __comp);
williamr@4
  1144
    __merge_adaptive(__new_middle, __second_cut, __last, __len1 - __len11,
williamr@4
  1145
                     __len2 - __len22, __buffer, __buffer_size, __comp);
williamr@4
  1146
  }
williamr@4
  1147
}
williamr@4
  1148
williamr@4
  1149
template <class _RandomAccessIter, class _Pointer, class _Distance,
williamr@4
  1150
          class _Compare>
williamr@4
  1151
void __stable_sort_adaptive(_RandomAccessIter __first,
williamr@4
  1152
                            _RandomAccessIter __last, _Pointer __buffer,
williamr@4
  1153
                            _Distance __buffer_size, _Compare __comp) {
williamr@4
  1154
  _Distance __len = (__last - __first + 1) / 2;
williamr@4
  1155
  _RandomAccessIter __middle = __first + __len;
williamr@4
  1156
  if (__len > __buffer_size) {
williamr@4
  1157
    __stable_sort_adaptive(__first, __middle, __buffer, __buffer_size,
williamr@4
  1158
                           __comp);
williamr@4
  1159
    __stable_sort_adaptive(__middle, __last, __buffer, __buffer_size,
williamr@4
  1160
                           __comp);
williamr@4
  1161
  }
williamr@4
  1162
  else {
williamr@4
  1163
    __merge_sort_with_buffer(__first, __middle, __buffer, (_Distance*)0,
williamr@4
  1164
                               __comp);
williamr@4
  1165
    __merge_sort_with_buffer(__middle, __last, __buffer, (_Distance*)0,
williamr@4
  1166
                               __comp);
williamr@4
  1167
  }
williamr@4
  1168
  __merge_adaptive(__first, __middle, __last, _Distance(__middle - __first),
williamr@4
  1169
                   _Distance(__last - __middle), __buffer, __buffer_size,
williamr@4
  1170
                   __comp);
williamr@4
  1171
}
williamr@4
  1172
williamr@4
  1173
template <class _RandomAccessIter, class _Tp, class _Distance, class _Compare>
williamr@4
  1174
void __stable_sort_aux(_RandomAccessIter __first,
williamr@4
  1175
                       _RandomAccessIter __last, _Tp*, _Distance*,
williamr@4
  1176
                       _Compare __comp) {
williamr@4
  1177
  _Temporary_buffer<_RandomAccessIter, _Tp> buf(__first, __last);
williamr@4
  1178
  if (buf.begin() == 0)
williamr@4
  1179
    __inplace_stable_sort(__first, __last, __comp);
williamr@4
  1180
  else
williamr@4
  1181
    __stable_sort_adaptive(__first, __last, buf.begin(),
williamr@4
  1182
                           _Distance(buf.size()),
williamr@4
  1183
                           __comp);
williamr@4
  1184
}
williamr@4
  1185
williamr@4
  1186
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1187
williamr@4
  1188
template <class _RandomAccessIter>
williamr@4
  1189
void stable_sort(_RandomAccessIter __first,
williamr@4
  1190
                 _RandomAccessIter __last) {
williamr@4
  1191
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1192
  _STLP_PRIV __stable_sort_aux(__first, __last,
williamr@4
  1193
                               _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
  1194
                               _STLP_DISTANCE_TYPE(__first, _RandomAccessIter),
williamr@4
  1195
                               _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)));
williamr@4
  1196
}
williamr@4
  1197
williamr@4
  1198
template <class _RandomAccessIter, class _Compare>
williamr@4
  1199
void stable_sort(_RandomAccessIter __first,
williamr@4
  1200
                 _RandomAccessIter __last, _Compare __comp) {
williamr@4
  1201
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1202
  _STLP_PRIV __stable_sort_aux(__first, __last,
williamr@4
  1203
                               _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
  1204
                               _STLP_DISTANCE_TYPE(__first, _RandomAccessIter),
williamr@4
  1205
                               __comp);
williamr@4
  1206
}
williamr@4
  1207
williamr@4
  1208
// partial_sort, partial_sort_copy, and auxiliary functions.
williamr@4
  1209
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1210
williamr@4
  1211
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
  1212
void __partial_sort(_RandomAccessIter __first, _RandomAccessIter __middle,
williamr@4
  1213
                    _RandomAccessIter __last, _Tp*, _Compare __comp) {
williamr@4
  1214
  make_heap(__first, __middle, __comp);
williamr@4
  1215
  for (_RandomAccessIter __i = __middle; __i < __last; ++__i) {
williamr@4
  1216
    if (__comp(*__i, *__first)) {
williamr@4
  1217
      _STLP_VERBOSE_ASSERT(!__comp(*__first, *__i), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1218
      __pop_heap(__first, __middle, __i, _Tp(*__i), __comp,
williamr@4
  1219
                 _STLP_DISTANCE_TYPE(__first, _RandomAccessIter));
williamr@4
  1220
    }
williamr@4
  1221
  }
williamr@4
  1222
  sort_heap(__first, __middle, __comp);
williamr@4
  1223
}
williamr@4
  1224
williamr@4
  1225
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1226
williamr@4
  1227
template <class _RandomAccessIter>
williamr@4
  1228
void partial_sort(_RandomAccessIter __first,_RandomAccessIter __middle,
williamr@4
  1229
                  _RandomAccessIter __last) {
williamr@4
  1230
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __middle))
williamr@4
  1231
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__middle, __last))
williamr@4
  1232
  _STLP_PRIV __partial_sort(__first, __middle, __last, _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
  1233
                            _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)));
williamr@4
  1234
}
williamr@4
  1235
williamr@4
  1236
template <class _RandomAccessIter, class _Compare>
williamr@4
  1237
void partial_sort(_RandomAccessIter __first,_RandomAccessIter __middle,
williamr@4
  1238
                  _RandomAccessIter __last, _Compare __comp) {
williamr@4
  1239
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __middle))
williamr@4
  1240
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__middle, __last))
williamr@4
  1241
  _STLP_PRIV __partial_sort(__first, __middle, __last, _STLP_VALUE_TYPE(__first, _RandomAccessIter), __comp);
williamr@4
  1242
}
williamr@4
  1243
williamr@4
  1244
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1245
williamr@4
  1246
template <class _InputIter, class _RandomAccessIter, class _Compare,
williamr@4
  1247
          class _Distance, class _Tp>
williamr@4
  1248
_RandomAccessIter __partial_sort_copy(_InputIter __first,
williamr@4
  1249
                                      _InputIter __last,
williamr@4
  1250
                                      _RandomAccessIter __result_first,
williamr@4
  1251
                                      _RandomAccessIter __result_last,
williamr@4
  1252
                                      _Compare __comp, _Distance*, _Tp*) {
williamr@4
  1253
  if (__result_first == __result_last) return __result_last;
williamr@4
  1254
  _RandomAccessIter __result_real_last = __result_first;
williamr@4
  1255
  while(__first != __last && __result_real_last != __result_last) {
williamr@4
  1256
    *__result_real_last = *__first;
williamr@4
  1257
    ++__result_real_last;
williamr@4
  1258
    ++__first;
williamr@4
  1259
  }
williamr@4
  1260
  make_heap(__result_first, __result_real_last, __comp);
williamr@4
  1261
  while (__first != __last) {
williamr@4
  1262
    if (__comp(*__first, *__result_first)) {
williamr@4
  1263
      _STLP_VERBOSE_ASSERT(!__comp(*__result_first, *__first), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1264
      __adjust_heap(__result_first, _Distance(0),
williamr@4
  1265
                    _Distance(__result_real_last - __result_first),
williamr@4
  1266
                    _Tp(*__first),
williamr@4
  1267
                    __comp);
williamr@4
  1268
    }
williamr@4
  1269
    ++__first;
williamr@4
  1270
  }
williamr@4
  1271
  sort_heap(__result_first, __result_real_last, __comp);
williamr@4
  1272
  return __result_real_last;
williamr@4
  1273
}
williamr@4
  1274
williamr@4
  1275
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1276
williamr@4
  1277
template <class _InputIter, class _RandomAccessIter>
williamr@4
  1278
_RandomAccessIter
williamr@4
  1279
partial_sort_copy(_InputIter __first, _InputIter __last,
williamr@4
  1280
                  _RandomAccessIter __result_first, _RandomAccessIter __result_last) {
williamr@4
  1281
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1282
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__result_first, __result_last))
williamr@4
  1283
  return _STLP_PRIV __partial_sort_copy(__first, __last, __result_first, __result_last,
williamr@4
  1284
                                        _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _InputIter)),
williamr@4
  1285
                                        _STLP_DISTANCE_TYPE(__result_first, _RandomAccessIter),
williamr@4
  1286
                                        _STLP_VALUE_TYPE(__first, _InputIter));
williamr@4
  1287
}
williamr@4
  1288
williamr@4
  1289
template <class _InputIter, class _RandomAccessIter, class _Compare>
williamr@4
  1290
_RandomAccessIter
williamr@4
  1291
partial_sort_copy(_InputIter __first, _InputIter __last,
williamr@4
  1292
                  _RandomAccessIter __result_first,
williamr@4
  1293
                  _RandomAccessIter __result_last, _Compare __comp) {
williamr@4
  1294
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1295
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__result_first, __result_last))
williamr@4
  1296
  return _STLP_PRIV __partial_sort_copy(__first, __last, __result_first, __result_last,
williamr@4
  1297
                                        __comp,
williamr@4
  1298
                                        _STLP_DISTANCE_TYPE(__result_first, _RandomAccessIter),
williamr@4
  1299
                                        _STLP_VALUE_TYPE(__first, _InputIter));
williamr@4
  1300
}
williamr@4
  1301
williamr@4
  1302
// nth_element() and its auxiliary functions.
williamr@4
  1303
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1304
williamr@4
  1305
template <class _RandomAccessIter, class _Tp, class _Compare>
williamr@4
  1306
void __nth_element(_RandomAccessIter __first, _RandomAccessIter __nth,
williamr@4
  1307
                   _RandomAccessIter __last, _Tp*, _Compare __comp) {
williamr@4
  1308
  while (__last - __first > 3) {
williamr@4
  1309
    _RandomAccessIter __cut =
williamr@4
  1310
      __unguarded_partition(__first, __last,
williamr@4
  1311
                            _Tp(__median(*__first,
williamr@4
  1312
                                         *(__first + (__last - __first)/2),
williamr@4
  1313
                                         *(__last - 1),
williamr@4
  1314
                                         __comp)),
williamr@4
  1315
                            __comp);
williamr@4
  1316
    if (__cut <= __nth)
williamr@4
  1317
      __first = __cut;
williamr@4
  1318
    else
williamr@4
  1319
      __last = __cut;
williamr@4
  1320
  }
williamr@4
  1321
  __insertion_sort(__first, __last, _STLP_VALUE_TYPE(__first,_RandomAccessIter), __comp);
williamr@4
  1322
}
williamr@4
  1323
williamr@4
  1324
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1325
williamr@4
  1326
template <class _RandomAccessIter>
williamr@4
  1327
void nth_element(_RandomAccessIter __first, _RandomAccessIter __nth,
williamr@4
  1328
                 _RandomAccessIter __last) {
williamr@4
  1329
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __nth))
williamr@4
  1330
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__nth, __last))
williamr@4
  1331
  _STLP_PRIV __nth_element(__first, __nth, __last, _STLP_VALUE_TYPE(__first, _RandomAccessIter),
williamr@4
  1332
                           _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)));
williamr@4
  1333
}
williamr@4
  1334
williamr@4
  1335
template <class _RandomAccessIter, class _Compare>
williamr@4
  1336
void nth_element(_RandomAccessIter __first, _RandomAccessIter __nth,
williamr@4
  1337
                 _RandomAccessIter __last, _Compare __comp) {
williamr@4
  1338
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __nth))
williamr@4
  1339
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__nth, __last))
williamr@4
  1340
  _STLP_PRIV __nth_element(__first, __nth, __last, _STLP_VALUE_TYPE(__first, _RandomAccessIter), __comp);
williamr@4
  1341
}
williamr@4
  1342
williamr@4
  1343
// Binary search (lower_bound, upper_bound, equal_range, binary_search).
williamr@4
  1344
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1345
williamr@4
  1346
template <class _ForwardIter, class _Tp,
williamr@4
  1347
          class _Compare1, class _Compare2, class _Distance>
williamr@4
  1348
_ForwardIter __upper_bound(_ForwardIter __first, _ForwardIter __last, const _Tp& __val,
williamr@4
  1349
                           _Compare1 __comp1, _Compare2 __comp2, _Distance*) {
williamr@4
  1350
  _Distance __len = distance(__first, __last);
williamr@4
  1351
  _Distance __half;
williamr@4
  1352
williamr@4
  1353
  while (__len > 0) {
williamr@4
  1354
    __half = __len >> 1;
williamr@4
  1355
    _ForwardIter __middle = __first;
williamr@4
  1356
    advance(__middle, __half);
williamr@4
  1357
    if (__comp2(__val, *__middle)) {
williamr@4
  1358
      _STLP_VERBOSE_ASSERT(!__comp1(*__middle, __val), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1359
      __len = __half;
williamr@4
  1360
    }
williamr@4
  1361
    else {
williamr@4
  1362
      __first = __middle;
williamr@4
  1363
      ++__first;
williamr@4
  1364
      __len = __len - __half - 1;
williamr@4
  1365
    }
williamr@4
  1366
  }
williamr@4
  1367
  return __first;
williamr@4
  1368
}
williamr@4
  1369
williamr@4
  1370
template <class _ForwardIter, class _Tp,
williamr@4
  1371
          class _Compare1, class _Compare2, class _Distance>
williamr@4
  1372
pair<_ForwardIter, _ForwardIter>
williamr@4
  1373
__equal_range(_ForwardIter __first, _ForwardIter __last, const _Tp& __val,
williamr@4
  1374
              _Compare1 __comp1, _Compare2 __comp2, _Distance* __dist) {
williamr@4
  1375
  _Distance __len = distance(__first, __last);
williamr@4
  1376
  _Distance __half;
williamr@4
  1377
williamr@4
  1378
  while (__len > 0) {
williamr@4
  1379
    __half = __len >> 1;
williamr@4
  1380
    _ForwardIter __middle = __first;
williamr@4
  1381
    advance(__middle, __half);
williamr@4
  1382
    if (__comp1(*__middle, __val)) {
williamr@4
  1383
      _STLP_VERBOSE_ASSERT(!__comp2(__val, *__middle), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1384
      __first = __middle;
williamr@4
  1385
      ++__first;
williamr@4
  1386
      __len = __len - __half - 1;
williamr@4
  1387
    }
williamr@4
  1388
    else if (__comp2(__val, *__middle)) {
williamr@4
  1389
      _STLP_VERBOSE_ASSERT(!__comp1(*__middle, __val), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1390
      __len = __half;
williamr@4
  1391
    }
williamr@4
  1392
    else {
williamr@4
  1393
      _ForwardIter __left = __lower_bound(__first, __middle, __val, __comp1, __comp2, __dist);
williamr@4
  1394
      //Small optim: If lower_bound haven't found an equivalent value
williamr@4
  1395
      //there is no need to call upper_bound.
williamr@4
  1396
      if (__comp1(*__left, __val)) {
williamr@4
  1397
        _STLP_VERBOSE_ASSERT(!__comp2(__val, *__left), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1398
        return pair<_ForwardIter, _ForwardIter>(__left, __left);
williamr@4
  1399
      }
williamr@4
  1400
      advance(__first, __len);
williamr@4
  1401
      _ForwardIter __right = __upper_bound(++__middle, __first, __val, __comp1, __comp2, __dist);
williamr@4
  1402
      return pair<_ForwardIter, _ForwardIter>(__left, __right);
williamr@4
  1403
    }
williamr@4
  1404
  }
williamr@4
  1405
  return pair<_ForwardIter, _ForwardIter>(__first, __first);
williamr@4
  1406
}
williamr@4
  1407
williamr@4
  1408
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1409
williamr@4
  1410
template <class _InputIter1, class _InputIter2, class _OutputIter>
williamr@4
  1411
_OutputIter merge(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1412
                  _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1413
                  _OutputIter __result) {
williamr@4
  1414
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
  1415
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
  1416
  while (__first1 != __last1 && __first2 != __last2) {
williamr@4
  1417
    if (*__first2 < *__first1) {
williamr@4
  1418
      *__result = *__first2;
williamr@4
  1419
      ++__first2;
williamr@4
  1420
    }
williamr@4
  1421
    else {
williamr@4
  1422
      *__result = *__first1;
williamr@4
  1423
      ++__first1;
williamr@4
  1424
    }
williamr@4
  1425
    ++__result;
williamr@4
  1426
  }
williamr@4
  1427
  return copy(__first2, __last2, copy(__first1, __last1, __result));
williamr@4
  1428
}
williamr@4
  1429
williamr@4
  1430
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1431
          class _Compare>
williamr@4
  1432
_OutputIter merge(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1433
                  _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1434
                  _OutputIter __result, _Compare __comp) {
williamr@4
  1435
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
  1436
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
  1437
  while (__first1 != __last1 && __first2 != __last2) {
williamr@4
  1438
    if (__comp(*__first2, *__first1)) {
williamr@4
  1439
      _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1440
      *__result = *__first2;
williamr@4
  1441
      ++__first2;
williamr@4
  1442
    }
williamr@4
  1443
    else {
williamr@4
  1444
      *__result = *__first1;
williamr@4
  1445
      ++__first1;
williamr@4
  1446
    }
williamr@4
  1447
    ++__result;
williamr@4
  1448
  }
williamr@4
  1449
  return copy(__first2, __last2, copy(__first1, __last1, __result));
williamr@4
  1450
}
williamr@4
  1451
williamr@4
  1452
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1453
williamr@4
  1454
template <class _BidirectionalIter, class _Distance, class _Compare>
williamr@4
  1455
void __merge_without_buffer(_BidirectionalIter __first,
williamr@4
  1456
                            _BidirectionalIter __middle,
williamr@4
  1457
                            _BidirectionalIter __last,
williamr@4
  1458
                            _Distance __len1, _Distance __len2,
williamr@4
  1459
                            _Compare __comp) {
williamr@4
  1460
  if (__len1 == 0 || __len2 == 0)
williamr@4
  1461
    return;
williamr@4
  1462
  if (__len1 + __len2 == 2) {
williamr@4
  1463
    if (__comp(*__middle, *__first)) {
williamr@4
  1464
      _STLP_VERBOSE_ASSERT(!__comp(*__first, *__middle), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1465
      iter_swap(__first, __middle);
williamr@4
  1466
    }
williamr@4
  1467
    return;
williamr@4
  1468
  }
williamr@4
  1469
  _BidirectionalIter __first_cut = __first;
williamr@4
  1470
  _BidirectionalIter __second_cut = __middle;
williamr@4
  1471
  _Distance __len11 = 0;
williamr@4
  1472
  _Distance __len22 = 0;
williamr@4
  1473
  if (__len1 > __len2) {
williamr@4
  1474
    __len11 = __len1 / 2;
williamr@4
  1475
    advance(__first_cut, __len11);
williamr@4
  1476
    __second_cut = lower_bound(__middle, __last, *__first_cut, __comp);
williamr@4
  1477
    __len22 += distance(__middle, __second_cut);
williamr@4
  1478
  }
williamr@4
  1479
  else {
williamr@4
  1480
    __len22 = __len2 / 2;
williamr@4
  1481
    advance(__second_cut, __len22);
williamr@4
  1482
    __first_cut = upper_bound(__first, __middle, *__second_cut, __comp);
williamr@4
  1483
    __len11 +=distance(__first, __first_cut);
williamr@4
  1484
  }
williamr@4
  1485
  _BidirectionalIter __new_middle
williamr@4
  1486
    = __rotate(__first_cut, __middle, __second_cut);
williamr@4
  1487
  __merge_without_buffer(__first, __first_cut, __new_middle, __len11, __len22,
williamr@4
  1488
                         __comp);
williamr@4
  1489
  __merge_without_buffer(__new_middle, __second_cut, __last, __len1 - __len11,
williamr@4
  1490
                         __len2 - __len22, __comp);
williamr@4
  1491
}
williamr@4
  1492
williamr@4
  1493
template <class _BidirectionalIter1, class _BidirectionalIter2,
williamr@4
  1494
          class _BidirectionalIter3, class _Compare>
williamr@4
  1495
_BidirectionalIter3 __merge_backward(_BidirectionalIter1 __first1,
williamr@4
  1496
                                     _BidirectionalIter1 __last1,
williamr@4
  1497
                                     _BidirectionalIter2 __first2,
williamr@4
  1498
                                     _BidirectionalIter2 __last2,
williamr@4
  1499
                                     _BidirectionalIter3 __result,
williamr@4
  1500
                                     _Compare __comp) {
williamr@4
  1501
  if (__first1 == __last1)
williamr@4
  1502
    return copy_backward(__first2, __last2, __result);
williamr@4
  1503
  if (__first2 == __last2)
williamr@4
  1504
    return copy_backward(__first1, __last1, __result);
williamr@4
  1505
  --__last1;
williamr@4
  1506
  --__last2;
williamr@4
  1507
  for (;;) {
williamr@4
  1508
    if (__comp(*__last2, *__last1)) {
williamr@4
  1509
      _STLP_VERBOSE_ASSERT(!__comp(*__last1, *__last2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1510
      *--__result = *__last1;
williamr@4
  1511
      if (__first1 == __last1)
williamr@4
  1512
        return copy_backward(__first2, ++__last2, __result);
williamr@4
  1513
      --__last1;
williamr@4
  1514
    }
williamr@4
  1515
    else {
williamr@4
  1516
      *--__result = *__last2;
williamr@4
  1517
      if (__first2 == __last2)
williamr@4
  1518
        return copy_backward(__first1, ++__last1, __result);
williamr@4
  1519
      --__last2;
williamr@4
  1520
    }
williamr@4
  1521
  }
williamr@4
  1522
}
williamr@4
  1523
williamr@4
  1524
template <class _BidirectionalIter, class _Tp,
williamr@4
  1525
          class _Distance, class _Compare>
williamr@4
  1526
inline void __inplace_merge_aux(_BidirectionalIter __first,
williamr@4
  1527
                                _BidirectionalIter __middle,
williamr@4
  1528
                                _BidirectionalIter __last, _Tp*, _Distance*,
williamr@4
  1529
                                _Compare __comp) {
williamr@4
  1530
  _Distance __len1 = distance(__first, __middle);
williamr@4
  1531
  _Distance __len2 = distance(__middle, __last);
williamr@4
  1532
williamr@4
  1533
  _Temporary_buffer<_BidirectionalIter, _Tp> __buf(__first, __last);
williamr@4
  1534
  if (__buf.begin() == 0)
williamr@4
  1535
    __merge_without_buffer(__first, __middle, __last, __len1, __len2, __comp);
williamr@4
  1536
  else
williamr@4
  1537
    __merge_adaptive(__first, __middle, __last, __len1, __len2,
williamr@4
  1538
                     __buf.begin(), _Distance(__buf.size()),
williamr@4
  1539
                     __comp);
williamr@4
  1540
}
williamr@4
  1541
williamr@4
  1542
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1543
williamr@4
  1544
template <class _BidirectionalIter>
williamr@4
  1545
void inplace_merge(_BidirectionalIter __first,
williamr@4
  1546
                   _BidirectionalIter __middle,
williamr@4
  1547
                   _BidirectionalIter __last) {
williamr@4
  1548
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __middle))
williamr@4
  1549
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__middle, __last))
williamr@4
  1550
  if (__first == __middle || __middle == __last)
williamr@4
  1551
    return;
williamr@4
  1552
  _STLP_PRIV __inplace_merge_aux(__first, __middle, __last,
williamr@4
  1553
                                 _STLP_VALUE_TYPE(__first, _BidirectionalIter), _STLP_DISTANCE_TYPE(__first, _BidirectionalIter),
williamr@4
  1554
                                 _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _BidirectionalIter)));
williamr@4
  1555
}
williamr@4
  1556
williamr@4
  1557
template <class _BidirectionalIter, class _Compare>
williamr@4
  1558
void inplace_merge(_BidirectionalIter __first,
williamr@4
  1559
                   _BidirectionalIter __middle,
williamr@4
  1560
                   _BidirectionalIter __last, _Compare __comp) {
williamr@4
  1561
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __middle))
williamr@4
  1562
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__middle, __last))
williamr@4
  1563
  if (__first == __middle || __middle == __last)
williamr@4
  1564
    return;
williamr@4
  1565
  _STLP_PRIV __inplace_merge_aux(__first, __middle, __last,
williamr@4
  1566
                                 _STLP_VALUE_TYPE(__first, _BidirectionalIter), _STLP_DISTANCE_TYPE(__first, _BidirectionalIter),
williamr@4
  1567
                                 __comp);
williamr@4
  1568
}
williamr@4
  1569
williamr@4
  1570
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1571
williamr@4
  1572
template <class _InputIter1, class _InputIter2, class _Compare>
williamr@4
  1573
bool __includes(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1574
                _InputIter2 __first2, _InputIter2 __last2, _Compare __comp) {
williamr@4
  1575
  _STLP_DEBUG_CHECK(__check_range(__first1, __last1))
williamr@4
  1576
  _STLP_DEBUG_CHECK(__check_range(__first2, __last2))
williamr@4
  1577
  while (__first1 != __last1 && __first2 != __last2)
williamr@4
  1578
    if (__comp(*__first2, *__first1)) {
williamr@4
  1579
      _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1580
      return false;
williamr@4
  1581
    }
williamr@4
  1582
    else if (__comp(*__first1, *__first2))
williamr@4
  1583
      ++__first1;
williamr@4
  1584
    else
williamr@4
  1585
      ++__first1, ++__first2;
williamr@4
  1586
williamr@4
  1587
  return __first2 == __last2;
williamr@4
  1588
}
williamr@4
  1589
williamr@4
  1590
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1591
williamr@4
  1592
template <class _InputIter1, class _InputIter2, class _Compare>
williamr@4
  1593
bool includes(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1594
              _InputIter2 __first2, _InputIter2 __last2, _Compare __comp) {
williamr@4
  1595
  return _STLP_PRIV __includes(__first1, __last1, __first2, __last2, __comp);
williamr@4
  1596
}
williamr@4
  1597
williamr@4
  1598
template <class _InputIter1, class _InputIter2>
williamr@4
  1599
bool includes(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1600
              _InputIter2 __first2, _InputIter2 __last2) {
williamr@4
  1601
  return _STLP_PRIV __includes(__first1, __last1, __first2, __last2,
williamr@4
  1602
                               _STLP_PRIV __less(_STLP_VALUE_TYPE(__first1, _InputIter1)));
williamr@4
  1603
}
williamr@4
  1604
williamr@4
  1605
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1606
williamr@4
  1607
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1608
          class _Compare>
williamr@4
  1609
_OutputIter __set_union(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1610
                        _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1611
                        _OutputIter __result, _Compare __comp) {
williamr@4
  1612
  _STLP_DEBUG_CHECK(__check_range(__first1, __last1))
williamr@4
  1613
  _STLP_DEBUG_CHECK(__check_range(__first2, __last2))
williamr@4
  1614
  while (__first1 != __last1 && __first2 != __last2) {
williamr@4
  1615
    if (__comp(*__first1, *__first2)) {
williamr@4
  1616
      _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1617
      *__result = *__first1;
williamr@4
  1618
      ++__first1;
williamr@4
  1619
    }
williamr@4
  1620
    else if (__comp(*__first2, *__first1)) {
williamr@4
  1621
      _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1622
      *__result = *__first2;
williamr@4
  1623
      ++__first2;
williamr@4
  1624
    }
williamr@4
  1625
    else {
williamr@4
  1626
      *__result = *__first1;
williamr@4
  1627
      ++__first1;
williamr@4
  1628
      ++__first2;
williamr@4
  1629
    }
williamr@4
  1630
    ++__result;
williamr@4
  1631
  }
williamr@4
  1632
  return copy(__first2, __last2, copy(__first1, __last1, __result));
williamr@4
  1633
}
williamr@4
  1634
williamr@4
  1635
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1636
williamr@4
  1637
template <class _InputIter1, class _InputIter2, class _OutputIter>
williamr@4
  1638
_OutputIter set_union(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1639
                      _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1640
                      _OutputIter __result) {
williamr@4
  1641
  return _STLP_PRIV __set_union(__first1, __last1, __first2, __last2, __result,
williamr@4
  1642
                                _STLP_PRIV __less(_STLP_VALUE_TYPE(__first1, _InputIter1)));
williamr@4
  1643
}
williamr@4
  1644
williamr@4
  1645
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1646
          class _Compare>
williamr@4
  1647
_OutputIter set_union(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1648
                      _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1649
                      _OutputIter __result, _Compare __comp) {
williamr@4
  1650
  return _STLP_PRIV __set_union(__first1, __last1, __first2, __last2, __result, __comp);
williamr@4
  1651
}
williamr@4
  1652
williamr@4
  1653
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1654
williamr@4
  1655
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1656
          class _Compare>
williamr@4
  1657
_OutputIter __set_intersection(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1658
                               _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1659
                               _OutputIter __result, _Compare __comp) {
williamr@4
  1660
  _STLP_DEBUG_CHECK(__check_range(__first1, __last1))
williamr@4
  1661
  _STLP_DEBUG_CHECK(__check_range(__first2, __last2))
williamr@4
  1662
  while (__first1 != __last1 && __first2 != __last2)
williamr@4
  1663
    if (__comp(*__first1, *__first2)) {
williamr@4
  1664
      _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1665
      ++__first1;
williamr@4
  1666
    }
williamr@4
  1667
    else if (__comp(*__first2, *__first1))
williamr@4
  1668
      ++__first2;
williamr@4
  1669
    else {
williamr@4
  1670
      *__result = *__first1;
williamr@4
  1671
      ++__first1;
williamr@4
  1672
      ++__first2;
williamr@4
  1673
      ++__result;
williamr@4
  1674
    }
williamr@4
  1675
  return __result;
williamr@4
  1676
}
williamr@4
  1677
williamr@4
  1678
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1679
williamr@4
  1680
template <class _InputIter1, class _InputIter2, class _OutputIter>
williamr@4
  1681
_OutputIter set_intersection(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1682
                             _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1683
                             _OutputIter __result) {
williamr@4
  1684
  return _STLP_PRIV __set_intersection(__first1, __last1, __first2, __last2, __result,
williamr@4
  1685
                                       _STLP_PRIV __less(_STLP_VALUE_TYPE(__first1, _InputIter1)));
williamr@4
  1686
}
williamr@4
  1687
williamr@4
  1688
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1689
          class _Compare>
williamr@4
  1690
_OutputIter set_intersection(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1691
                             _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1692
                             _OutputIter __result, _Compare __comp) {
williamr@4
  1693
  return _STLP_PRIV __set_intersection(__first1, __last1, __first2, __last2, __result, __comp);
williamr@4
  1694
}
williamr@4
  1695
williamr@4
  1696
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1697
williamr@4
  1698
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1699
          class _Compare>
williamr@4
  1700
_OutputIter __set_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1701
                             _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1702
                             _OutputIter __result, _Compare __comp) {
williamr@4
  1703
  _STLP_DEBUG_CHECK(__check_range(__first1, __last1))
williamr@4
  1704
  _STLP_DEBUG_CHECK(__check_range(__first2, __last2))
williamr@4
  1705
  while (__first1 != __last1 && __first2 != __last2)
williamr@4
  1706
    if (__comp(*__first1, *__first2)) {
williamr@4
  1707
      _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1708
      *__result = *__first1;
williamr@4
  1709
      ++__first1;
williamr@4
  1710
      ++__result;
williamr@4
  1711
    }
williamr@4
  1712
    else if (__comp(*__first2, *__first1))
williamr@4
  1713
      ++__first2;
williamr@4
  1714
    else {
williamr@4
  1715
      ++__first1;
williamr@4
  1716
      ++__first2;
williamr@4
  1717
    }
williamr@4
  1718
  return copy(__first1, __last1, __result);
williamr@4
  1719
}
williamr@4
  1720
williamr@4
  1721
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1722
williamr@4
  1723
template <class _InputIter1, class _InputIter2, class _OutputIter>
williamr@4
  1724
_OutputIter set_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1725
                           _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1726
                           _OutputIter __result) {
williamr@4
  1727
  return _STLP_PRIV __set_difference(__first1, __last1, __first2, __last2, __result,
williamr@4
  1728
                                     _STLP_PRIV __less(_STLP_VALUE_TYPE(__first1, _InputIter1)));
williamr@4
  1729
}
williamr@4
  1730
williamr@4
  1731
template <class _InputIter1, class _InputIter2, class _OutputIter,
williamr@4
  1732
          class _Compare>
williamr@4
  1733
_OutputIter set_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1734
                           _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1735
                           _OutputIter __result, _Compare __comp) {
williamr@4
  1736
  return _STLP_PRIV __set_difference(__first1, __last1, __first2, __last2, __result, __comp);
williamr@4
  1737
}
williamr@4
  1738
williamr@4
  1739
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1740
williamr@4
  1741
template <class _InputIter1, class _InputIter2, class _OutputIter, class _Compare>
williamr@4
  1742
_OutputIter
williamr@4
  1743
__set_symmetric_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1744
                           _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1745
                           _OutputIter __result, _Compare __comp) {
williamr@4
  1746
  _STLP_DEBUG_CHECK(__check_range(__first1, __last1))
williamr@4
  1747
  _STLP_DEBUG_CHECK(__check_range(__first2, __last2))
williamr@4
  1748
  while (__first1 != __last1 && __first2 != __last2) {
williamr@4
  1749
    if (__comp(*__first1, *__first2)) {
williamr@4
  1750
      _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1751
      *__result = *__first1;
williamr@4
  1752
      ++__first1;
williamr@4
  1753
      ++__result;
williamr@4
  1754
    }
williamr@4
  1755
    else if (__comp(*__first2, *__first1)) {
williamr@4
  1756
      *__result = *__first2;
williamr@4
  1757
      ++__first2;
williamr@4
  1758
      ++__result;
williamr@4
  1759
    }
williamr@4
  1760
    else {
williamr@4
  1761
      ++__first1;
williamr@4
  1762
      ++__first2;
williamr@4
  1763
    }
williamr@4
  1764
  }
williamr@4
  1765
  return copy(__first2, __last2, copy(__first1, __last1, __result));
williamr@4
  1766
}
williamr@4
  1767
williamr@4
  1768
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1769
williamr@4
  1770
template <class _InputIter1, class _InputIter2, class _OutputIter>
williamr@4
  1771
_OutputIter
williamr@4
  1772
set_symmetric_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1773
                         _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1774
                         _OutputIter __result) {
williamr@4
  1775
  return _STLP_PRIV __set_symmetric_difference(__first1, __last1, __first2, __last2, __result,
williamr@4
  1776
                                               _STLP_PRIV __less(_STLP_VALUE_TYPE(__first1, _InputIter1)));
williamr@4
  1777
}
williamr@4
  1778
williamr@4
  1779
template <class _InputIter1, class _InputIter2, class _OutputIter, class _Compare>
williamr@4
  1780
_OutputIter
williamr@4
  1781
set_symmetric_difference(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
  1782
                         _InputIter2 __first2, _InputIter2 __last2,
williamr@4
  1783
                         _OutputIter __result,
williamr@4
  1784
                         _Compare __comp) {
williamr@4
  1785
  return _STLP_PRIV __set_symmetric_difference(__first1, __last1, __first2, __last2, __result, __comp);
williamr@4
  1786
}
williamr@4
  1787
williamr@4
  1788
// min_element and max_element, with and without an explicitly supplied
williamr@4
  1789
// comparison function.
williamr@4
  1790
williamr@4
  1791
template <class _ForwardIter>
williamr@4
  1792
_ForwardIter max_element(_ForwardIter __first, _ForwardIter __last) {
williamr@4
  1793
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1794
  if (__first == __last) return __first;
williamr@4
  1795
  _ForwardIter __result = __first;
williamr@4
  1796
  while (++__first != __last)
williamr@4
  1797
    if (*__result < *__first)
williamr@4
  1798
      __result = __first;
williamr@4
  1799
  return __result;
williamr@4
  1800
}
williamr@4
  1801
williamr@4
  1802
template <class _ForwardIter, class _Compare>
williamr@4
  1803
_ForwardIter max_element(_ForwardIter __first, _ForwardIter __last,
williamr@4
  1804
                         _Compare __comp) {
williamr@4
  1805
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1806
  if (__first == __last) return __first;
williamr@4
  1807
  _ForwardIter __result = __first;
williamr@4
  1808
  while (++__first != __last) {
williamr@4
  1809
    if (__comp(*__result, *__first)) {
williamr@4
  1810
      _STLP_VERBOSE_ASSERT(!__comp(*__first, *__result), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1811
      __result = __first;
williamr@4
  1812
    }
williamr@4
  1813
  }
williamr@4
  1814
  return __result;
williamr@4
  1815
}
williamr@4
  1816
williamr@4
  1817
template <class _ForwardIter>
williamr@4
  1818
_ForwardIter min_element(_ForwardIter __first, _ForwardIter __last) {
williamr@4
  1819
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1820
  if (__first == __last) return __first;
williamr@4
  1821
  _ForwardIter __result = __first;
williamr@4
  1822
  while (++__first != __last)
williamr@4
  1823
    if (*__first < *__result)
williamr@4
  1824
      __result = __first;
williamr@4
  1825
  return __result;
williamr@4
  1826
}
williamr@4
  1827
williamr@4
  1828
template <class _ForwardIter, class _Compare>
williamr@4
  1829
_ForwardIter min_element(_ForwardIter __first, _ForwardIter __last,
williamr@4
  1830
                         _Compare __comp) {
williamr@4
  1831
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1832
  if (__first == __last) return __first;
williamr@4
  1833
  _ForwardIter __result = __first;
williamr@4
  1834
  while (++__first != __last) {
williamr@4
  1835
    if (__comp(*__first, *__result)) {
williamr@4
  1836
      _STLP_VERBOSE_ASSERT(!__comp(*__result, *__first), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1837
      __result = __first;
williamr@4
  1838
    }
williamr@4
  1839
  }
williamr@4
  1840
  return __result;
williamr@4
  1841
}
williamr@4
  1842
williamr@4
  1843
// next_permutation and prev_permutation, with and without an explicitly
williamr@4
  1844
// supplied comparison function.
williamr@4
  1845
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1846
williamr@4
  1847
template <class _BidirectionalIter, class _Compare>
williamr@4
  1848
bool __next_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
williamr@4
  1849
                        _Compare __comp) {
williamr@4
  1850
  _STLP_DEBUG_CHECK(__check_range(__first, __last))
williamr@4
  1851
  if (__first == __last)
williamr@4
  1852
    return false;
williamr@4
  1853
  _BidirectionalIter __i = __first;
williamr@4
  1854
  ++__i;
williamr@4
  1855
  if (__i == __last)
williamr@4
  1856
    return false;
williamr@4
  1857
  __i = __last;
williamr@4
  1858
  --__i;
williamr@4
  1859
williamr@4
  1860
  for(;;) {
williamr@4
  1861
    _BidirectionalIter __ii = __i;
williamr@4
  1862
    --__i;
williamr@4
  1863
    if (__comp(*__i, *__ii)) {
williamr@4
  1864
      _STLP_VERBOSE_ASSERT(!__comp(*__ii, *__i), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1865
      _BidirectionalIter __j = __last;
williamr@4
  1866
      while (!__comp(*__i, *--__j)) {}
williamr@4
  1867
      iter_swap(__i, __j);
williamr@4
  1868
      reverse(__ii, __last);
williamr@4
  1869
      return true;
williamr@4
  1870
    }
williamr@4
  1871
    if (__i == __first) {
williamr@4
  1872
      reverse(__first, __last);
williamr@4
  1873
      return false;
williamr@4
  1874
    }
williamr@4
  1875
  }
williamr@4
  1876
#if defined (_STLP_NEED_UNREACHABLE_RETURN)
williamr@4
  1877
    return false;
williamr@4
  1878
#endif
williamr@4
  1879
}
williamr@4
  1880
williamr@4
  1881
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1882
williamr@4
  1883
template <class _BidirectionalIter>
williamr@4
  1884
bool next_permutation(_BidirectionalIter __first, _BidirectionalIter __last) {
williamr@4
  1885
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1886
  return _STLP_PRIV __next_permutation(__first, __last,
williamr@4
  1887
                                       _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _BidirectionalIter)));
williamr@4
  1888
}
williamr@4
  1889
williamr@4
  1890
template <class _BidirectionalIter, class _Compare>
williamr@4
  1891
bool next_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
williamr@4
  1892
                      _Compare __comp) {
williamr@4
  1893
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1894
  return _STLP_PRIV __next_permutation(__first, __last, __comp);
williamr@4
  1895
}
williamr@4
  1896
williamr@4
  1897
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1898
williamr@4
  1899
template <class _BidirectionalIter, class _Compare>
williamr@4
  1900
bool __prev_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
williamr@4
  1901
                        _Compare __comp) {
williamr@4
  1902
  if (__first == __last)
williamr@4
  1903
    return false;
williamr@4
  1904
  _BidirectionalIter __i = __first;
williamr@4
  1905
  ++__i;
williamr@4
  1906
  if (__i == __last)
williamr@4
  1907
    return false;
williamr@4
  1908
  __i = __last;
williamr@4
  1909
  --__i;
williamr@4
  1910
williamr@4
  1911
  for(;;) {
williamr@4
  1912
    _BidirectionalIter __ii = __i;
williamr@4
  1913
    --__i;
williamr@4
  1914
    if (__comp(*__ii, *__i)) {
williamr@4
  1915
      _STLP_VERBOSE_ASSERT(!__comp(*__i, *__ii), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1916
      _BidirectionalIter __j = __last;
williamr@4
  1917
      while (!__comp(*--__j, *__i)) {}
williamr@4
  1918
      iter_swap(__i, __j);
williamr@4
  1919
      reverse(__ii, __last);
williamr@4
  1920
      return true;
williamr@4
  1921
    }
williamr@4
  1922
    if (__i == __first) {
williamr@4
  1923
      reverse(__first, __last);
williamr@4
  1924
      return false;
williamr@4
  1925
    }
williamr@4
  1926
  }
williamr@4
  1927
#if defined (_STLP_NEED_UNREACHABLE_RETURN)
williamr@4
  1928
    return false;
williamr@4
  1929
#endif
williamr@4
  1930
}
williamr@4
  1931
williamr@4
  1932
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1933
williamr@4
  1934
template <class _BidirectionalIter>
williamr@4
  1935
bool prev_permutation(_BidirectionalIter __first, _BidirectionalIter __last) {
williamr@4
  1936
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1937
  return _STLP_PRIV __prev_permutation(__first, __last,
williamr@4
  1938
                                       _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _BidirectionalIter)));
williamr@4
  1939
}
williamr@4
  1940
williamr@4
  1941
template <class _BidirectionalIter, class _Compare>
williamr@4
  1942
bool prev_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
williamr@4
  1943
                      _Compare __comp) {
williamr@4
  1944
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1945
  return _STLP_PRIV __prev_permutation(__first, __last, __comp);
williamr@4
  1946
}
williamr@4
  1947
williamr@4
  1948
#if !defined (_STLP_NO_EXTENSIONS)
williamr@4
  1949
williamr@4
  1950
// is_heap, a predicate testing whether or not a range is
williamr@4
  1951
// a heap.  This function is an extension, not part of the C++
williamr@4
  1952
// standard.
williamr@4
  1953
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1954
williamr@4
  1955
template <class _RandomAccessIter, class _Distance, class _StrictWeakOrdering>
williamr@4
  1956
bool __is_heap(_RandomAccessIter __first, _StrictWeakOrdering __comp,
williamr@4
  1957
               _Distance __n) {
williamr@4
  1958
  _Distance __parent = 0;
williamr@4
  1959
  for (_Distance __child = 1; __child < __n; ++__child) {
williamr@4
  1960
    if (__comp(__first[__parent], __first[__child])) {
williamr@4
  1961
      _STLP_VERBOSE_ASSERT(!__comp(__first[__child], __first[__parent]), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1962
      return false;
williamr@4
  1963
    }
williamr@4
  1964
    if ((__child & 1) == 0)
williamr@4
  1965
      ++__parent;
williamr@4
  1966
  }
williamr@4
  1967
  return true;
williamr@4
  1968
}
williamr@4
  1969
williamr@4
  1970
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  1971
williamr@4
  1972
template <class _RandomAccessIter>
williamr@4
  1973
bool is_heap(_RandomAccessIter __first, _RandomAccessIter __last) {
williamr@4
  1974
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1975
  return _STLP_PRIV __is_heap(__first, _STLP_PRIV __less(_STLP_VALUE_TYPE(__first, _RandomAccessIter)), __last - __first);
williamr@4
  1976
}
williamr@4
  1977
williamr@4
  1978
template <class _RandomAccessIter, class _StrictWeakOrdering>
williamr@4
  1979
bool is_heap(_RandomAccessIter __first, _RandomAccessIter __last,
williamr@4
  1980
             _StrictWeakOrdering __comp) {
williamr@4
  1981
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
  1982
  return _STLP_PRIV __is_heap(__first, __comp, __last - __first);
williamr@4
  1983
}
williamr@4
  1984
williamr@4
  1985
williamr@4
  1986
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
  1987
williamr@4
  1988
template <class _ForwardIter, class _StrictWeakOrdering>
williamr@4
  1989
bool __is_sorted(_ForwardIter __first, _ForwardIter __last,
williamr@4
  1990
                 _StrictWeakOrdering __comp) {
williamr@4
  1991
  _STLP_DEBUG_CHECK(__check_range(__first, __last))
williamr@4
  1992
  if (__first == __last)
williamr@4
  1993
    return true;
williamr@4
  1994
williamr@4
  1995
  _ForwardIter __next = __first;
williamr@4
  1996
  for (++__next; __next != __last; __first = __next, ++__next) {
williamr@4
  1997
    if (__comp(*__next, *__first)) {
williamr@4
  1998
      _STLP_VERBOSE_ASSERT(!__comp(*__first, *__next), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@4
  1999
      return false;
williamr@4
  2000
    }
williamr@4
  2001
  }
williamr@4
  2002
williamr@4
  2003
  return true;
williamr@4
  2004
}
williamr@4
  2005
williamr@4
  2006
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
  2007
#endif /* _STLP_NO_EXTENSIONS */
williamr@4
  2008
williamr@4
  2009
_STLP_END_NAMESPACE
williamr@4
  2010
williamr@4
  2011
#undef __stl_threshold
williamr@4
  2012
williamr@4
  2013
#endif /* _STLP_ALGO_C */
williamr@4
  2014
// Local Variables:
williamr@4
  2015
// mode:C++
williamr@4
  2016
// End: