epoc32/include/stdapis/stlportv5/stl/_algobase.c
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 3 e1b950c65cb4
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@2
     1
/*
williamr@2
     2
 *
williamr@4
     3
 * Portions Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.
williamr@4
     4
 *
williamr@2
     5
 * Copyright (c) 1994
williamr@2
     6
 * Hewlett-Packard Company
williamr@2
     7
 *
williamr@2
     8
 * Copyright (c) 1996,1997
williamr@2
     9
 * Silicon Graphics Computer Systems, Inc.
williamr@2
    10
 *
williamr@2
    11
 * Copyright (c) 1997
williamr@2
    12
 * Moscow Center for SPARC Technology
williamr@2
    13
 *
williamr@4
    14
 * Copyright (c) 1999
williamr@2
    15
 * Boris Fomitchev
williamr@2
    16
 *
williamr@2
    17
 * This material is provided "as is", with absolutely no warranty expressed
williamr@2
    18
 * or implied. Any use is at your own risk.
williamr@2
    19
 *
williamr@4
    20
 * Permission to use or copy this software for any purpose is hereby granted
williamr@2
    21
 * without fee, provided the above notices are retained on all copies.
williamr@2
    22
 * Permission to modify the code and to distribute modified code is granted,
williamr@2
    23
 * provided the above notices are retained, and a notice that the code was
williamr@2
    24
 * modified is included with the above copyright notice.
williamr@2
    25
 *
williamr@2
    26
 */
williamr@2
    27
#ifndef _STLP_ALGOBASE_C
williamr@2
    28
#define _STLP_ALGOBASE_C
williamr@2
    29
williamr@4
    30
#ifndef _STLP_INTERNAL_ALGOBASE_H
williamr@2
    31
#  include <stl/_algobase.h>
williamr@4
    32
#endif
williamr@2
    33
williamr@2
    34
_STLP_BEGIN_NAMESPACE
williamr@2
    35
williamr@2
    36
template <class _InputIter1, class _InputIter2>
williamr@2
    37
bool lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,
williamr@2
    38
                             _InputIter2 __first2, _InputIter2 __last2) {
williamr@4
    39
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
    40
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
    41
  for ( ; __first1 != __last1 && __first2 != __last2
williamr@4
    42
        ; ++__first1, ++__first2) {
williamr@4
    43
    if (*__first1 < *__first2) {
williamr@4
    44
      return true;
williamr@2
    45
    }
williamr@4
    46
    if (*__first2 < *__first1)
williamr@4
    47
      return false;
williamr@4
    48
  }
williamr@2
    49
  return __first1 == __last1 && __first2 != __last2;
williamr@2
    50
}
williamr@2
    51
williamr@2
    52
template <class _InputIter1, class _InputIter2, class _Compare>
williamr@2
    53
bool lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,
williamr@2
    54
                             _InputIter2 __first2, _InputIter2 __last2,
williamr@2
    55
                             _Compare __comp) {
williamr@4
    56
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
    57
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
    58
  for ( ; __first1 != __last1 && __first2 != __last2
williamr@4
    59
        ; ++__first1, ++__first2) {
williamr@4
    60
    if (__comp(*__first1, *__first2)) {
williamr@4
    61
      return true;
williamr@2
    62
    }
williamr@4
    63
    if (__comp(*__first2, *__first1))
williamr@4
    64
      return false;
williamr@4
    65
  }
williamr@2
    66
  return __first1 == __last1 && __first2 != __last2;
williamr@2
    67
}
williamr@2
    68
williamr@4
    69
#if !defined (_STLP_NO_EXTENSIONS)
williamr@4
    70
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@2
    71
williamr@2
    72
template <class _InputIter1, class _InputIter2>
williamr@2
    73
