aboutsummaryrefslogtreecommitdiff
path: root/include/cru/common
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-01-12 00:53:13 +0800
committercrupest <crupest@outlook.com>2022-01-12 00:53:13 +0800
commit01f98ce88950cdb729f5db58bf26f2fffa1c326c (patch)
tree43107a45983e2f61bbe64da1ba9a4fe33f0f616b /include/cru/common
parentd5621e5b1becd24edfbd598767b040524f535af9 (diff)
downloadcru-01f98ce88950cdb729f5db58bf26f2fffa1c326c.tar.gz
cru-01f98ce88950cdb729f5db58bf26f2fffa1c326c.tar.bz2
cru-01f98ce88950cdb729f5db58bf26f2fffa1c326c.zip
...
Diffstat (limited to 'include/cru/common')
-rw-r--r--include/cru/common/ClonablePtr.hpp48
-rw-r--r--include/cru/common/Event.hpp1
2 files changed, 30 insertions, 19 deletions
diff --git a/include/cru/common/ClonablePtr.hpp b/include/cru/common/ClonablePtr.hpp
index 5e4b80c9..39b5b454 100644
--- a/include/cru/common/ClonablePtr.hpp
+++ b/include/cru/common/ClonablePtr.hpp
@@ -93,6 +93,18 @@ class ClonablePtr {
element_type& operator*() const noexcept { return *ptr_; }
pointer operator->() const noexcept { return ptr_.get(); }
+ int Compare(const ClonablePtr& other) const noexcept {
+ if (ptr_ == other.ptr_) {
+ return 0;
+ } else if (ptr_ < other.ptr_) {
+ return -1;
+ } else {
+ return 1;
+ }
+ }
+
+ int Compare(nullptr_t) const noexcept { return ptr_ ? 1 : 0; }
+
private:
std::unique_ptr<element_type> ptr_;
};
@@ -104,92 +116,92 @@ void swap(ClonablePtr<T>& left, ClonablePtr<T>& right) noexcept {
template <typename T>
bool operator==(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() == right.get();
+ return left.Compare(right) == 0;
}
template <typename T>
bool operator!=(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() != right.get();
+ return left.Compare(right) != 0;
}
template <typename T>
bool operator<(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() < right.get();
+ return left.Compare(right) < 0;
}
template <typename T>
bool operator<=(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() <= right.get();
+ return left.Compare(right) <= 0;
}
template <typename T>
bool operator>(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() > right.get();
+ return left.Compare(right) > 0;
}
template <typename T>
bool operator>=(const ClonablePtr<T>& left, const ClonablePtr<T>& right) {
- return left.get() >= right.get();
+ return left.Compare(right) >= 0;
}
template <typename T>
bool operator==(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() == nullptr;
+ return left.Compare(nullptr) == 0;
}
template <typename T>
bool operator!=(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() != nullptr;
+ return left.Compare(nullptr) != 0;
}
template <typename T>
bool operator<(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() < nullptr;
+ return left.Compare(nullptr) < 0;
}
template <typename T>
bool operator<=(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() <= nullptr;
+ return left.Compare(nullptr) <= 0;
}
template <typename T>
bool operator>(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() > nullptr;
+ return left.Compare(nullptr) > 0;
}
template <typename T>
bool operator>=(const ClonablePtr<T>& left, std::nullptr_t) {
- return left.get() >= nullptr;
+ return left.Compare(nullptr) >= 0;
}
template <typename T>
bool operator==(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr == right.get();
+ return right.Compare(nullptr) == 0;
}
template <typename T>
bool operator!=(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr != right.get();
+ return right.Compare(nullptr) != 0;
}
template <typename T>
bool operator<(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr < right.get();
+ return right.Compare(nullptr) > 0;
}
template <typename T>
bool operator<=(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr <= right.get();
+ return right.Compare(nullptr) >= 0;
}
template <typename T>
bool operator>(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr > right.get();
+ return right.Compare(nullptr) < 0;
}
template <typename T>
bool operator>=(std::nullptr_t, const ClonablePtr<T>& right) {
- return nullptr >= right.get();
+ return right.Compare(nullptr) <= 0;
}
} // namespace cru
diff --git a/include/cru/common/Event.hpp b/include/cru/common/Event.hpp
index b6999aa4..5d60c5b3 100644
--- a/include/cru/common/Event.hpp
+++ b/include/cru/common/Event.hpp
@@ -8,7 +8,6 @@
#include <initializer_list>
#include <memory>
#include <utility>
-#include <variant>
#include <vector>
namespace cru {