Export of internal Abseil changes.
-- f9f068aa8a260dc576398e47b8e4540902e41358 by Derek Mauro <dmauro@google.com>: Fix test string with embedded NUL. Currently parses as octal. PiperOrigin-RevId: 237088193 -- d271ffdd3f450f817f6d30e98ff39d439aaf3a98 by Abseil Team <absl-team@google.com>: Make symbolizer examine any mapping with read+exec permission regardless of 'w' bit. PiperOrigin-RevId: 237056461 -- af315f8306d36a7367a452fd0b58cafdbf20719d by Abseil Team <absl-team@google.com>: Switch comments referencing base:: CondVar and Mutex to absl::. PiperOrigin-RevId: 236917884 -- c624d5d1c0bdb917bff5e651ba40599472f84e0e by Gennadiy Rozental <rogeeff@google.com>: Internal change PiperOrigin-RevId: 236898300 -- 3cdc82429af964846d1152f49148abc61d196a4b by Samuel Benzaquen <sbenza@google.com>: Make the `long double` overload if AbslHashValue a template to avoid invalid conversions with implicit operators. This overload was never meant to capture anything other than `long double` and any current caller to it that wasn't a `long double` is potentially a bug. In particular, any type with an implicit `bool` conversion is calling this overload instead of trying to find a hash<> specialization, thus causing pretty bad hash behavior. PiperOrigin-RevId: 236877073 GitOrigin-RevId: f9f068aa8a260dc576398e47b8e4540902e41358 Change-Id: If9cc008dd814f0ca06ed881f612c06575f1f7137
This commit is contained in:
parent
9fdf5e5b80
commit
febc5ee6a9
70 changed files with 483 additions and 410 deletions
|
@ -275,7 +275,6 @@ struct WrapInTuple {
|
|||
|
||||
TEST(HashValueTest, Strings) {
|
||||
EXPECT_TRUE((is_hashable<std::string>::value));
|
||||
EXPECT_TRUE((is_hashable<std::string>::value));
|
||||
|
||||
const std::string small = "foo";
|
||||
const std::string dup = "foofoo";
|
||||
|
@ -705,7 +704,8 @@ TEST(HashTest, HashNonUniquelyRepresentedType) {
|
|||
}
|
||||
|
||||
TEST(HashTest, StandardHashContainerUsage) {
|
||||
std::unordered_map<int, std::string, Hash<int>> map = {{0, "foo"}, { 42, "bar" }};
|
||||
std::unordered_map<int, std::string, Hash<int>> map = {{0, "foo"},
|
||||
{42, "bar"}};
|
||||
|
||||
EXPECT_NE(map.find(0), map.end());
|
||||
EXPECT_EQ(map.find(1), map.end());
|
||||
|
@ -775,4 +775,24 @@ TEST(HashTest, TypeErased) {
|
|||
SpyHash(std::make_pair(size_t{7}, 17)));
|
||||
}
|
||||
|
||||
struct ValueWithBoolConversion {
|
||||
operator bool() const { return false; }
|
||||
int i;
|
||||
};
|
||||
|
||||
} // namespace
|
||||
namespace std {
|
||||
template <>
|
||||
struct hash<ValueWithBoolConversion> {
|
||||
size_t operator()(ValueWithBoolConversion v) { return v.i; }
|
||||
};
|
||||
} // namespace std
|
||||
|
||||
namespace {
|
||||
|
||||
TEST(HashTest, DoesNotUseImplicitConversionsToBool) {
|
||||
EXPECT_NE(absl::Hash<ValueWithBoolConversion>()(ValueWithBoolConversion{0}),
|
||||
absl::Hash<ValueWithBoolConversion>()(ValueWithBoolConversion{1}));
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue