[PATCH] D92676: ADT: Add hash_value overload for Optional
Duncan P. N. Exon Smith via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 8 15:25:30 PST 2020
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rGcaab41c08e36: ADT: Add hash_value overload for Optional (authored by dexonsmith).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D92676/new/
https://reviews.llvm.org/D92676
Files:
llvm/include/llvm/ADT/Optional.h
llvm/unittests/ADT/OptionalTest.cpp
Index: llvm/unittests/ADT/OptionalTest.cpp
===================================================================
--- llvm/unittests/ADT/OptionalTest.cpp
+++ llvm/unittests/ADT/OptionalTest.cpp
@@ -599,4 +599,21 @@
EXPECT_NONFATAL_FAILURE(EXPECT_EQ(llvm::None, Comparable::get()), "object");
}
+TEST(OptionalTest, HashValue) {
+ // Check that None, false, and true all hash differently.
+ Optional<bool> B, B0 = false, B1 = true;
+ EXPECT_NE(hash_value(B0), hash_value(B));
+ EXPECT_NE(hash_value(B1), hash_value(B));
+ EXPECT_NE(hash_value(B1), hash_value(B0));
+
+ // Check that None, 0, and 1 all hash differently.
+ Optional<int> I, I0 = 0, I1 = 1;
+ EXPECT_NE(hash_value(I0), hash_value(I));
+ EXPECT_NE(hash_value(I1), hash_value(I));
+ EXPECT_NE(hash_value(I1), hash_value(I0));
+
+ // Check None hash the same way regardless of type.
+ EXPECT_EQ(hash_value(B), hash_value(I));
+}
+
} // end anonymous namespace
Index: llvm/include/llvm/ADT/Optional.h
===================================================================
--- llvm/include/llvm/ADT/Optional.h
+++ llvm/include/llvm/ADT/Optional.h
@@ -15,6 +15,7 @@
#ifndef LLVM_ADT_OPTIONAL_H
#define LLVM_ADT_OPTIONAL_H
+#include "llvm/ADT/Hashing.h"
#include "llvm/ADT/None.h"
#include "llvm/Support/Compiler.h"
#include "llvm/Support/type_traits.h"
@@ -299,6 +300,10 @@
#endif
};
+template <class T> llvm::hash_code hash_value(const Optional<T> &O) {
+ return O ? hash_combine(true, *O) : hash_value(false);
+}
+
template <typename T, typename U>
constexpr bool operator==(const Optional<T> &X, const Optional<U> &Y) {
if (X && Y)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D92676.310373.patch
Type: text/x-patch
Size: 1621 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201208/32e5723a/attachment.bin>
More information about the llvm-commits
mailing list