From 907423f7db7b9537cc3101398fc981f140fef348 Mon Sep 17 00:00:00 2001 From: Owen Anderson Date: Thu, 6 Mar 2014 01:51:01 +0000 Subject: Fix issues in the NamedMDNode operand iterator, including those pointed out by Chandler in review. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203058 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/IR/Metadata.h | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/include/llvm/IR/Metadata.h b/include/llvm/IR/Metadata.h index 27f7fd935d..9992e5cbde 100644 --- a/include/llvm/IR/Metadata.h +++ b/include/llvm/IR/Metadata.h @@ -208,8 +208,9 @@ class NamedMDNode : public ilist_node { explicit NamedMDNode(const Twine &N); - template - class op_iterator_impl { + template + class op_iterator_impl : + public std::iterator { 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 { 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 &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; } + 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 { 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 op_iterator; + typedef op_iterator_impl 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_op_iterator; + typedef op_iterator_impl 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()); } -- cgit v1.2.3