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

Delta Between Two Patch Sets: compiled/StringScanner.h

Issue 29333474: Issue 4125 - [emscripten] Convert filter classes to C++ (Closed)
Left Patch Set: Using embind Created Jan. 15, 2016, 8:44 p.m.
Right Patch Set: Addressed comments from Patch Set 28 Created March 21, 2017, 10:04 a.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
Right: Side by side diff | Download
« no previous file with change/comment | « compiled/StringMap.h ('k') | compiled/WhitelistFilter.h » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
(no file at all)
1 #pragma once
2
3 #include "String.h"
4
5 class StringScanner
6 {
7 private:
8 const DependentString mStr;
9 String::size_type mPos;
10 String::size_type mEnd;
11 String::value_type mTerminator;
12 public:
13 explicit StringScanner(const String& str, String::size_type pos = 0,
14 String::value_type terminator = u'\0')
15 : mStr(str), mPos(pos), mEnd(str.length()), mTerminator(terminator) {}
16
17 bool done() const
18 {
19 return mPos >= mEnd;
20 }
21
22 String::size_type position() const
23 {
24 return mPos - 1;
25 }
26
27 String::value_type next()
28 {
29 String::value_type result = done() ? mTerminator : mStr[mPos];
30 mPos++;
31 return result;
32 }
33
34 bool skipOne(String::value_type ch)
35 {
36 if (!done() && mStr[mPos] == ch)
37 {
38 mPos++;
39 return true;
40 }
41
42 return false;
43 }
44
45 bool skip(String::value_type ch)
46 {
47 bool skipped = false;
48 while ((skipped = skipOne(ch)));
49 return skipped;
50 }
51 };
LEFTRIGHT

Powered by Google App Engine
This is Rietveld