aboutsummaryrefslogtreecommitdiff
path: root/lib/Analysis/IPA/CallGraph.cpp
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2008-09-08 11:05:51 +0000
committerDuncan Sands <baldrick@free.fr>2008-09-08 11:05:51 +0000
commitd7b9851c4e634ed3599b1a4c70b1c76c90a11686 (patch)
treee6d0ee180e8d76901ea2b62013a8aea5966d0b22 /lib/Analysis/IPA/CallGraph.cpp
parent98d2d07d416b3431a298eec5a2bfe8b39652c3aa (diff)
Reapply 55859. This doesn't change anything as
long as the callgraph is correct. It checks for wrong callgraphs more strictly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55894 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/IPA/CallGraph.cpp')
-rw-r--r--lib/Analysis/IPA/CallGraph.cpp22
1 files changed, 8 insertions, 14 deletions
diff --git a/lib/Analysis/IPA/CallGraph.cpp b/lib/Analysis/IPA/CallGraph.cpp
index c8f25b07b8..99848c8326 100644
--- a/lib/Analysis/IPA/CallGraph.cpp
+++ b/lib/Analysis/IPA/CallGraph.cpp
@@ -272,26 +272,20 @@ void CallGraphNode::print(std::ostream &OS) const {
else
OS << "Call graph node <<null function: 0x" << this << ">>:\n";
- for (const_iterator I = begin(), E = end(); I != E; ++I)
+ for (const_iterator I = begin(), E = end(); I != E; ++I) {
if (I->second->getFunction())
- OS << " Calls function '" << I->second->getFunction()->getName() <<"'\n";
- else
- OS << " Calls external node\n";
+ OS << " Calls function '" << I->second->getFunction()->getName() << "'";
+ else
+ OS << " Calls external node";
+ if (I->first.getInstruction())
+ OS << " from '" << *I->first.getInstruction() << "'";
+ OS << "\n";
+ }
OS << "\n";
}
void CallGraphNode::dump() const { print(cerr); }
-void CallGraphNode::removeCallEdgeTo(CallGraphNode *Callee) {
- for (unsigned i = CalledFunctions.size(); ; --i) {
- assert(i && "Cannot find callee to remove!");
- if (CalledFunctions[i-1].second == Callee) {
- CalledFunctions.erase(CalledFunctions.begin()+i-1);
- return;
- }
- }
-}
-
/// removeCallEdgeFor - This method removes the edge in the node for the
/// specified call site. Note that this method takes linear time, so it
/// should be used sparingly.