diff options
author | Chris Lattner <sabre@nondot.org> | 2004-09-18 21:34:34 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-09-18 21:34:34 +0000 |
commit | 824a21868b16f9873fe5d239df80eb758ffad206 (patch) | |
tree | 1844a50b85f76f77b085539968c695d767ee4a47 | |
parent | 91e6f5e975af31ef9bac6b5e17d277564388476d (diff) | |
download | bcm5719-llvm-824a21868b16f9873fe5d239df80eb758ffad206.tar.gz bcm5719-llvm-824a21868b16f9873fe5d239df80eb758ffad206.zip |
Add CallGraphNode::removeAnyCallEdgeTo method
llvm-svn: 16398
-rw-r--r-- | llvm/include/llvm/Analysis/CallGraph.h | 5 | ||||
-rw-r--r-- | llvm/lib/Analysis/IPA/CallGraph.cpp | 12 |
2 files changed, 17 insertions, 0 deletions
diff --git a/llvm/include/llvm/Analysis/CallGraph.h b/llvm/include/llvm/Analysis/CallGraph.h index 4b4db6bd608..8f2c3023890 100644 --- a/llvm/include/llvm/Analysis/CallGraph.h +++ b/llvm/include/llvm/Analysis/CallGraph.h @@ -251,6 +251,11 @@ public: /// used sparingly. void removeCallEdgeTo(CallGraphNode *Callee); + /// removeAnyCallEdgeTo - This method removes any call edges from this node to + /// the specified callee function. This takes more time to execute than + /// removeCallEdgeTo, so it should not be used unless necessary. + void removeAnyCallEdgeTo(CallGraphNode *Callee); + private: // Stuff to construct the node, used by CallGraph friend class CallGraph; diff --git a/llvm/lib/Analysis/IPA/CallGraph.cpp b/llvm/lib/Analysis/IPA/CallGraph.cpp index ac926dc59a1..e3a60248895 100644 --- a/llvm/lib/Analysis/IPA/CallGraph.cpp +++ b/llvm/lib/Analysis/IPA/CallGraph.cpp @@ -206,3 +206,15 @@ void CallGraphNode::removeCallEdgeTo(CallGraphNode *Callee) { } } } + +// removeAnyCallEdgeTo - This method removes any call edges from this node to +// the specified callee function. This takes more time to execute than +// removeCallEdgeTo, so it should not be used unless necessary. +void CallGraphNode::removeAnyCallEdgeTo(CallGraphNode *Callee) { + for (std::vector<CallGraphNode*>::iterator I = CalledFunctions.begin(), + E = CalledFunctions.end(); I != E; ++I) + if (*I == Callee) { + CalledFunctions.erase(I); + E = CalledFunctions.end(); + } +} |