/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
*/
/********************************************
DISCLAIMER:
This is a wrapper code to mimic the relevant std:: class
Please use it ONLY when porting an existing code e.g. from the original sources
For all new development please use classes from Common::
*********************************************/
#ifndef COMMON_STD_ALGORITHM_H
#define COMMON_STD_ALGORITHM_H
#include "common/algorithm.h"
#include "common/util.h"
namespace Std {
template inline T abs(T x) {
return ABS(x);
}
template inline T min(T a, T b) {
return MIN(a, b);
}
template inline T max(T a, T b) {
return MAX(a, b);
}
template inline T clip(T v, T amin, T amax) {
return CLIP(v, amin, amax);
}
template inline T sqrt(T x) {
return ::sqrt(x);
}
template inline void swap(T &a, T &b) {
SWAP(a, b);
}
template
In fill(In first, In last, const Value &val) {
return Common::fill(first, last, val);
}
template
void sort(T first, T last, StrictWeakOrdering comp) {
Common::sort(first, last, comp);
}
template
void sort(T *first, T *last) {
Common::sort(first, last, Common::Less());
}
template
void sort(T first, T last) {
Common::sort(first, last);
}
template
In find(In first, In last, const T &v) {
return Common::find(first, last, v);
}
template
T unique(T first, T last) {
T pos;
for (pos = first + 1; pos < last; ++pos) {
// Check for duplicate
for (T existingPos = first; existingPos < last; ++existingPos) {
if (*pos == *existingPos) {
// Found a match, so shift values over the duplicate
while (pos < (last - 1)) {
T &prior = pos;
++pos;
prior = pos;
}
--last;
break;
}
}
}
return pos;
}
template
ForwardIt lower_bound(ForwardIt first, ForwardIt last, const T &value) {
for (ForwardIt it = first; it < last; ++it) {
if (*it >= value)
return it;
}
return last;
}
template
ForwardIt upper_bound(ForwardIt first, ForwardIt last, const T &value) {
for (ForwardIt it = first; it < last; ++it) {
if (*it > value)
return it;
}
return last;
}
template
ForwardIt upper_bound(ForwardIt first, ForwardIt last, const T &value, Compare comp) {
for (ForwardIt it = first; it < last; ++it) {
if (comp(value, *it))
return it;
}
return last;
}
template
ForwardIt next(ForwardIt it, int n = 1) {
ForwardIt it2 = it;
while (n > 0) { ++it2; --n; }
while (n < 0) { --it2; ++n; }
return it2;
}
template
BidirIt prev(BidirIt it, int n = 1) {
BidirIt it2 = it;
while (n > 0) { --it2; --n; }
while (n < 0) { ++it2; ++n; }
return it2;
}
} // namespace Std
#endif