| Index: pkg/yaml/lib/src/model.dart
|
| diff --git a/pkg/yaml/lib/src/model.dart b/pkg/yaml/lib/src/model.dart
|
| deleted file mode 100644
|
| index 93cb49c7a36901fbad5935ff3827fbac645960b9..0000000000000000000000000000000000000000
|
| --- a/pkg/yaml/lib/src/model.dart
|
| +++ /dev/null
|
| @@ -1,259 +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.
|
| -
|
| -/// This file contains the node classes for the internal representations of YAML
|
| -/// documents. These nodes are used for both the serialization tree and the
|
| -/// representation graph.
|
| -library yaml.model;
|
| -
|
| -import 'package:source_span/source_span.dart';
|
| -
|
| -import 'equality.dart';
|
| -import 'parser.dart';
|
| -import 'visitor.dart';
|
| -import 'yaml_exception.dart';
|
| -
|
| -/// The prefix for tag types defined by the YAML spec.
|
| -const _YAML_URI_PREFIX = "tag:yaml.org,2002:";
|
| -
|
| -/// A tag that indicates the type of a YAML node.
|
| -class Tag {
|
| - /// The name of the tag, either a URI or a local tag beginning with "!".
|
| - final String name;
|
| -
|
| - /// The kind of the tag.
|
| - final TagKind kind;
|
| -
|
| - /// Returns the standard YAML tag URI for [type].
|
| - static String yaml(String type) => "tag:yaml.org,2002:$type";
|
| -
|
| - const Tag(this.name, this.kind);
|
| -
|
| - const Tag.scalar(String name)
|
| - : this(name, TagKind.SCALAR);
|
| -
|
| - const Tag.sequence(String name)
|
| - : this(name, TagKind.SEQUENCE);
|
| -
|
| - const Tag.mapping(String name)
|
| - : this(name, TagKind.MAPPING);
|
| -
|
| - /// Two tags are equal if their URIs are equal.
|
| - operator ==(other) {
|
| - if (other is! Tag) return false;
|
| - return name == other.name;
|
| - }
|
| -
|
| - String toString() {
|
| - if (name.startsWith(_YAML_URI_PREFIX)) {
|
| - return '!!${name.substring(_YAML_URI_PREFIX.length)}';
|
| - } else {
|
| - return '!<$name>';
|
| - }
|
| - }
|
| -
|
| - int get hashCode => name.hashCode;
|
| -}
|
| -
|
| -/// An enum for kinds of tags.
|
| -class TagKind {
|
| - /// A tag indicating that the value is a scalar.
|
| - static const SCALAR = const TagKind._("scalar");
|
| -
|
| - /// A tag indicating that the value is a sequence.
|
| - static const SEQUENCE = const TagKind._("sequence");
|
| -
|
| - /// A tag indicating that the value is a mapping.
|
| - static const MAPPING = const TagKind._("mapping");
|
| -
|
| - final String name;
|
| -
|
| - const TagKind._(this.name);
|
| -
|
| - String toString() => name;
|
| -}
|
| -
|
| -/// The abstract class for YAML nodes.
|
| -abstract class Node {
|
| - /// Every YAML node has a tag that describes its type.
|
| - Tag tag;
|
| -
|
| - /// Any YAML node can have an anchor associated with it.
|
| - String anchor;
|
| -
|
| - /// The source span for this node.
|
| - SourceSpan span;
|
| -
|
| - Node(this.tag, this.span, [this.anchor]);
|
| -
|
| - bool operator ==(other) {
|
| - if (other is! Node) return false;
|
| - return tag == other.tag;
|
| - }
|
| -
|
| - int get hashCode => tag.hashCode ^ anchor.hashCode;
|
| -
|
| - visit(Visitor v);
|
| -}
|
| -
|
| -/// A sequence node represents an ordered list of nodes.
|
| -class SequenceNode extends Node {
|
| - /// The nodes in the sequence.
|
| - List<Node> content;
|
| -
|
| - SequenceNode(String tagName, this.content, SourceSpan span)
|
| - : super(new Tag.sequence(tagName), span);
|
| -
|
| - /// Two sequences are equal if their tags and contents are equal.
|
| - bool operator ==(other) {
|
| - // Should be super != other; bug 2554
|
| - if (!(super == other) || other is! SequenceNode) return false;
|
| - if (content.length != other.content.length) return false;
|
| - for (var i = 0; i < content.length; i++) {
|
| - if (content[i] != other.content[i]) return false;
|
| - }
|
| - return true;
|
| - }
|
| -
|
| - String toString() => '$tag [${content.map((e) => '$e').join(', ')}]';
|
| -
|
| - int get hashCode => super.hashCode ^ deepHashCode(content);
|
| -
|
| - visit(Visitor v) => v.visitSequence(this);
|
| -}
|
| -
|
| -/// An alias node is a reference to an anchor.
|
| -class AliasNode extends Node {
|
| - AliasNode(String anchor, SourceSpan span)
|
| - : super(new Tag.scalar(Tag.yaml("str")), span, anchor);
|
| -
|
| - visit(Visitor v) => v.visitAlias(this);
|
| -}
|
| -
|
| -/// A scalar node represents all YAML nodes that have a single value.
|
| -class ScalarNode extends Node {
|
| - /// The string value of the scalar node, if it was created by the parser.
|
| - final String _content;
|
| -
|
| - /// The Dart value of the scalar node, if it was created by the composer.
|
| - final value;
|
| -
|
| - /// Creates a new Scalar node.
|
| - ///
|
| - /// Exactly one of [content] and [value] should be specified. Content should
|
| - /// be specified for a newly-parsed scalar that hasn't yet been composed.
|
| - /// Value should be specified for a composed scalar, although `null` is a
|
| - /// valid value.
|
| - ScalarNode(String tagName, SourceSpan span, {String content, this.value})
|
| - : _content = content,
|
| - super(new Tag.scalar(tagName), span);
|
| -
|
| - /// Two scalars are equal if their string representations are equal.
|
| - bool operator ==(other) {
|
| - // Should be super != other; bug 2554
|
| - if (!(super == other) || other is! ScalarNode) return false;
|
| - return content == other.content;
|
| - }
|
| -
|
| - /// Returns the string representation of the scalar. After composition, this
|
| - /// is equal to the canonical serialization of the value of the scalar.
|
| - String get content => _content != null ? _content : canonicalContent;
|
| -
|
| - /// Returns the canonical serialization of the value of the scalar. If the
|
| - /// value isn't given, the result of this will be "null".
|
| - String get canonicalContent {
|
| - if (value == null || value is bool || value is int) return '$value';
|
| -
|
| - if (value is num) {
|
| - // 20 is the maximum value for this argument, which we use since YAML
|
| - // doesn't specify a maximum.
|
| - return value.toStringAsExponential(20).
|
| - replaceFirst(new RegExp("0+e"), "e");
|
| - }
|
| -
|
| - if (value is String) {
|
| - // TODO(nweiz): This could be faster if we used a RegExp to check for
|
| - // special characters and short-circuited if they didn't exist.
|
| -
|
| - var escapedValue = value.codeUnits.map((c) {
|
| - switch (c) {
|
| - case Parser.TAB: return "\\t";
|
| - case Parser.LF: return "\\n";
|
| - case Parser.CR: return "\\r";
|
| - case Parser.DOUBLE_QUOTE: return '\\"';
|
| - case Parser.NULL: return "\\0";
|
| - case Parser.BELL: return "\\a";
|
| - case Parser.BACKSPACE: return "\\b";
|
| - case Parser.VERTICAL_TAB: return "\\v";
|
| - case Parser.FORM_FEED: return "\\f";
|
| - case Parser.ESCAPE: return "\\e";
|
| - case Parser.BACKSLASH: return "\\\\";
|
| - case Parser.NEL: return "\\N";
|
| - case Parser.NBSP: return "\\_";
|
| - case Parser.LINE_SEPARATOR: return "\\L";
|
| - case Parser.PARAGRAPH_SEPARATOR: return "\\P";
|
| - default:
|
| - if (c < 0x20 || (c >= 0x7f && c < 0x100)) {
|
| - return "\\x${zeroPad(c.toRadixString(16).toUpperCase(), 2)}";
|
| - } else if (c >= 0x100 && c < 0x10000) {
|
| - return "\\u${zeroPad(c.toRadixString(16).toUpperCase(), 4)}";
|
| - } else if (c >= 0x10000) {
|
| - return "\\u${zeroPad(c.toRadixString(16).toUpperCase(), 8)}";
|
| - } else {
|
| - return new String.fromCharCodes([c]);
|
| - }
|
| - }
|
| - });
|
| - return '"${escapedValue.join()}"';
|
| - }
|
| -
|
| - throw new YamlException('Unknown scalar value.', span);
|
| - }
|
| -
|
| - String toString() => '$tag "$content"';
|
| -
|
| - /// Left-pads [str] with zeros so that it's at least [length] characters
|
| - /// long.
|
| - String zeroPad(String str, int length) {
|
| - assert(length >= str.length);
|
| - var prefix = new List.filled(length - str.length, '0');
|
| - return '${prefix.join()}$str';
|
| - }
|
| -
|
| - int get hashCode => super.hashCode ^ content.hashCode;
|
| -
|
| - visit(Visitor v) => v.visitScalar(this);
|
| -}
|
| -
|
| -/// A mapping node represents an unordered map of nodes to nodes.
|
| -class MappingNode extends Node {
|
| - /// The node map.
|
| - Map<Node, Node> content;
|
| -
|
| - MappingNode(String tagName, this.content, SourceSpan span)
|
| - : super(new Tag.mapping(tagName), span);
|
| -
|
| - /// Two mappings are equal if their tags and contents are equal.
|
| - bool operator ==(other) {
|
| - // Should be super != other; bug 2554
|
| - if (!(super == other) || other is! MappingNode) return false;
|
| - if (content.length != other.content.length) return false;
|
| - for (var key in content.keys) {
|
| - if (!other.content.containsKey(key)) return false;
|
| - if (content[key] != other.content[key]) return false;
|
| - }
|
| - return true;
|
| - }
|
| -
|
| - String toString() {
|
| - var strContent = content.keys
|
| - .map((k) => '${k}: ${content[k]}')
|
| - .join(', ');
|
| - return '$tag {$strContent}';
|
| - }
|
| -
|
| - int get hashCode => super.hashCode ^ deepHashCode(content);
|
| -
|
| - visit(Visitor v) => v.visitMapping(this);
|
| -}
|
|
|