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: Properly determine ref_counted offset instead of assuming that it is zero Created March 14, 2017, 10:18 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
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) {}
+
+ const bool done()
sergei 2017/03/20 17:07:12 It should be `bool done() const`.
Wladimir Palant 2017/03/21 10:10:06 Done.
+ {
+ return mPos >= mEnd;
+ }
+
+ const String::size_type position()
sergei 2017/03/20 17:07:10 it should be `String::size_type position() const`.
Wladimir Palant 2017/03/21 10:10:09 Done.
+ {
+ 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;
+ }
+};

Powered by Google App Engine
This is Rietveld