summaryrefslogtreecommitdiff
path: root/src/common/algorithm.h
diff options
context:
space:
mode:
authorGravatar Lioncash2019-10-15 14:47:42 -0400
committerGravatar Lioncash2019-10-15 15:24:50 -0400
commitac4dbd3b25f022b3ef025f6d3451712187308efb (patch)
tree0d2b2fac72afd6c8ae91935ff5c1968590bd2d8a /src/common/algorithm.h
parentMerge pull request #2965 from FernandoS27/fair-core-timing (diff)
downloadyuzu-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.h22
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
10namespace Common {
11
12template <class ForwardIt, class T, class Compare = std::less<>>
13ForwardIt 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