From f7bd6392906a8edb31a802c835b074e5cbdce774 Mon Sep 17 00:00:00 2001
From: Chris Lattner <sabre@nondot.org>
Date: Fri, 7 Sep 2001 16:20:18 +0000
Subject: [PATCH] * Support new setName interface * Make the iterator a little
 nicer

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@422 91177308-0d34-0410-b5e6-96231b3b80d8
---
 include/llvm/Function.h | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/include/llvm/Function.h b/include/llvm/Function.h
index 59849c637a5..b1d38dda4f9 100644
--- a/include/llvm/Function.h
+++ b/include/llvm/Function.h
@@ -48,7 +48,7 @@ public:
   ~Method();
 
   // Specialize setName to handle symbol table majik...
-  virtual void setName(const string &name);
+  virtual void setName(const string &name, SymbolTable *ST = 0);
 
   const Type *getReturnType() const;
   const MethodType *getMethodType() const;
@@ -146,7 +146,7 @@ public:
     inline BIty  &getInstructionIterator() { return BI; }
 
     inline IIty operator*()  const { return *BI; }
-    inline IIty *operator->() const { return &(operator*()); }
+    inline IIty operator->() const { return operator*(); }
 
     inline bool operator==(const InstIterator &y) const { 
       return BB == y.BB && (BI == y.BI || BB == BBs.end());
@@ -163,7 +163,7 @@ public:
       // The only way that the II could be broken is if it is now pointing to
       // the end() of the current BasicBlock and there are successor BBs.
       while (BI == (*BB)->end()) {
-	++BB; 
+	++BB;
 	if (BB == BBs.end()) break;
 	BI = (*BB)->begin();
       }
@@ -189,6 +189,8 @@ public:
     inline InstIterator  operator--(int) { 
       InstIterator tmp = *this; --*this; return tmp; 
     }
+
+    inline bool atEnd() const { return BB == BBs.end(); }
   };
 
   inline inst_iterator inst_begin() { return inst_iterator(*this); }