Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: compiled/StringScanner.h

Issue 29333474: Issue 4125 - [emscripten] Convert filter classes to C++ (Closed)
Patch Set: Addressed comments from Patch Set 28 Created March 21, 2017, 10:04 a.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « compiled/StringMap.h ('k') | compiled/WhitelistFilter.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: compiled/StringScanner.h
===================================================================
new file mode 100644
--- /dev/null
+++ b/compiled/StringScanner.h
@@ -0,0 +1,51 @@
+#pragma once
+
+#include "String.h"
+
+class StringScanner
+{
+private:
+ const DependentString mStr;
+ String::size_type mPos;
+ String::size_type mEnd;
+ String::value_type mTerminator;
+public:
+ explicit StringScanner(const String& str, String::size_type pos = 0,
+ String::value_type terminator = u'\0')
+ : mStr(str), mPos(pos), mEnd(str.length()), mTerminator(terminator) {}
+
+ bool done() const
+ {
+ return mPos >= mEnd;
+ }
+
+ String::size_type position() const
+ {
+ return mPos - 1;
+ }
+
+ String::value_type next()
+ {
+ String::value_type result = done() ? mTerminator : mStr[mPos];
+ mPos++;
+ return result;
+ }
+
+ bool skipOne(String::value_type ch)
+ {
+ if (!done() && mStr[mPos] == ch)
+ {
+ mPos++;
+ return true;
+ }
+
+ return false;
+ }
+
+ bool skip(String::value_type ch)
+ {
+ bool skipped = false;
+ while ((skipped = skipOne(ch)));
+ return skipped;
+ }
+};
« no previous file with comments | « compiled/StringMap.h ('k') | compiled/WhitelistFilter.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld