We really want to hash pairs of directly-hashable data as directly
authorChandler Carruth <chandlerc@gmail.com>
Fri, 2 Mar 2012 09:26:36 +0000 (09:26 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Fri, 2 Mar 2012 09:26:36 +0000 (09:26 +0000)
commit4d628e200f7133e353c38806b57a229ef6ad2ab4
tree9cb8db0b305fbf1266adc7327b1a35ec1278eec3
parentc7384cfc7addb5d2818ac0bb4492778f28183c49
We really want to hash pairs of directly-hashable data as directly
hashable data. This matters when we have pair<T*, U*> as a key, which is
quite common in DenseMap, etc. To that end, we need to detect when this
is safe. The requirements on a generic std::pair<T, U> are:

1) Both T and U must satisfy the existing is_hashable_data trait. Note
   that this includes the requirement that T and U have no internal
   padding bits or other bits not contributing directly to equality.
2) The alignment constraints of std::pair<T, U> do not require padding
   between consecutive objects.
3) The alignment constraints of U and the size of T do not conspire to
   require padding between the first and second elements.

Grow two somewhat magical traits to detect this by forming a pod
structure and inspecting offset artifacts on it. Hopefully this won't
cause any compilers to panic.

Added and adjusted tests now that pairs, even nested pairs, are treated
as just sequences of data.

Thanks to Jeffrey Yasskin for helping me sort through this and reviewing
the somewhat subtle traits.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@151883 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/ADT/Hashing.h
include/llvm/Support/type_traits.h
unittests/ADT/HashingTest.cpp