int __lexicographical_compare_3way(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
    74
                                   _InputIter2 __first2, _InputIter2 __last2) {
williamr@2
    75
  while (__first1 != __last1 && __first2 != __last2) {
williamr@4
    76
    if (*__first1 < *__first2) {
williamr@4
    77
      _STLP_VERBOSE_ASSERT(!(*__first2 < *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@2
    78
      return -1;
williamr@4
    79
    }
williamr@2
    80
    if (*__first2 < *__first1)
williamr@2
    81
      return 1;
williamr@2
    82
    ++__first1;
williamr@2
    83
    ++__first2;
williamr@2
    84
  }
williamr@2
    85
  if (__first2 == __last2) {
williamr@2
    86
    return !(__first1 == __last1);
williamr@2
    87
  }
williamr@2
    88
  else {
williamr@2
    89
    return -1;
williamr@2
    90
  }
williamr@2
    91
}
williamr@2
    92
williamr@4
    93
_STLP_MOVE_TO_STD_NAMESPACE
williamr@2
    94
williamr@2
    95
template <class _InputIter1, class _InputIter2>
williamr@2
    96
int lexicographical_compare_3way(_InputIter1 __first1, _InputIter1 __last1,
williamr@4
    97
                                 _InputIter2 __first2, _InputIter2 __last2) {
williamr@4
    98
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
    99
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
   100
  return _STLP_PRIV __lexicographical_compare_3way(__first1, __last1, __first2, __last2);
williamr@2
   101
}
williamr@4
   102
#endif
williamr@4
   103
williamr@4
   104
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@2
   105
williamr@2
   106
template <class _RandomAccessIter, class _Tp>
williamr@2
   107
_STLP_INLINE_LOOP _RandomAccessIter __find(_RandomAccessIter __first, _RandomAccessIter __last,
williamr@2
   108
                                           const _Tp& __val,
williamr@4
   109
                                           const random_access_iterator_tag &) {
williamr@2
   110
  _STLP_DIFFERENCE_TYPE(_RandomAccessIter) __trip_count = (__last - __first) >> 2;
williamr@2
   111
williamr@2
   112
  for ( ; __trip_count > 0 ; --__trip_count) {
williamr@2
   113
    if (*__first == __val) return __first;
williamr@2
   114
    ++__first;
williamr@2
   115
williamr@2
   116
    if (*__first == __val) return __first;
williamr@2
   117
    ++__first;
williamr@2
   118
williamr@2
   119
    if (*__first == __val) return __first;
williamr@2
   120
    ++__first;
williamr@2
   121
williamr@2
   122
    if (*__first == __val) return __first;
williamr@2
   123
    ++__first;
williamr@2
   124
  }
williamr@2
   125
williamr@4
   126
  switch (__last - __first) {
williamr@2
   127
  case 3:
williamr@2
   128
    if (*__first == __val) return __first;
williamr@2
   129
    ++__first;
williamr@2
   130
  case 2:
williamr@2
   131
    if (*__first == __val) return __first;
williamr@2
   132
    ++__first;
williamr@2
   133
  case 1:
williamr@2
   134
    if (*__first == __val) return __first;
williamr@4
   135
    //++__first;
williamr@2
   136
  case 0:
williamr@2
   137
  default:
williamr@2
   138
    return __last;
williamr@2
   139
  }
williamr@2
   140
}
williamr@2
   141
williamr@4
   142
inline char*
williamr@4
   143
__find(char* __first, char* __last, char __val, const random_access_iterator_tag &) {
williamr@4
   144
  void *res =  memchr(__first, __val, __last - __first);
williamr@4
   145
  return res != 0 ? __STATIC_CAST(char*, res) : __last;
williamr@4
   146
}
williamr@4
   147
inline const char*
williamr@4
   148
__find(const char* __first, const char* __last, char __val, const random_access_iterator_tag &) {
williamr@4
   149
  const void *res =  memchr(__first, __val, __last - __first);
williamr@4
   150
  return res != 0 ? __STATIC_CAST(const char*, res) : __last;
williamr@4
   151
}
williamr@4
   152
williamr@2
   153
template <class _RandomAccessIter, class _Predicate>
williamr@2
   154
_STLP_INLINE_LOOP _RandomAccessIter __find_if(_RandomAccessIter __first, _RandomAccessIter __last,
williamr@2
   155
                                              _Predicate __pred,
williamr@4
   156
                                              const random_access_iterator_tag &) {
williamr@2
   157
  _STLP_DIFFERENCE_TYPE(_RandomAccessIter) __trip_count = (__last - __first) >> 2;
williamr@2
   158
williamr@2
   159
  for ( ; __trip_count > 0 ; --__trip_count) {
williamr@2
   160
    if (__pred(*__first)) return __first;
williamr@2
   161
    ++__first;
williamr@2
   162
williamr@2
   163
    if (__pred(*__first)) return __first;
williamr@2
   164
    ++__first;
williamr@2
   165
williamr@2
   166
    if (__pred(*__first)) return __first;
williamr@2
   167
    ++__first;
williamr@2
   168
williamr@2
   169
    if (__pred(*__first)) return __first;
williamr@2
   170
    ++__first;
williamr@2
   171
  }
williamr@2
   172
williamr@2
   173
  switch(__last - __first) {
williamr@2
   174
  case 3:
williamr@2
   175
    if (__pred(*__first)) return __first;
williamr@2
   176
    ++__first;
williamr@2
   177
  case 2:
williamr@2
   178
    if (__pred(*__first)) return __first;
williamr@2
   179
    ++__first;
williamr@2
   180
  case 1:
williamr@2
   181
    if (__pred(*__first)) return __first;
williamr@4
   182
      //++__first;
williamr@2
   183
  case 0:
williamr@2
   184
  default:
williamr@2
   185
    return __last;
williamr@2
   186
  }
williamr@2
   187
}
williamr@2
   188
williamr@2
   189
template <class _InputIter, class _Tp>
williamr@4
   190
_STLP_INLINE_LOOP _InputIter __find(_InputIter __first, _InputIter __last,
williamr@4
   191
                                    const _Tp& __val,
williamr@4
   192
                                    const input_iterator_tag &) {
williamr@4
   193
  while (__first != __last && !(*__first == __val)) ++__first;
williamr@2
   194
  return __first;
williamr@2
   195
}
williamr@2
   196
williamr@2
   197
template <class _InputIter, class _Predicate>
williamr@4
   198
_STLP_INLINE_LOOP _InputIter __find_if(_InputIter __first, _STLP_MPW_EXTRA_CONST _InputIter __last,
williamr@4
   199
                                       _Predicate __pred,
williamr@4
   200
                                       const input_iterator_tag &) {
williamr@2
   201
  while (__first != __last && !__pred(*__first))
williamr@2
   202
    ++__first;
williamr@2
   203
  return __first;
williamr@2
   204
}
williamr@2
   205
williamr@4
   206
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   207
williamr@2
   208
template <class _InputIter, class _Predicate>
williamr@2
   209
_InputIter find_if(_InputIter __first, _InputIter __last,
williamr@2
   210
                   _Predicate __pred) {
williamr@4
   211
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   212
  return _STLP_PRIV __find_if(__first, __last, __pred, _STLP_ITERATOR_CATEGORY(__first, _InputIter));
williamr@2
   213
}
williamr@2
   214
williamr@2
   215
template <class _InputIter, class _Tp>
williamr@4
   216
_InputIter find(_InputIter __first, _InputIter __last, const _Tp& __val) {
williamr@4
   217
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@4
   218
  return _STLP_PRIV __find(__first, __last, __val, _STLP_ITERATOR_CATEGORY(__first, _InputIter));
williamr@2
   219
}
williamr@2
   220
williamr@2
   221
template <class _ForwardIter1, class _ForwardIter2, class _BinaryPred>
williamr@2
   222
_ForwardIter1 search(_ForwardIter1 __first1, _ForwardIter1 __last1,
williamr@2
   223
                     _ForwardIter2 __first2, _ForwardIter2 __last2,
williamr@4
   224
                     _BinaryPred  __pred) {
williamr@4
   225
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
   226
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
   227
  // Test for empty ranges
williamr@4
   228
  if (__first1 == __last1 || __first2 == __last2)
williamr@4
   229
    return __first1;
williamr@2
   230
williamr@2
   231
  // Test for a pattern of length 1.
williamr@4
   232
  _ForwardIter2 __p1(__first2);
williamr@4
   233
williamr@4
   234
  if ( ++__p1 == __last2 ) {
williamr@4
   235
    while (__first1 != __last1 && !__pred(*__first1, *__first2)) {
williamr@2
   236
      ++__first1;
williamr@4
   237
    }
williamr@4
   238
    return __first1;
williamr@2
   239
  }
williamr@4
   240
williamr@2
   241
  // General case.
williamr@2
   242
williamr@4
   243
  for ( ; ; ) { // __first1 != __last1 will be checked below
williamr@4
   244
    while (__first1 != __last1 && !__pred(*__first1, *__first2)) {
williamr@2
   245
      ++__first1;
williamr@2
   246
    }
williamr@4
   247
    if (__first1 == __last1) {
williamr@2
   248
      return __last1;
williamr@4
   249
    }
williamr@4
   250
    _ForwardIter2 __p = __p1;
williamr@4
   251
    _ForwardIter1 __current = __first1;
williamr@2
   252
    if (++__current == __last1) return __last1;
williamr@2
   253
williamr@4
   254
    while (__pred(*__current, *__p)) {
williamr@2
   255
      if (++__p == __last2)
williamr@2
   256
        return __first1;
williamr@2
   257
      if (++__current == __last1)
williamr@2
   258
        return __last1;
williamr@2
   259
    }
williamr@2
   260
williamr@2
   261
    ++__first1;
williamr@2
   262
  }
williamr@2
   263
  return __first1;
williamr@2
   264
}
williamr@2
   265
williamr@4
   266
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   267
williamr@2
   268
// find_first_of, with and without an explicitly supplied comparison function.
williamr@2
   269
template <class _InputIter, class _ForwardIter, class _BinaryPredicate>
williamr@2
   270
_InputIter __find_first_of(_InputIter __first1, _InputIter __last1,
williamr@2
   271
                           _ForwardIter __first2, _ForwardIter __last2,
williamr@2
   272
                           _BinaryPredicate __comp) {
williamr@4
   273
  for ( ; __first1 != __last1; ++__first1) {
williamr@4
   274
    for (_ForwardIter __iter = __first2; __iter != __last2; ++__iter) {
williamr@4
   275
      if (__comp(*__first1, *__iter)) {
williamr@2
   276
        return __first1;
williamr@4
   277
      }
williamr@4
   278
    }
williamr@4
   279
  }
williamr@2
   280
  return __last1;
williamr@2
   281
}
williamr@2
   282
williamr@2
   283
// find_end, with and without an explicitly supplied comparison function.
williamr@2
   284
// Search [first2, last2) as a subsequence in [first1, last1), and return
williamr@2
   285
// the *last* possible match.  Note that find_end for bidirectional iterators
williamr@2
   286
// is much faster than for forward iterators.
williamr@2
   287
williamr@4
   288
// find_end for forward iterators.
williamr@2
   289
template <class _ForwardIter1, class _ForwardIter2,
williamr@2
   290
  class _BinaryPredicate>
williamr@2
   291
_ForwardIter1 __find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
williamr@2
   292
                         _ForwardIter2 __first2, _ForwardIter2 __last2,
williamr@2
   293
                         const forward_iterator_tag &, const forward_iterator_tag &,
williamr@4
   294
                         _BinaryPredicate __comp) {
williamr@2
   295
  if (__first2 == __last2)
williamr@2
   296
    return __last1;
williamr@2
   297
  else {
williamr@2
   298
    _ForwardIter1 __result = __last1;
williamr@4
   299
    for (;;) {
williamr@4
   300
      _ForwardIter1 __new_result = search(__first1, __last1, __first2, __last2, __comp);
williamr@2
   301
      if (__new_result == __last1)
williamr@2
   302
        return __result;
williamr@2
   303
      else {
williamr@2
   304
        __result = __new_result;
williamr@2
   305
        __first1 = __new_result;
williamr@2
   306
        ++__first1;
williamr@2
   307
      }
williamr@2
   308
    }
williamr@2
   309
  }
williamr@2
   310
}
williamr@2
   311
williamr@4
   312
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   313
williamr@2
   314
// find_end for bidirectional iterators.  Requires partial specialization.
williamr@4
   315
#if defined (_STLP_CLASS_PARTIAL_SPECIALIZATION)
williamr@2
   316
williamr@4
   317
#  ifndef _STLP_INTERNAL_ITERATOR_H
williamr@2
   318
_STLP_END_NAMESPACE
williamr@4
   319
#    include <stl/_iterator.h>
williamr@4
   320
_STLP_BEGIN_NAMESPACE
williamr@4
   321
#  endif /*_STLP_INTERNAL_ITERATOR_H*/
williamr@4
   322
williamr@4
   323
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@2
   324
williamr@2
   325
template <class _BidirectionalIter1, class _BidirectionalIter2,
williamr@4
   326
          class _BinaryPredicate>
williamr@2
   327
_BidirectionalIter1
williamr@2
   328
__find_end(_BidirectionalIter1 __first1, _BidirectionalIter1 __last1,
williamr@2
   329
           _BidirectionalIter2 __first2, _BidirectionalIter2 __last2,
williamr@4
   330
           const bidirectional_iterator_tag &, const bidirectional_iterator_tag &,
williamr@4
   331
           _BinaryPredicate __comp) {
williamr@2
   332
  typedef reverse_iterator<_BidirectionalIter1> _RevIter1;
williamr@2
   333
  typedef reverse_iterator<_BidirectionalIter2> _RevIter2;
williamr@2
   334
williamr@2
   335
  _RevIter1 __rlast1(__first1);
williamr@2
   336
  _RevIter2 __rlast2(__first2);
williamr@2
   337
  _RevIter1 __rresult = search(_RevIter1(__last1), __rlast1,
williamr@2
   338
                               _RevIter2(__last2), __rlast2,
williamr@2
   339
                               __comp);
williamr@2
   340
williamr@2
   341
  if (__rresult == __rlast1)
williamr@2
   342
    return __last1;
williamr@2
   343
  else {
williamr@2
   344
    _BidirectionalIter1 __result = __rresult.base();
williamr@2
   345
    advance(__result, -distance(__first2, __last2));
williamr@2
   346
    return __result;
williamr@2
   347
  }
williamr@2
   348
}
williamr@4
   349
williamr@4
   350
_STLP_MOVE_TO_STD_NAMESPACE
williamr@2
   351
#endif /* _STLP_CLASS_PARTIAL_SPECIALIZATION */
williamr@2
   352
williamr@4
   353
template <class _ForwardIter1, class _ForwardIter2,
williamr@4
   354
          class _BinaryPredicate>
williamr@4
   355
_ForwardIter1
williamr@4
   356
find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
williamr@2
   357
         _ForwardIter2 __first2, _ForwardIter2 __last2,
williamr@4
   358
         _BinaryPredicate __comp) {
williamr@4
   359
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@4
   360
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))
williamr@4
   361
  return _STLP_PRIV __find_end(__first1, __last1, __first2, __last2,
williamr@4
   362
#if defined (_STLP_CLASS_PARTIAL_SPECIALIZATION)
williamr@4
   363
                               _STLP_ITERATOR_CATEGORY(__first1, _ForwardIter1),
williamr@4
   364
                               _STLP_ITERATOR_CATEGORY(__first2, _ForwardIter2),
williamr@4
   365
#else
williamr@4
   366
                               forward_iterator_tag(),
williamr@4
   367
                               forward_iterator_tag(),
williamr@4
   368
#endif
williamr@4
   369
                               __comp);
