forked from OSchip/llvm-project
Fix spello, add DenseMapInfo specialization for PointerIntPair.
llvm-svn: 60228
This commit is contained in:
parent
06db5255c3
commit
2774a41b96
|
@ -18,6 +18,9 @@
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
struct DenseMapInfo;
|
||||||
|
|
||||||
/// PointerIntPair - This class implements a pair of a pointer and small
|
/// PointerIntPair - This class implements a pair of a pointer and small
|
||||||
/// integer. It is designed to represent this in the space required by one
|
/// integer. It is designed to represent this in the space required by one
|
||||||
/// pointer by bitmangling the integer into the low part of the pointer. This
|
/// pointer by bitmangling the integer into the low part of the pointer. This
|
||||||
|
@ -65,5 +68,24 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Provide specialization of DenseMapInfo for PointerIntPair.
|
||||||
|
template<typename PointerTy, unsigned IntBits, typename IntType>
|
||||||
|
struct DenseMapInfo<PointerIntPair<PointerTy, IntBits, IntType> > {
|
||||||
|
typedef PointerIntPair<PointerTy, IntBits, IntType> Ty;
|
||||||
|
static Ty getEmptyKey() {
|
||||||
|
return Ty(reinterpret_cast<PointerTy>(-1),
|
||||||
|
IntType((1 << IntBits)-1));
|
||||||
|
}
|
||||||
|
static Ty getTombstoneKey() {
|
||||||
|
return Ty(reinterpret_cast<PointerTy>(-2), IntType(0));
|
||||||
|
}
|
||||||
|
static unsigned getHashValue(Ty V) {
|
||||||
|
uintptr_t IV = reinterpret_cast<uintptr_t>(V.getOpaqueValue());
|
||||||
|
return unsigned(IV) ^ unsigned(IV >> 9);
|
||||||
|
}
|
||||||
|
static bool isEqual(const Ty &LHS, const Ty &RHS) { return LHS == RHS; }
|
||||||
|
static bool isPod() { return true; }
|
||||||
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue