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

Unified Diff: pkg/yaml/lib/src/composer.dart

Issue 689513002: Rewrite the pkg/yaml parser. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Code review changes Created 6 years, 1 month 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/yaml/CHANGELOG.md ('k') | pkg/yaml/lib/src/constructor.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: pkg/yaml/lib/src/composer.dart
diff --git a/pkg/yaml/lib/src/composer.dart b/pkg/yaml/lib/src/composer.dart
deleted file mode 100644
index 8612067e7a2c9ef04a5a3084549fe878593a712c..0000000000000000000000000000000000000000
--- a/pkg/yaml/lib/src/composer.dart
+++ /dev/null
@@ -1,183 +0,0 @@
-// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-library yaml.composer;
-
-import 'model.dart';
-import 'visitor.dart';
-import 'yaml_exception.dart';
-
-/// Takes a parsed YAML document (what the spec calls the "serialization tree")
-/// and resolves aliases, resolves tags, and parses scalars to produce the
-/// "representation graph".
-class Composer extends Visitor {
- /// The root node of the serialization tree.
- final Node _root;
-
- /// Map from anchor names to the most recent representation graph node with
- /// that anchor.
- final _anchors = <String, Node>{};
-
- /// The next id to use for the represenation graph's anchors.
- ///
- /// The spec doesn't use anchors in the representation graph, but we do so
- /// that the constructor can ensure that the same node in the representation
- /// graph produces the same native object.
- var _idCounter = 0;
-
- Composer(this._root);
-
- /// Runs the Composer to produce a representation graph.
- Node compose() => _root.visit(this);
-
- /// Returns the anchor to which an alias node refers.
- Node visitAlias(AliasNode alias) {
- if (!_anchors.containsKey(alias.anchor)) {
- throw new YamlException("No anchor for alias ${alias.anchor}.",
- alias.span);
- }
- return _anchors[alias.anchor];
- }
-
- /// Parses a scalar node according to its tag, or auto-detects the type if no
- /// tag exists.
- ///
- /// Currently this only supports the YAML core type schema.
- Node visitScalar(ScalarNode scalar) {
- if (scalar.tag.name == "!") {
- return setAnchor(scalar, parseString(scalar));
- } else if (scalar.tag.name == "?") {
- for (var fn in [parseNull, parseBool, parseInt, parseFloat]) {
- var result = fn(scalar);
- if (result != null) return result;
- }
- return setAnchor(scalar, parseString(scalar));
- }
-
- var result = _parseByTag(scalar);
- if (result != null) return setAnchor(scalar, result);
- throw new YamlException('Invalid literal for ${scalar.tag}.',
- scalar.span);
- }
-
- ScalarNode _parseByTag(ScalarNode scalar) {
- switch (scalar.tag.name) {
- case "null": return parseNull(scalar);
- case "bool": return parseBool(scalar);
- case "int": return parseInt(scalar);
- case "float": return parseFloat(scalar);
- case "str": return parseString(scalar);
- }
- throw new YamlException('Undefined tag: ${scalar.tag}.', scalar.span);
- }
-
- /// Assigns a tag to the sequence and recursively composes its contents.
- Node visitSequence(SequenceNode seq) {
- var tagName = seq.tag.name;
- if (tagName != "!" && tagName != "?" && tagName != Tag.yaml("seq")) {
- throw new YamlException("Invalid tag for sequence: ${seq.tag}.",
- seq.span);
- }
-
- var result = setAnchor(seq,
- new SequenceNode(Tag.yaml('seq'), null, seq.span));
- result.content = super.visitSequence(seq);
- return result;
- }
-
- /// Assigns a tag to the mapping and recursively composes its contents.
- Node visitMapping(MappingNode map) {
- var tagName = map.tag.name;
- if (tagName != "!" && tagName != "?" && tagName != Tag.yaml("map")) {
- throw new YamlException("Invalid tag for mapping: ${map.tag}.",
- map.span);
- }
-
- var result = setAnchor(map,
- new MappingNode(Tag.yaml('map'), null, map.span));
- result.content = super.visitMapping(map);
- return result;
- }
-
- /// If the serialization tree node [anchored] has an anchor, records that
- /// that anchor is pointing to the representation graph node [result].
- Node setAnchor(Node anchored, Node result) {
- if (anchored.anchor == null) return result;
- result.anchor = '${_idCounter++}';
- _anchors[anchored.anchor] = result;
- return result;
- }
-
- /// Parses a null scalar.
- ScalarNode parseNull(ScalarNode scalar) {
- if (new RegExp(r"^(null|Null|NULL|~|)$").hasMatch(scalar.content)) {
- return new ScalarNode(Tag.yaml("null"), scalar.span, value: null);
- } else {
- return null;
- }
- }
-
- /// Parses a boolean scalar.
- ScalarNode parseBool(ScalarNode scalar) {
- var match = new RegExp(r"^(?:(true|True|TRUE)|(false|False|FALSE))$").
- firstMatch(scalar.content);
- if (match == null) return null;
- return new ScalarNode(Tag.yaml("bool"), scalar.span,
- value: match.group(1) != null);
- }
-
- /// Parses an integer scalar.
- ScalarNode parseInt(ScalarNode scalar) {
- var match = new RegExp(r"^[-+]?[0-9]+$").firstMatch(scalar.content);
- if (match != null) {
- return new ScalarNode(Tag.yaml("int"), scalar.span,
- value: int.parse(match.group(0)));
- }
-
- match = new RegExp(r"^0o([0-7]+)$").firstMatch(scalar.content);
- if (match != null) {
- int n = int.parse(match.group(1), radix: 8);
- return new ScalarNode(Tag.yaml("int"), scalar.span, value: n);
- }
-
- match = new RegExp(r"^0x[0-9a-fA-F]+$").firstMatch(scalar.content);
- if (match != null) {
- return new ScalarNode(Tag.yaml("int"), scalar.span,
- value: int.parse(match.group(0)));
- }
-
- return null;
- }
-
- /// Parses a floating-point scalar.
- ScalarNode parseFloat(ScalarNode scalar) {
- var match = new RegExp(
- r"^[-+]?(\.[0-9]+|[0-9]+(\.[0-9]*)?)([eE][-+]?[0-9]+)?$").
- firstMatch(scalar.content);
- if (match != null) {
- // YAML allows floats of the form "0.", but Dart does not. Fix up those
- // floats by removing the trailing dot.
- var matchStr = match.group(0).replaceAll(new RegExp(r"\.$"), "");
- return new ScalarNode(Tag.yaml("float"), scalar.span,
- value: double.parse(matchStr));
- }
-
- match = new RegExp(r"^([+-]?)\.(inf|Inf|INF)$").firstMatch(scalar.content);
- if (match != null) {
- var value = match.group(1) == "-" ? -double.INFINITY : double.INFINITY;
- return new ScalarNode(Tag.yaml("float"), scalar.span, value: value);
- }
-
- match = new RegExp(r"^\.(nan|NaN|NAN)$").firstMatch(scalar.content);
- if (match != null) {
- return new ScalarNode(Tag.yaml("float"), scalar.span, value: double.NAN);
- }
-
- return null;
- }
-
- /// Parses a string scalar.
- ScalarNode parseString(ScalarNode scalar) =>
- new ScalarNode(Tag.yaml("str"), scalar.span, value: scalar.content);
-}
« no previous file with comments | « pkg/yaml/CHANGELOG.md ('k') | pkg/yaml/lib/src/constructor.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698