1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-22 18:54:02 +01:00

The count() function for STL datatypes returns unsigned, even where it's

only 1/0 result like std::set. Some of the LLVM ADT already return unsigned
count(), while others still return bool count().

In continuation to r197879, this patch modifies DenseMap, DenseSet, 
ScopedHashTable, ValueMap:: count() to return size_type instead of bool,
1 instead of true and 0 instead of false.

size_type is typedef-ed locally within each class to size_t.

http://reviews.llvm.org/D4018

Reviewed by dblaikie.

llvm-svn: 211350
This commit is contained in:
Yaron Keren 2014-06-20 10:26:56 +00:00
parent 8087ec46e0
commit e1172cbc66
14 changed files with 42 additions and 29 deletions

View File

@ -34,6 +34,7 @@ class BitVector {
unsigned Capacity; // Size of allocated memory in BitWord. unsigned Capacity; // Size of allocated memory in BitWord.
public: public:
typedef size_t size_type;
// Encapsulation of a single bit. // Encapsulation of a single bit.
class reference { class reference {
friend class BitVector; friend class BitVector;
@ -111,10 +112,10 @@ public:
bool empty() const { return Size == 0; } bool empty() const { return Size == 0; }
/// size - Returns the number of bits in this bitvector. /// size - Returns the number of bits in this bitvector.
unsigned size() const { return Size; } size_type size() const { return Size; }
/// count - Returns the number of bits which are set. /// count - Returns the number of bits which are set.
unsigned count() const { size_type count() const {
unsigned NumBits = 0; unsigned NumBits = 0;
for (unsigned i = 0; i < NumBitWords(size()); ++i) for (unsigned i = 0; i < NumBitWords(size()); ++i)
if (sizeof(BitWord) == 4) if (sizeof(BitWord) == 4)

View File

@ -43,6 +43,7 @@ protected:
typedef std::pair<KeyT, ValueT> BucketT; typedef std::pair<KeyT, ValueT> BucketT;
public: public:
typedef size_t size_type;
typedef KeyT key_type; typedef KeyT key_type;
typedef ValueT mapped_type; typedef ValueT mapped_type;
typedef BucketT value_type; typedef BucketT value_type;
@ -70,7 +71,7 @@ public:
unsigned size() const { return getNumEntries(); } unsigned size() const { return getNumEntries(); }
/// Grow the densemap so that it has at least Size buckets. Does not shrink /// Grow the densemap so that it has at least Size buckets. Does not shrink
void resize(size_t Size) { void resize(size_type Size) {
if (Size > getNumBuckets()) if (Size > getNumBuckets())
grow(Size); grow(Size);
} }
@ -99,10 +100,10 @@ public:
setNumTombstones(0); setNumTombstones(0);
} }
/// count - Return true if the specified key is in the map. /// Return 1 if the specified key is in the map, 0 otherwise.
bool count(const KeyT &Val) const { size_type count(const KeyT &Val) const {
const BucketT *TheBucket; const BucketT *TheBucket;
return LookupBucketFor(Val, TheBucket); return LookupBucketFor(Val, TheBucket) ? 1 : 0;
} }
iterator find(const KeyT &Val) { iterator find(const KeyT &Val) {

View File

@ -29,11 +29,12 @@ class DenseSet {
public: public:
typedef ValueT key_type; typedef ValueT key_type;
typedef ValueT value_type; typedef ValueT value_type;
typedef size_t size_type;
explicit DenseSet(unsigned NumInitBuckets = 0) : TheMap(NumInitBuckets) {} explicit DenseSet(unsigned NumInitBuckets = 0) : TheMap(NumInitBuckets) {}
bool empty() const { return TheMap.empty(); } bool empty() const { return TheMap.empty(); }
unsigned size() const { return TheMap.size(); } size_type size() const { return TheMap.size(); }
size_t getMemorySize() const { return TheMap.getMemorySize(); } size_t getMemorySize() const { return TheMap.getMemorySize(); }
/// Grow the DenseSet so that it has at least Size buckets. Will not shrink /// Grow the DenseSet so that it has at least Size buckets. Will not shrink
@ -44,7 +45,8 @@ public:
TheMap.clear(); TheMap.clear();
} }
bool count(const ValueT &V) const { /// Return 1 if the specified key is in the set, 0 otherwise.
size_type count(const ValueT &V) const {
return TheMap.count(V); return TheMap.count(V);
} }

View File

@ -29,7 +29,7 @@ template<typename KeyT, typename ValueT,
typename MapType = llvm::DenseMap<KeyT, unsigned>, typename MapType = llvm::DenseMap<KeyT, unsigned>,
typename VectorType = std::vector<std::pair<KeyT, ValueT> > > typename VectorType = std::vector<std::pair<KeyT, ValueT> > >
class MapVector { class MapVector {
typedef typename VectorType::size_type SizeType; typedef typename VectorType::size_type size_type;
MapType Map; MapType Map;
VectorType Vector; VectorType Vector;
@ -38,7 +38,7 @@ public:
typedef typename VectorType::iterator iterator; typedef typename VectorType::iterator iterator;
typedef typename VectorType::const_iterator const_iterator; typedef typename VectorType::const_iterator const_iterator;
SizeType size() const { size_type size() const {
return Vector.size(); return Vector.size();
} }
@ -100,7 +100,7 @@ public:
return std::make_pair(begin() + I, false); return std::make_pair(begin() + I, false);
} }
unsigned count(const KeyT &Key) const { size_type count(const KeyT &Key) const {
typename MapType::const_iterator Pos = Map.find(Key); typename MapType::const_iterator Pos = Map.find(Key);
return Pos == Map.end()? 0 : 1; return Pos == Map.end()? 0 : 1;
} }

View File

@ -148,6 +148,7 @@ public:
/// ScopeTy - This is a helpful typedef that allows clients to get easy access /// ScopeTy - This is a helpful typedef that allows clients to get easy access
/// to the name of the scope for this hash table. /// to the name of the scope for this hash table.
typedef ScopedHashTableScope<K, V, KInfo, AllocatorTy> ScopeTy; typedef ScopedHashTableScope<K, V, KInfo, AllocatorTy> ScopeTy;
typedef size_t size_type;
private: private:
typedef ScopedHashTableVal<K, V> ValTy; typedef ScopedHashTableVal<K, V> ValTy;
DenseMap<K, ValTy*, KInfo> TopLevelMap; DenseMap<K, ValTy*, KInfo> TopLevelMap;
@ -170,7 +171,8 @@ public:
AllocatorTy &getAllocator() { return Allocator; } AllocatorTy &getAllocator() { return Allocator; }
const AllocatorTy &getAllocator() const { return Allocator; } const AllocatorTy &getAllocator() const { return Allocator; }
bool count(const K &Key) const { /// Return 1 if the specified key is in the table, 0 otherwise.
size_type count(const K &Key) const {
return TopLevelMap.count(Key); return TopLevelMap.count(Key);
} }

View File

@ -54,6 +54,7 @@ class SmallBitVector {
}; };
public: public:
typedef size_t size_type;
// Encapsulation of a single bit. // Encapsulation of a single bit.
class reference { class reference {
SmallBitVector &TheVector; SmallBitVector &TheVector;
@ -168,12 +169,12 @@ public:
} }
/// size - Returns the number of bits in this bitvector. /// size - Returns the number of bits in this bitvector.
size_t size() const { size_type size() const {
return isSmall() ? getSmallSize() : getPointer()->size(); return isSmall() ? getSmallSize() : getPointer()->size();
} }
/// count - Returns the number of bits which are set. /// count - Returns the number of bits which are set.
unsigned count() const { size_type count() const {
if (isSmall()) { if (isSmall()) {
uintptr_t Bits = getSmallBits(); uintptr_t Bits = getSmallBits();
if (NumBaseBits == 32) if (NumBaseBits == 32)

View File

@ -73,8 +73,9 @@ protected:
~SmallPtrSetImplBase(); ~SmallPtrSetImplBase();
public: public:
typedef size_t size_type;
bool LLVM_ATTRIBUTE_UNUSED_RESULT empty() const { return size() == 0; } bool LLVM_ATTRIBUTE_UNUSED_RESULT empty() const { return size() == 0; }
unsigned size() const { return NumElements; } size_type size() const { return NumElements; }
void clear() { void clear() {
// If the capacity of the array is huge, and the # elements used is small, // If the capacity of the array is huge, and the # elements used is small,
@ -263,7 +264,7 @@ public:
} }
/// count - Return 1 if the specified pointer is in the set, 0 otherwise. /// count - Return 1 if the specified pointer is in the set, 0 otherwise.
unsigned count(PtrType Ptr) const { size_type count(PtrType Ptr) const {
return count_imp(PtrTraits::getAsVoidPointer(Ptr)) ? 1 : 0; return count_imp(PtrTraits::getAsVoidPointer(Ptr)) ? 1 : 0;
} }

View File

@ -37,18 +37,19 @@ class SmallSet {
typedef typename SmallVector<T, N>::const_iterator VIterator; typedef typename SmallVector<T, N>::const_iterator VIterator;
typedef typename SmallVector<T, N>::iterator mutable_iterator; typedef typename SmallVector<T, N>::iterator mutable_iterator;
public: public:
typedef size_t size_type;
SmallSet() {} SmallSet() {}
bool LLVM_ATTRIBUTE_UNUSED_RESULT empty() const { bool LLVM_ATTRIBUTE_UNUSED_RESULT empty() const {
return Vector.empty() && Set.empty(); return Vector.empty() && Set.empty();
} }
unsigned size() const { size_type size() const {
return isSmall() ? Vector.size() : Set.size(); return isSmall() ? Vector.size() : Set.size();
} }
/// count - Return 1 if the element is in the set, 0 otherwise. /// count - Return 1 if the element is in the set, 0 otherwise.
unsigned count(const T &V) const { size_type count(const T &V) const {
if (isSmall()) { if (isSmall()) {
// Since the collection is small, just do a linear search. // Since the collection is small, just do a linear search.
return vfind(V) == Vector.end() ? 0 : 1; return vfind(V) == Vector.end() ? 0 : 1;

View File

@ -45,6 +45,7 @@ struct SparseBitVectorElement
: public ilist_node<SparseBitVectorElement<ElementSize> > { : public ilist_node<SparseBitVectorElement<ElementSize> > {
public: public:
typedef unsigned long BitWord; typedef unsigned long BitWord;
typedef size_t size_type;
enum { enum {
BITWORD_SIZE = sizeof(BitWord) * CHAR_BIT, BITWORD_SIZE = sizeof(BitWord) * CHAR_BIT,
BITWORDS_PER_ELEMENT = (ElementSize + BITWORD_SIZE - 1) / BITWORD_SIZE, BITWORDS_PER_ELEMENT = (ElementSize + BITWORD_SIZE - 1) / BITWORD_SIZE,
@ -120,7 +121,7 @@ public:
return Bits[Idx / BITWORD_SIZE] & (1L << (Idx % BITWORD_SIZE)); return Bits[Idx / BITWORD_SIZE] & (1L << (Idx % BITWORD_SIZE));
} }
unsigned count() const { size_type count() const {
unsigned NumBits = 0; unsigned NumBits = 0;
for (unsigned i = 0; i < BITWORDS_PER_ELEMENT; ++i) for (unsigned i = 0; i < BITWORDS_PER_ELEMENT; ++i)
if (sizeof(BitWord) == 4) if (sizeof(BitWord) == 4)

View File

@ -185,6 +185,7 @@ public:
typedef const ValueT &const_reference; typedef const ValueT &const_reference;
typedef ValueT *pointer; typedef ValueT *pointer;
typedef const ValueT *const_pointer; typedef const ValueT *const_pointer;
typedef size_t size_type;
SparseMultiSet() SparseMultiSet()
: Sparse(nullptr), Universe(0), FreelistIdx(SMSNode::INVALID), NumFree(0) {} : Sparse(nullptr), Universe(0), FreelistIdx(SMSNode::INVALID), NumFree(0) {}
@ -327,7 +328,7 @@ public:
/// This is not the same as BitVector::size() which returns the size of the /// This is not the same as BitVector::size() which returns the size of the
/// universe. /// universe.
/// ///
unsigned size() const { size_type size() const {
assert(NumFree <= Dense.size() && "Out-of-bounds free entries"); assert(NumFree <= Dense.size() && "Out-of-bounds free entries");
return Dense.size() - NumFree; return Dense.size() - NumFree;
} }
@ -378,7 +379,7 @@ public:
/// Returns the number of elements identified by Key. This will be linear in /// Returns the number of elements identified by Key. This will be linear in
/// the number of elements of that key. /// the number of elements of that key.
unsigned count(const KeyT &Key) const { size_type count(const KeyT &Key) const {
unsigned Ret = 0; unsigned Ret = 0;
for (const_iterator It = find(Key); It != end(); ++It) for (const_iterator It = find(Key); It != end(); ++It)
++Ret; ++Ret;

View File

@ -124,6 +124,7 @@ class SparseSet {
typedef typename KeyFunctorT::argument_type KeyT; typedef typename KeyFunctorT::argument_type KeyT;
typedef SmallVector<ValueT, 8> DenseT; typedef SmallVector<ValueT, 8> DenseT;
typedef size_t size_type;
DenseT Dense; DenseT Dense;
SparseT *Sparse; SparseT *Sparse;
unsigned Universe; unsigned Universe;
@ -186,7 +187,7 @@ public:
/// This is not the same as BitVector::size() which returns the size of the /// This is not the same as BitVector::size() which returns the size of the
/// universe. /// universe.
/// ///
unsigned size() const { return Dense.size(); } size_type size() const { return Dense.size(); }
/// clear - Clears the set. This is a very fast constant time operation. /// clear - Clears the set. This is a very fast constant time operation.
/// ///
@ -231,7 +232,7 @@ public:
/// count - Returns 1 if this set contains an element identified by Key, /// count - Returns 1 if this set contains an element identified by Key,
/// 0 otherwise. /// 0 otherwise.
/// ///
unsigned count(const KeyT &Key) const { size_type count(const KeyT &Key) const {
return find(Key) == end() ? 0 : 1; return find(Key) == end() ? 0 : 1;
} }

View File

@ -87,6 +87,7 @@ public:
typedef KeyT key_type; typedef KeyT key_type;
typedef ValueT mapped_type; typedef ValueT mapped_type;
typedef std::pair<KeyT, ValueT> value_type; typedef std::pair<KeyT, ValueT> value_type;
typedef size_t size_type;
explicit ValueMap(unsigned NumInitBuckets = 64) explicit ValueMap(unsigned NumInitBuckets = 64)
: Map(NumInitBuckets), Data() {} : Map(NumInitBuckets), Data() {}
@ -103,16 +104,16 @@ public:
inline const_iterator end() const { return const_iterator(Map.end()); } inline const_iterator end() const { return const_iterator(Map.end()); }
bool empty() const { return Map.empty(); } bool empty() const { return Map.empty(); }
unsigned size() const { return Map.size(); } size_type size() const { return Map.size(); }
/// Grow the map so that it has at least Size buckets. Does not shrink /// Grow the map so that it has at least Size buckets. Does not shrink
void resize(size_t Size) { Map.resize(Size); } void resize(size_t Size) { Map.resize(Size); }
void clear() { Map.clear(); } void clear() { Map.clear(); }
/// count - Return true if the specified key is in the map. /// Return 1 if the specified key is in the map, 0 otherwise.
bool count(const KeyT &Val) const { size_type count(const KeyT &Val) const {
return Map.find_as(Val) != Map.end(); return Map.find_as(Val) == Map.end() ? 0 : 1;
} }
iterator find(const KeyT &Val) { iterator find(const KeyT &Val) {

View File

@ -308,7 +308,7 @@ void WinCodeViewLineTables::endFunction(const MachineFunction *MF) {
return; return;
const Function *GV = MF->getFunction(); const Function *GV = MF->getFunction();
assert(FnDebugInfo.count(GV) == true); assert(FnDebugInfo.count(GV));
assert(CurFn == &FnDebugInfo[GV]); assert(CurFn == &FnDebugInfo[GV]);
if (CurFn->Instrs.empty()) { if (CurFn->Instrs.empty()) {

View File

@ -663,7 +663,7 @@ void Instruction::setMetadata(unsigned KindID, MDNode *Node) {
// Otherwise, we're removing metadata from an instruction. // Otherwise, we're removing metadata from an instruction.
assert((hasMetadataHashEntry() == assert((hasMetadataHashEntry() ==
getContext().pImpl->MetadataStore.count(this)) && (getContext().pImpl->MetadataStore.count(this) > 0)) &&
"HasMetadata bit out of date!"); "HasMetadata bit out of date!");
if (!hasMetadataHashEntry()) if (!hasMetadataHashEntry())
return; // Nothing to remove! return; // Nothing to remove!