Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(337)

Unified Diff: pkg/string_scanner/lib/string_scanner.dart

Issue 299973002: Add LineScanner and SpanScanner classes to string_scanner. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: code review Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « pkg/string_scanner/lib/src/utils.dart ('k') | pkg/string_scanner/pubspec.yaml » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: pkg/string_scanner/lib/string_scanner.dart
diff --git a/pkg/string_scanner/lib/string_scanner.dart b/pkg/string_scanner/lib/string_scanner.dart
index 3e3913b50169ba5796102c6314aba658341457b8..be294f4f651d8be72bdcfe78353ca12554dab99c 100644
--- a/pkg/string_scanner/lib/string_scanner.dart
+++ b/pkg/string_scanner/lib/string_scanner.dart
@@ -5,165 +5,7 @@
/// A library for parsing strings using a sequence of patterns.
library string_scanner;
-import 'dart:math' as math;
-
-/// When compiled to JS, forward slashes are always escaped in [RegExp.pattern].
-///
-/// See issue 17998.
-final _slashAutoEscape = new RegExp("/").pattern == "\\/";
-
-// TODO(nweiz): Add some integration between this and source maps.
-/// A class that scans through a string using [Pattern]s.
-class StringScanner {
- /// The string being scanned through.
- final String string;
-
- /// The current position of the scanner in the string, in characters.
- int get position => _position;
- set position(int position) {
- if (position < 0 || position > string.length) {
- throw new ArgumentError("Invalid position $position");
- }
-
- _position = position;
- }
- int _position = 0;
-
- /// The data about the previous match made by the scanner.
- ///
- /// If the last match failed, this will be `null`.
- Match get lastMatch => _lastMatch;
- Match _lastMatch;
-
- /// The portion of the string that hasn't yet been scanned.
- String get rest => string.substring(position);
-
- /// Whether the scanner has completely consumed [string].
- bool get isDone => position == string.length;
-
- /// Creates a new [StringScanner] that starts scanning from [position].
- ///
- /// [position] defaults to 0, the beginning of the string.
- StringScanner(this.string, {int position}) {
- if (position != null) this.position = position;
- }
-
- /// If [pattern] matches at the current position of the string, scans forward
- /// until the end of the match.
- ///
- /// Returns whether or not [pattern] matched.
- bool scan(Pattern pattern) {
- var success = matches(pattern);
- if (success) _position = _lastMatch.end;
- return success;
- }
-
- /// If [pattern] matches at the current position of the string, scans forward
- /// until the end of the match.
- ///
- /// If [pattern] did not match, throws a [FormatException] describing the
- /// position of the failure. [name] is used in this error as the expected name
- /// of the pattern being matched; if it's `null`, the pattern itself is used
- /// instead.
- void expect(Pattern pattern, {String name}) {
- if (scan(pattern)) return;
-
- if (name == null) {
- if (pattern is RegExp) {
- var source = pattern.pattern;
- if (!_slashAutoEscape) source = source.replaceAll("/", "\\/");
- name = "/$source/";
- } else {
- name = pattern.toString()
- .replaceAll("\\", "\\\\").replaceAll('"', '\\"');
- name = '"$name"';
- }
- }
- _fail(name);
- }
-
- /// If the string has not been fully consumed, this throws a
- /// [FormatException].
- void expectDone() {
- if (isDone) return;
- _fail("no more input");
- }
-
- /// Returns whether or not [pattern] matches at the current position of the
- /// string.
- ///
- /// This doesn't move the scan pointer forward.
- bool matches(Pattern pattern) {
- _lastMatch = pattern.matchAsPrefix(string, position);
- return _lastMatch != null;
- }
-
- /// Throws a [FormatException] with [message] as well as a detailed
- /// description of the location of the error in the string.
- ///
- /// [match] is the match information for the span of the string with which the
- /// error is associated. This should be a match returned by this scanner's
- /// [lastMatch] property. By default, the error is associated with the last
- /// match.
- ///
- /// If [position] and/or [length] are passed, they are used as the error span
- /// instead. If only [length] is passed, [position] defaults to the current
- /// position; if only [position] is passed, [length] defaults to 1.
- ///
- /// It's an error to pass [match] at the same time as [position] or [length].
- void error(String message, {Match match, int position, int length}) {
- if (match != null && (position != null || length != null)) {
- throw new ArgumentError("Can't pass both match and position/length.");
- }
-
- if (position != null && position < 0) {
- throw new RangeError("position must be greater than or equal to 0.");
- }
-
- if (length != null && length < 1) {
- throw new RangeError("length must be greater than or equal to 0.");
- }
-
- if (match == null && position == null && length == null) match = lastMatch;
- if (position == null) {
- position = match == null ? this.position : match.start;
- }
- if (length == null) length = match == null ? 1 : match.end - match.start;
-
- var newlines = "\n".allMatches(string.substring(0, position)).toList();
- var line = newlines.length + 1;
- var column;
- var lastLine;
- if (newlines.isEmpty) {
- column = position + 1;
- lastLine = string.substring(0, position);
- } else {
- column = position - newlines.last.end + 1;
- lastLine = string.substring(newlines.last.end, position);
- }
-
- var remaining = string.substring(position);
- var nextNewline = remaining.indexOf("\n");
- if (nextNewline == -1) {
- lastLine += remaining;
- } else {
- length = math.min(length, nextNewline);
- lastLine += remaining.substring(0, nextNewline);
- }
-
- var spaces = new List.filled(column - 1, ' ').join();
- var underline = new List.filled(length, '^').join();
-
- throw new FormatException(
- "Error on line $line, column $column: $message\n"
- "$lastLine\n"
- "$spaces$underline");
- }
-
- // TODO(nweiz): Make this handle long lines more gracefully.
- /// Throws a [FormatException] describing that [name] is expected at the
- /// current position in the string.
- void _fail(String name) {
- error("expected $name.", position: this.position, length: 1);
- }
-}
+export 'src/exception.dart';
+export 'src/line_scanner.dart';
+export 'src/span_scanner.dart';
+export 'src/string_scanner.dart';
« no previous file with comments | « pkg/string_scanner/lib/src/utils.dart ('k') | pkg/string_scanner/pubspec.yaml » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698