simplify some code to avoid string thrashing.
llvm-svn: 52837
This commit is contained in:
parent
266f1cc1e4
commit
42e983e5a9
|
@ -156,10 +156,12 @@ Constant *Module::getOrInsertFunction(const std::string &Name,
|
|||
|
||||
// Okay, the function exists. Does it have externally visible linkage?
|
||||
if (F->hasInternalLinkage()) {
|
||||
// Rename the function.
|
||||
F->setName(SymTab.getUniqueName(F->getName()));
|
||||
// Clear the function's name.
|
||||
F->setName("");
|
||||
// Retry, now there won't be a conflict.
|
||||
return getOrInsertFunction(Name, Ty);
|
||||
Constant *NewF = getOrInsertFunction(Name, Ty);
|
||||
F->setName(&Name[0], Name.size());
|
||||
return NewF;
|
||||
}
|
||||
|
||||
// If the function exists but has the wrong type, return a bitcast to the
|
||||
|
|
Loading…
Reference in New Issue