From: Daniel Dunbar Date: Tue, 18 Aug 2009 18:26:35 +0000 (+0000) Subject: Add StringRef::count({char,StringRef}) X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=5caba3bcb14fae4b36924463ed2bcf3846f029a9;p=oota-llvm.git Add StringRef::count({char,StringRef}) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79354 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/ADT/StringRef.h b/include/llvm/ADT/StringRef.h index 40689a98870..54330560390 100644 --- a/include/llvm/ADT/StringRef.h +++ b/include/llvm/ADT/StringRef.h @@ -172,6 +172,28 @@ namespace llvm { return npos; } + /// count - Return the number of occurrences of \arg C in the string. + size_t count(char C) const { + size_t Count = 0; + for (size_t i = 0, e = Length; i != e; ++i) + if (Data[i] == C) + return i; + return Count; + } + + /// count - Return the number of non-overlapped occurrences of \arg Str in + /// the string. + size_t count(const StringRef &Str) const { + size_t Count = 0; + size_t N = Str.size(); + if (N > Length) + return 0; + for (size_t i = 0, e = Length - N + 1; i != e; ++i) + if (substr(i, N).equals(Str)) + ++Count; + return Count; + } + /// @} /// @name Substring Operations /// @{ diff --git a/unittests/ADT/StringRefTest.cpp b/unittests/ADT/StringRefTest.cpp index 972201c1ff0..ef89e9f3f9d 100644 --- a/unittests/ADT/StringRefTest.cpp +++ b/unittests/ADT/StringRefTest.cpp @@ -94,6 +94,13 @@ TEST(StringRefTest, Utilities) { EXPECT_TRUE(Str.find("hello") == 0); EXPECT_TRUE(Str.find("ello") == 1); EXPECT_TRUE(Str.find("zz") == StringRef::npos); + + EXPECT_TRUE(Str.count('l') == 2); + EXPECT_TRUE(Str.count('z') == 0); + EXPECT_TRUE(Str.count("helloworld") == 0); + EXPECT_TRUE(Str.count("hello") == 1); + EXPECT_TRUE(Str.count("ello") == 1); + EXPECT_TRUE(Str.count("zz") == 0); } } // end anonymous namespace