/* 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