[llvm] r203058 - Fix issues in the NamedMDNode operand iterator, including those pointed out by
Owen Anderson
resistor at mac.com
Wed Mar 5 17:51:01 PST 2014
Author: resistor
Date: Wed Mar 5 19:51:01 2014
New Revision: 203058
URL: http://llvm.org/viewvc/llvm-project?rev=203058&view=rev
Log:
Fix issues in the NamedMDNode operand iterator, including those pointed out by
Chandler in review.
Modified:
llvm/trunk/include/llvm/IR/Metadata.h
Modified: llvm/trunk/include/llvm/IR/Metadata.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/IR/Metadata.h?rev=203058&r1=203057&r2=203058&view=diff
==============================================================================
--- llvm/trunk/include/llvm/IR/Metadata.h (original)
+++ llvm/trunk/include/llvm/IR/Metadata.h Wed Mar 5 19:51:01 2014
@@ -208,8 +208,9 @@ class NamedMDNode : public ilist_node<Na
explicit NamedMDNode(const Twine &N);
- template<class T>
- class op_iterator_impl {
+ template<class T1, class T2>
+ class op_iterator_impl :
+ public std::iterator<std::random_access_iterator_tag, T2> {
const NamedMDNode *Node;
unsigned Idx;
op_iterator_impl(const NamedMDNode *N, unsigned i) : Node(N), Idx(i) { }
@@ -220,10 +221,11 @@ class NamedMDNode : public ilist_node<Na
op_iterator_impl() : Node(0), Idx(0) { }
op_iterator_impl(const op_iterator_impl &o) : Node(o.Node), Idx(o.Idx) { }
- bool operator==(const op_iterator_impl<T> &o) const { return Idx == o.Idx; }
- bool operator!=(const op_iterator_impl<T> &o) const { return Idx != o.Idx; }
+ bool operator==(const op_iterator_impl &o) const { return Idx == o.Idx; }
+ bool operator!=(const op_iterator_impl &o) const { return Idx != o.Idx; }
op_iterator_impl &operator++() {
- ++Idx; return *this;
+ ++Idx;
+ return *this;
}
op_iterator_impl operator++(int) {
op_iterator_impl tmp(*this);
@@ -231,10 +233,11 @@ class NamedMDNode : public ilist_node<Na
return tmp;
}
op_iterator_impl &operator=(const op_iterator_impl &o) {
+ Node = o.Node;
Idx = o.Idx;
return *this;
}
- T operator*() const { return Node->getOperand(Idx); }
+ T1 operator*() const { return Node->getOperand(Idx); }
};
public:
@@ -273,11 +276,11 @@ public:
// ---------------------------------------------------------------------------
// Operand Iterator interface...
//
- typedef op_iterator_impl<MDNode*> op_iterator;
+ typedef op_iterator_impl<MDNode*, MDNode> op_iterator;
op_iterator op_begin() { return op_iterator(this, 0); }
op_iterator op_end() { return op_iterator(this, getNumOperands()); }
- typedef op_iterator_impl<const MDNode*> const_op_iterator;
+ typedef op_iterator_impl<const MDNode*, MDNode> const_op_iterator;
const_op_iterator op_begin() const { return const_op_iterator(this, 0); }
const_op_iterator op_end() const { return const_op_iterator(this, getNumOperands()); }
More information about the llvm-commits
mailing list