aboutsummaryrefslogtreecommitdiff
path: root/include/openvic-dataloader/detail/PointerHash.hpp
diff options
context:
space:
mode:
author George L. Albany <Megacake1234@gmail.com>2023-09-05 21:38:13 +0200
committer GitHub <noreply@github.com>2023-09-05 21:38:13 +0200
commit870068cf33057348000b1422d4bf40772aaf0b87 (patch)
treef7569029f45ec019b0387e63aa7b94d1da7cc03a /include/openvic-dataloader/detail/PointerHash.hpp
parent238ab9dfaa8ec7a48142154d227605ae367d53d1 (diff)
parent1d2c5ce39d12adcb584d586952a59e15f2495f67 (diff)
Merge pull request #9 from OpenVicProject/node-line-column
Diffstat (limited to 'include/openvic-dataloader/detail/PointerHash.hpp')
-rw-r--r--include/openvic-dataloader/detail/PointerHash.hpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/include/openvic-dataloader/detail/PointerHash.hpp b/include/openvic-dataloader/detail/PointerHash.hpp
new file mode 100644
index 0000000..c0d28bc
--- /dev/null
+++ b/include/openvic-dataloader/detail/PointerHash.hpp
@@ -0,0 +1,23 @@
+#pragma once
+
+#include <cstdint>
+
+namespace ovdl::detail {
+ /* hash any pointer */
+ template<typename T>
+ struct PointerHash {
+ using type = T;
+ using ptr_type = T*;
+ using const_type = const T;
+ using const_ptr_type = const T*;
+ using const_ptr_const_type = const const_ptr_type;
+ constexpr std::size_t operator()(const_ptr_const_type pointer) const {
+ auto addr = reinterpret_cast<uintptr_t>(pointer);
+#if SIZE_MAX < UINTPTR_MAX
+ /* size_t is not large enough to hold the pointer’s memory address */
+ addr %= SIZE_MAX; /* truncate the address so it is small enough to fit in a size_t */
+#endif
+ return addr;
+ }
+ };
+} \ No newline at end of file