diff options
author | Duncan Sands <baldrick@free.fr> | 2008-09-08 11:05:51 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-09-08 11:05:51 +0000 |
commit | d7b9851c4e634ed3599b1a4c70b1c76c90a11686 (patch) | |
tree | e6d0ee180e8d76901ea2b62013a8aea5966d0b22 /lib/Analysis/IPA/CallGraph.cpp | |
parent | 98d2d07d416b3431a298eec5a2bfe8b39652c3aa (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.cpp | 22 |
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. |