summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/CBackend
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-01-13 06:38:18 +0000
committerChris Lattner <sabre@nondot.org>2010-01-13 06:38:18 +0000
commit209aecad0c8693ea11db269e6d0f020c71958a62 (patch)
treed996c9b540cf3a392b5e03579530ae787fb71f36 /llvm/lib/Target/CBackend
parent64eecd2de5c5edd309eb52961a4dbf8fe1b0446a (diff)
downloadbcm5719-llvm-209aecad0c8693ea11db269e6d0f020c71958a62.tar.gz
bcm5719-llvm-209aecad0c8693ea11db269e6d0f020c71958a62.zip
change Mangler::makeNameProper to return its result in a SmallVector
instead of returning it in an std::string. Based on this change: 1. Change TargetLoweringObjectFileCOFF::getCOFFSection to take a StringRef 2. Change a bunch of targets to call makeNameProper with a smallstring, making several of them *much* more efficient. 3. Rewrite Mangler::makeNameProper to not build names and then prepend prefixes, not use temporary std::strings, and to avoid other crimes. llvm-svn: 93298
Diffstat (limited to 'llvm/lib/Target/CBackend')
-rw-r--r--llvm/lib/Target/CBackend/CBackend.cpp20
1 files changed, 15 insertions, 5 deletions
diff --git a/llvm/lib/Target/CBackend/CBackend.cpp b/llvm/lib/Target/CBackend/CBackend.cpp
index ba1a377a92b..914af53c995 100644
--- a/llvm/lib/Target/CBackend/CBackend.cpp
+++ b/llvm/lib/Target/CBackend/CBackend.cpp
@@ -25,6 +25,7 @@
#include "llvm/IntrinsicInst.h"
#include "llvm/InlineAsm.h"
#include "llvm/ADT/StringExtras.h"
+#include "llvm/ADT/SmallString.h"
#include "llvm/ADT/STLExtras.h"
#include "llvm/Analysis/ConstantsScanner.h"
#include "llvm/Analysis/FindUsedTypes.h"
@@ -2207,12 +2208,17 @@ void CWriter::printModuleTypes(const TypeSymbolTable &TST) {
// If there are no type names, exit early.
if (I == End) return;
+ SmallString<128> TempName;
+
// Print out forward declarations for structure types before anything else!
Out << "/* Structure forward decls */\n";
for (; I != End; ++I) {
- std::string Name = "struct l_" + Mang->makeNameProper(I->first);
- Out << Name << ";\n";
- TypeNames.insert(std::make_pair(I->second, Name));
+ const char *Prefix = "struct l_";
+ TempName.append(Prefix, Prefix+strlen(Prefix));
+ Mang->makeNameProper(TempName, I->first);
+ Out << TempName.str() << ";\n";
+ TypeNames.insert(std::make_pair(I->second, TempName.str()));
+ TempName.clear();
}
Out << '\n';
@@ -2221,10 +2227,14 @@ void CWriter::printModuleTypes(const TypeSymbolTable &TST) {
// for struct or opaque types.
Out << "/* Typedefs */\n";
for (I = TST.begin(); I != End; ++I) {
- std::string Name = "l_" + Mang->makeNameProper(I->first);
+ const char *Prefix = "l_";
+ TempName.append(Prefix, Prefix+strlen(Prefix));
+ Mang->makeNameProper(TempName, I->first);
+
Out << "typedef ";
- printType(Out, I->second, false, Name);
+ printType(Out, I->second, false, TempName.str());
Out << ";\n";
+ TempName.clear();
}
Out << '\n';
OpenPOWER on IntegriCloud