mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Add initial iterator support for folding set.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42589 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6ccc2d579e
commit
116c3219df
@ -220,6 +220,8 @@ protected:
|
|||||||
typedef FoldingSetImpl::Node FoldingSetNode;
|
typedef FoldingSetImpl::Node FoldingSetNode;
|
||||||
typedef FoldingSetImpl::NodeID FoldingSetNodeID;
|
typedef FoldingSetImpl::NodeID FoldingSetNodeID;
|
||||||
|
|
||||||
|
template<class T> class FoldingSetIterator;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
/// FoldingSet - This template class is used to instantiate a specialized
|
/// FoldingSet - This template class is used to instantiate a specialized
|
||||||
/// implementation of the folding set to the node class T. T must be a
|
/// implementation of the folding set to the node class T. T must be a
|
||||||
@ -238,6 +240,14 @@ public:
|
|||||||
explicit FoldingSet(unsigned Log2InitSize = 6)
|
explicit FoldingSet(unsigned Log2InitSize = 6)
|
||||||
: FoldingSetImpl(Log2InitSize)
|
: FoldingSetImpl(Log2InitSize)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
typedef FoldingSetIterator<T> iterator;
|
||||||
|
iterator begin() { return iterator(Buckets); }
|
||||||
|
iterator end() { return iterator(Buckets+NumBuckets); }
|
||||||
|
|
||||||
|
typedef FoldingSetIterator<const T> const_iterator;
|
||||||
|
const_iterator begin() const { return const_iterator(Buckets); }
|
||||||
|
const_iterator end() const { return const_iterator(Buckets+NumBuckets); }
|
||||||
|
|
||||||
/// GetOrInsertNode - If there is an existing simple Node exactly
|
/// GetOrInsertNode - If there is an existing simple Node exactly
|
||||||
/// equal to the specified node, return it. Otherwise, insert 'N' and
|
/// equal to the specified node, return it. Otherwise, insert 'N' and
|
||||||
@ -254,6 +264,47 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
/// FoldingSetIteratorImpl - This is the common iterator support shared by all
|
||||||
|
/// folding sets, which knows how to walk the folding set hash table.
|
||||||
|
class FoldingSetIteratorImpl {
|
||||||
|
protected:
|
||||||
|
FoldingSetNode *NodePtr;
|
||||||
|
FoldingSetIteratorImpl(void **Bucket);
|
||||||
|
void advance();
|
||||||
|
|
||||||
|
public:
|
||||||
|
bool operator==(const FoldingSetIteratorImpl &RHS) const {
|
||||||
|
return NodePtr == RHS.NodePtr;
|
||||||
|
}
|
||||||
|
bool operator!=(const FoldingSetIteratorImpl &RHS) const {
|
||||||
|
return NodePtr != RHS.NodePtr;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
class FoldingSetIterator : public FoldingSetIteratorImpl {
|
||||||
|
public:
|
||||||
|
FoldingSetIterator(void **Bucket) : FoldingSetIteratorImpl(Bucket) {}
|
||||||
|
|
||||||
|
T &operator*() const {
|
||||||
|
return *static_cast<T*>(NodePtr);
|
||||||
|
}
|
||||||
|
|
||||||
|
T *operator->() const {
|
||||||
|
return static_cast<T*>(NodePtr);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline FoldingSetIterator& operator++() { // Preincrement
|
||||||
|
advance();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
FoldingSetIterator operator++(int) { // Postincrement
|
||||||
|
FoldingSetIterator tmp = *this; ++*this; return tmp;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
} // End of namespace llvm.
|
} // End of namespace llvm.
|
||||||
|
|
||||||
|
|
||||||
|
@ -151,6 +151,7 @@ static FoldingSetImpl::Node *GetNextPtr(void *NextInBucketPtr) {
|
|||||||
/// testing.
|
/// testing.
|
||||||
static void **GetBucketPtr(void *NextInBucketPtr) {
|
static void **GetBucketPtr(void *NextInBucketPtr) {
|
||||||
intptr_t Ptr = reinterpret_cast<intptr_t>(NextInBucketPtr);
|
intptr_t Ptr = reinterpret_cast<intptr_t>(NextInBucketPtr);
|
||||||
|
assert((Ptr & 1) && "Not a bucket pointer");
|
||||||
return reinterpret_cast<void**>(Ptr & ~intptr_t(1));
|
return reinterpret_cast<void**>(Ptr & ~intptr_t(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -323,3 +324,34 @@ FoldingSetImpl::Node *FoldingSetImpl::GetOrInsertNode(FoldingSetImpl::Node *N) {
|
|||||||
InsertNode(N, IP);
|
InsertNode(N, IP);
|
||||||
return N;
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// FoldingSetIteratorImpl Implementation
|
||||||
|
|
||||||
|
FoldingSetIteratorImpl::FoldingSetIteratorImpl(void **Bucket) {
|
||||||
|
// Skip to the first non-null non-self-cycle bucket.
|
||||||
|
while (*Bucket == 0 || GetNextPtr(*Bucket) == 0)
|
||||||
|
++Bucket;
|
||||||
|
|
||||||
|
NodePtr = static_cast<FoldingSetNode*>(*Bucket);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FoldingSetIteratorImpl::advance() {
|
||||||
|
// If there is another link within this bucket, go to it.
|
||||||
|
void *Probe = NodePtr->getNextInBucket();
|
||||||
|
|
||||||
|
if (FoldingSetNode *NextNodeInBucket = GetNextPtr(Probe))
|
||||||
|
NodePtr = NextNodeInBucket;
|
||||||
|
else {
|
||||||
|
// Otherwise, this is the last link in this bucket.
|
||||||
|
void **Bucket = GetBucketPtr(Probe);
|
||||||
|
|
||||||
|
// Skip to the next non-null non-self-cycle bucket.
|
||||||
|
do {
|
||||||
|
++Bucket;
|
||||||
|
} while (*Bucket == 0 || GetNextPtr(*Bucket) == 0);
|
||||||
|
|
||||||
|
NodePtr = static_cast<FoldingSetNode*>(*Bucket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user