diff options
| author | 2019-10-15 14:47:42 -0400 | |
|---|---|---|
| committer | 2019-10-15 15:24:50 -0400 | |
| commit | ac4dbd3b25f022b3ef025f6d3451712187308efb (patch) | |
| tree | 0d2b2fac72afd6c8ae91935ff5c1968590bd2d8a /src/common/algorithm.h | |
| parent | Merge pull request #2965 from FernandoS27/fair-core-timing (diff) | |
| download | yuzu-ac4dbd3b25f022b3ef025f6d3451712187308efb.tar.gz yuzu-ac4dbd3b25f022b3ef025f6d3451712187308efb.tar.xz yuzu-ac4dbd3b25f022b3ef025f6d3451712187308efb.zip | |
common: Rename binary_find.h to algorithm.h
Makes the header more general for other potential algorithms in the
future. While we're at it, include a missing <functional> include to
satisfy the use of std::less.
Diffstat (limited to 'src/common/algorithm.h')
| -rw-r--r-- | src/common/algorithm.h | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/common/algorithm.h b/src/common/algorithm.h new file mode 100644 index 000000000..18e7ece98 --- /dev/null +++ b/src/common/algorithm.h | |||
| @@ -0,0 +1,22 @@ | |||
| 1 | // Copyright 2019 yuzu emulator team | ||
| 2 | // Licensed under GPLv2 or any later version | ||
| 3 | // Refer to the license.txt file included. | ||
| 4 | |||
| 5 | #pragma once | ||
| 6 | |||
| 7 | #include <algorithm> | ||
| 8 | #include <functional> | ||
| 9 | |||
| 10 | namespace Common { | ||
| 11 | |||
| 12 | template <class ForwardIt, class T, class Compare = std::less<>> | ||
| 13 | ForwardIt BinaryFind(ForwardIt first, ForwardIt last, const T& value, Compare comp = {}) { | ||
| 14 | // Note: BOTH type T and the type after ForwardIt is dereferenced | ||
| 15 | // must be implicitly convertible to BOTH Type1 and Type2, used in Compare. | ||
| 16 | // This is stricter than lower_bound requirement (see above) | ||
| 17 | |||
| 18 | first = std::lower_bound(first, last, value, comp); | ||
| 19 | return first != last && !comp(value, *first) ? first : last; | ||
| 20 | } | ||
| 21 | |||
| 22 | } // namespace Common | ||