From 72e61b85017286418ca5266c2ff7b88782e2fe00 Mon Sep 17 00:00:00 2001 From: Owen Anderson Date: Tue, 1 Jul 2008 23:49:59 +0000 Subject: [PATCH] Add a version of AddString that takes a const char* so we can avoid extraneous conversions to std::string. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52995 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/ADT/FoldingSet.h | 1 + lib/Support/FoldingSet.cpp | 38 +++++++++++++++++++++++++++++++++++ 2 files changed, 39 insertions(+) diff --git a/include/llvm/ADT/FoldingSet.h b/include/llvm/ADT/FoldingSet.h index 5f541aeaa4f..cce1eec1848 100644 --- a/include/llvm/ADT/FoldingSet.h +++ b/include/llvm/ADT/FoldingSet.h @@ -220,6 +220,7 @@ public: void AddFloat(float F); void AddDouble(double D); void AddString(const std::string &String); + void AddString(const char* String); template inline void Add(const T& x) { FoldingSetTrait::Profile(x, *this); } diff --git a/lib/Support/FoldingSet.cpp b/lib/Support/FoldingSet.cpp index 80140438714..5f1de4a657f 100644 --- a/lib/Support/FoldingSet.cpp +++ b/lib/Support/FoldingSet.cpp @@ -57,6 +57,44 @@ void FoldingSetNodeID::AddFloat(float F) { void FoldingSetNodeID::AddDouble(double D) { AddInteger(DoubleToBits(D)); } + +void FoldingSetNodeID::AddString(const char *String) { + unsigned Size = static_cast(strlen(String)); + Bits.push_back(Size); + if (!Size) return; + + unsigned Units = Size / 4; + unsigned Pos = 0; + const unsigned *Base = (const unsigned *)String; + + // If the string is aligned do a bulk transfer. + if (!((intptr_t)Base & 3)) { + Bits.append(Base, Base + Units); + Pos = (Units + 1) * 4; + } else { + // Otherwise do it the hard way. + for ( Pos += 4; Pos <= Size; Pos += 4) { + unsigned V = ((unsigned char)String[Pos - 4] << 24) | + ((unsigned char)String[Pos - 3] << 16) | + ((unsigned char)String[Pos - 2] << 8) | + (unsigned char)String[Pos - 1]; + Bits.push_back(V); + } + } + + // With the leftover bits. + unsigned V = 0; + // Pos will have overshot size by 4 - #bytes left over. + switch (Pos - Size) { + case 1: V = (V << 8) | (unsigned char)String[Size - 3]; // Fall thru. + case 2: V = (V << 8) | (unsigned char)String[Size - 2]; // Fall thru. + case 3: V = (V << 8) | (unsigned char)String[Size - 1]; break; + default: return; // Nothing left. + } + + Bits.push_back(V); +} + void FoldingSetNodeID::AddString(const std::string &String) { unsigned Size = static_cast(String.size()); Bits.push_back(Size); -- 2.34.1