williamr@2
   370
}
williamr@2
   371
williamr@4
   372
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   373
williamr@4
   374
template <class _ForwardIter, class _Tp, class _Compare1, class _Compare2, class _Distance>
williamr@4
   375
_ForwardIter __lower_bound(_ForwardIter __first, _ForwardIter __last, const _Tp& __val,
williamr@4
   376
                           _Compare1 __comp1, _Compare2 __comp2, _Distance*) {
williamr@2
   377
  _Distance __len = distance(__first, __last);
williamr@2
   378
  _Distance __half;
williamr@2
   379
  _ForwardIter __middle;
williamr@2
   380
williamr@2
   381
  while (__len > 0) {
williamr@2
   382
    __half = __len >> 1;
williamr@2
   383
    __middle = __first;
williamr@2
   384
    advance(__middle, __half);
williamr@4
   385
    if (__comp1(*__middle, __val)) {
williamr@4
   386
      _STLP_VERBOSE_ASSERT(!__comp2(__val, *__middle), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)
williamr@2
   387
      __first = __middle;
williamr@2
   388
      ++__first;
williamr@2
   389
      __len = __len - __half - 1;
williamr@2
   390
    }
williamr@2
   391
    else
williamr@2
   392
      __len = __half;
williamr@2
   393
  }
williamr@4
   394
  if (&__comp2) {/* do nothing. to avoid warnings */} 
williamr@2
   395
  return __first;
williamr@2
   396
}
williamr@2
   397
williamr@4
   398
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   399
williamr@2
   400
_STLP_END_NAMESPACE
williamr@2
   401
williamr@2
   402
#endif /* _STLP_ALGOBASE_C */
williamr@2
   403
williamr@2
   404
// Local Variables:
williamr@2
   405
// mode:C++
williamr@2
   406
// End: