diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-10-17 18:13:02 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-10-17 18:13:02 +0000 |
commit | 1c0761d6e90bff86e4f5807017954be2debd6214 (patch) | |
tree | 50aa2a7bc0676de83351f6c6702e4c091b9b9a22 /clang/lib/Basic/IdentifierTable.cpp | |
parent | acb5a4b57c25659b53a6f553b7fa8590d2043f13 (diff) | |
download | bcm5719-llvm-1c0761d6e90bff86e4f5807017954be2debd6214.tar.gz bcm5719-llvm-1c0761d6e90bff86e4f5807017954be2debd6214.zip |
Avoid std::string thrashing in MultiKeywordSelector::getName(), and simplify.
llvm-svn: 84343
Diffstat (limited to 'clang/lib/Basic/IdentifierTable.cpp')
-rw-r--r-- | clang/lib/Basic/IdentifierTable.cpp | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/clang/lib/Basic/IdentifierTable.cpp b/clang/lib/Basic/IdentifierTable.cpp index 93c260fdbe1..a3c5c4a408d 100644 --- a/clang/lib/Basic/IdentifierTable.cpp +++ b/clang/lib/Basic/IdentifierTable.cpp @@ -16,6 +16,7 @@ #include "clang/Basic/LangOptions.h" #include "llvm/ADT/FoldingSet.h" #include "llvm/ADT/DenseMap.h" +#include "llvm/Support/raw_ostream.h" #include <cstdio> using namespace clang; @@ -153,7 +154,7 @@ tok::PPKeywordKind IdentifierInfo::getPPKeywordID() const { unsigned Len = getLength(); if (Len < 2) return tok::pp_not_keyword; - const char *Name = getName(); + const char *Name = getNameStart(); switch (HASH(Len, Name[0], Name[2])) { default: return tok::pp_not_keyword; CASE( 2, 'i', '\0', if); @@ -301,24 +302,15 @@ IdentifierInfo *Selector::getIdentifierInfoForSlot(unsigned argIndex) const { } std::string MultiKeywordSelector::getName() const { - std::string Result; - unsigned Length = 0; + llvm::SmallString<256> Str; + llvm::raw_svector_ostream OS(Str); for (keyword_iterator I = keyword_begin(), E = keyword_end(); I != E; ++I) { if (*I) - Length += (*I)->getLength(); - ++Length; // : + OS << (*I)->getNameStr(); + OS << ':'; } - Result.reserve(Length); - - for (keyword_iterator I = keyword_begin(), E = keyword_end(); I != E; ++I) { - if (*I) - Result.insert(Result.end(), (*I)->getName(), - (*I)->getName()+(*I)->getLength()); - Result.push_back(':'); - } - - return Result; + return OS.str(); } std::string Selector::getAsString() const { @@ -330,11 +322,12 @@ std::string Selector::getAsString() const { // If the number of arguments is 0 then II is guaranteed to not be null. if (getNumArgs() == 0) - return II->getName(); + return II->getNameStr(); + + if (!II) + return ":"; - std::string Res = II ? II->getName() : ""; - Res += ":"; - return Res; + return II->getNameStr().str() + ":"; } // We have a multiple keyword selector (no embedded flags). |