diff --git a/include/llvm/ADT/SmallString.h b/include/llvm/ADT/SmallString.h index 740a0a5cd84..e569f54481a 100644 --- a/include/llvm/ADT/SmallString.h +++ b/include/llvm/ADT/SmallString.h @@ -28,18 +28,30 @@ public: SmallString() {} /// Initialize from a StringRef. - /*implicit*/ SmallString(StringRef S) : SmallVector(S.begin(), S.end()) {} + SmallString(StringRef S) : SmallVector(S.begin(), S.end()) {} /// Initialize with a range. template SmallString(ItTy S, ItTy E) : SmallVector(S, E) {} + // Note that in order to add new overloads for append & assign, we have to + // duplicate the inherited versions so as not to inadvertently hide them. + /// @} /// @name String Assignment /// @{ - // Provide assign from SmallVectorImpl - using SmallVectorImpl::assign; + /// Assign from a repeated element. + void assign(size_t NumElts, char Elt) { + this->SmallVectorImpl::assign(NumElts, Elt); + } + + /// Assign from an iterator pair. + template + void assign(in_iter S, in_iter E) { + this->clear(); + SmallVectorImpl::append(S, E); + } /// Assign from a StringRef. void assign(StringRef RHS) { @@ -53,7 +65,20 @@ public: SmallVectorImpl::append(RHS.begin(), RHS.end()); } - using SmallVectorImpl::append; + /// @} + /// @name String Concatenation + /// @{ + + /// Append from an iterator pair. + template + void append(in_iter S, in_iter E) { + SmallVectorImpl::append(S, E); + } + + void append(size_t NumInputs, char Elt) { + SmallVectorImpl::append(NumInputs, Elt); + } + /// Append from a StringRef. void append(StringRef RHS) { @@ -69,6 +94,12 @@ public: /// @name String Comparison /// @{ + /// Check for string equality. This is more efficient than compare() when + /// the relative ordering of inequal strings isn't needed. + bool equals(StringRef RHS) const { + return str().equals(RHS); + } + /// Check for string equality, ignoring case. bool equals_lower(StringRef RHS) const { return str().equals_lower(RHS); @@ -245,9 +276,6 @@ public: /// Implicit conversion to StringRef. operator StringRef() const { return str(); } - // Provide op= for SmallVectorImpl - using SmallVectorImpl::operator=; - // Extra operators. const SmallString &operator=(StringRef RHS) { this->clear(); @@ -255,15 +283,9 @@ public: } SmallString &operator+=(StringRef RHS) { - append(RHS.begin(), RHS.end()); + this->append(RHS.begin(), RHS.end()); return *this; } - - SmallString &operator+=(const SmallVectorImpl &RHS) { - append(RHS.begin(), RHS.end()); - return *this; - } - SmallString &operator+=(char C) { this->push_back(C); return *this; diff --git a/include/llvm/ADT/SmallVector.h b/include/llvm/ADT/SmallVector.h index e5e53d1dd65..2a5168c261f 100644 --- a/include/llvm/ADT/SmallVector.h +++ b/include/llvm/ADT/SmallVector.h @@ -451,12 +451,10 @@ public: void assign(unsigned NumElts, const T &Elt) { clear(); - append(NumElts, Elt); - } - - template void assign(in_iter S, in_iter E) { - clear(); - append(S, E); + if (this->capacity() < NumElts) + this->grow(NumElts); + this->setEnd(this->begin()+NumElts); + std::uninitialized_fill(this->begin(), this->end(), Elt); } iterator erase(iterator I) { diff --git a/include/llvm/DebugInfo/DIContext.h b/include/llvm/DebugInfo/DIContext.h index c20f1ea4505..f04dc001f4b 100644 --- a/include/llvm/DebugInfo/DIContext.h +++ b/include/llvm/DebugInfo/DIContext.h @@ -50,7 +50,8 @@ public: bool operator==(const DILineInfo &RHS) const { return Line == RHS.Line && Column == RHS.Column && - FileName == RHS.FileName && FunctionName == RHS.FunctionName; + FileName.equals(RHS.FileName) && + FunctionName.equals(RHS.FunctionName); } bool operator!=(const DILineInfo &RHS) const { return !(*this == RHS); diff --git a/unittests/ADT/SmallStringTest.cpp b/unittests/ADT/SmallStringTest.cpp index ff04f5bd57f..9398e99c911 100644 --- a/unittests/ADT/SmallStringTest.cpp +++ b/unittests/ADT/SmallStringTest.cpp @@ -50,6 +50,13 @@ TEST_F(SmallStringTest, AssignRepeated) { EXPECT_STREQ("aaa", theString.c_str()); } +TEST_F(SmallStringTest, AssignIterPair) { + StringRef abc = "abc"; + theString.assign(abc.begin(), abc.end()); + EXPECT_EQ(3u, theString.size()); + EXPECT_STREQ("abc", theString.c_str()); +} + TEST_F(SmallStringTest, AssignStringRef) { StringRef abc = "abc"; theString.assign(abc); @@ -81,23 +88,6 @@ TEST_F(SmallStringTest, AppendStringRef) { EXPECT_STREQ("abcabc", theString.c_str()); } -TEST_F(SmallStringTest, PlusEqualsStringRef) { - StringRef abc = "abc"; - theString += abc; - theString += abc; - EXPECT_EQ(6u, theString.size()); - EXPECT_STREQ("abcabc", theString.c_str()); -} - -TEST_F(SmallStringTest, PlusEqualsSmallVector) { - StringRef abc = "abc"; - SmallVector abcVec(abc.begin(), abc.end()); - theString += abcVec; - theString += abcVec; - EXPECT_EQ(6u, theString.size()); - EXPECT_STREQ("abcabc", theString.c_str()); -} - TEST_F(SmallStringTest, AppendSmallVector) { StringRef abc = "abc"; SmallVector abcVec(abc.begin(), abc.end()); diff --git a/unittests/ADT/SmallVectorTest.cpp b/unittests/ADT/SmallVectorTest.cpp index 0ecb7987797..90c7982699a 100644 --- a/unittests/ADT/SmallVectorTest.cpp +++ b/unittests/ADT/SmallVectorTest.cpp @@ -338,17 +338,6 @@ TYPED_TEST(SmallVectorTest, AssignTest) { this->assertValuesInOrder(this->theVector, 2u, 77, 77); } -TYPED_TEST(SmallVectorTest, AssignIterPair) { - SCOPED_TRACE("AssignIterPair"); - - std::vector v; - v.push_back(1); - v.push_back(2); - this->theVector.push_back(Constructable(1)); - this->theVector.assign(v.begin(), v.end()); - this->assertValuesInOrder(this->theVector, 2u, 1, 2); -} - // Erase a single element TYPED_TEST(SmallVectorTest, EraseTest) { SCOPED_TRACE("EraseTest");