summaryrefslogtreecommitdiffstats
path: root/llvm/utils/FileCheck/FileCheck.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-09-25 17:09:12 +0000
committerChris Lattner <sabre@nondot.org>2009-09-25 17:09:12 +0000
commit221460e0bee5a9eb51eae8f7b6df3e29ae8a1aa2 (patch)
treebab28c14c5b0b67b9a8ea434777929f8c075520d /llvm/utils/FileCheck/FileCheck.cpp
parent722212d1a0672ae18a23db58c4cfb7e38073abfa (diff)
downloadbcm5719-llvm-221460e0bee5a9eb51eae8f7b6df3e29ae8a1aa2.tar.gz
bcm5719-llvm-221460e0bee5a9eb51eae8f7b6df3e29ae8a1aa2.zip
special case Patterns that are a single fixed string. This is a microscopic
perf win and is needed for future changes. llvm-svn: 82777
Diffstat (limited to 'llvm/utils/FileCheck/FileCheck.cpp')
-rw-r--r--llvm/utils/FileCheck/FileCheck.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/utils/FileCheck/FileCheck.cpp b/llvm/utils/FileCheck/FileCheck.cpp
index 1f79b92e9d0..061d321b903 100644
--- a/llvm/utils/FileCheck/FileCheck.cpp
+++ b/llvm/utils/FileCheck/FileCheck.cpp
@@ -75,6 +75,8 @@ class Pattern {
/// Chunks - The pattern chunks to match. If the bool is false, it is a fixed
/// string match, if it is true, it is a regex match.
SmallVector<PatternChunk, 4> Chunks;
+
+ StringRef FixedStr;
public:
Pattern() { }
@@ -101,6 +103,14 @@ bool Pattern::ParsePattern(StringRef PatternStr, SourceMgr &SM) {
return true;
}
+ // Check to see if this is a fixed string, or if it has regex pieces.
+ if (PatternStr.size() < 2 || PatternStr.find("{{") == StringRef::npos) {
+ FixedStr = PatternStr;
+ return false;
+ }
+
+ // Otherwise, there is at least one regex piece.
+
// Scan the pattern to break it into regex and non-regex pieces.
while (!PatternStr.empty()) {
// Handle fixed string matches.
@@ -141,6 +151,12 @@ bool Pattern::ParsePattern(StringRef PatternStr, SourceMgr &SM) {
/// returns the position that is matched or npos if there is no match. If
/// there is a match, the size of the matched string is returned in MatchLen.
size_t Pattern::Match(StringRef Buffer, size_t &MatchLen) const {
+ // If this is a fixed string pattern, just match it now.
+ if (!FixedStr.empty()) {
+ MatchLen = FixedStr.size();
+ return Buffer.find(FixedStr);
+ }
+
size_t FirstMatch = StringRef::npos;
MatchLen = 0;
OpenPOWER on IntegriCloud