Index: pkg/yaml/lib/src/constructor.dart |
diff --git a/pkg/yaml/lib/src/constructor.dart b/pkg/yaml/lib/src/constructor.dart |
index 116809dfb6ad3d4a4c2f3dfaf3659c001987beb7..b77c38b597b51dba65e05c8d28c56ac9ce4b7d92 100644 |
--- a/pkg/yaml/lib/src/constructor.dart |
+++ b/pkg/yaml/lib/src/constructor.dart |
@@ -4,9 +4,10 @@ |
library yaml.constructor; |
+import 'equality.dart'; |
import 'model.dart'; |
import 'visitor.dart'; |
-import 'yaml_map.dart'; |
+import 'yaml_node.dart'; |
/// Takes a parsed and composed YAML document (what the spec calls the |
/// "representation graph") and creates native Dart objects that represent that |
@@ -16,43 +17,52 @@ class Constructor extends Visitor { |
final Node _root; |
/// Map from anchor names to the most recent Dart node with that anchor. |
- final _anchors = <String, dynamic>{}; |
+ final _anchors = <String, YamlNode>{}; |
Constructor(this._root); |
/// Runs the Constructor to produce a Dart object. |
- construct() => _root.visit(this); |
+ YamlNode construct() => _root.visit(this); |
/// Returns the value of a scalar. |
- visitScalar(ScalarNode scalar) => scalar.value; |
+ YamlScalar visitScalar(ScalarNode scalar) => |
+ new YamlScalar(scalar.value, scalar.span); |
/// Converts a sequence into a List of Dart objects. |
- visitSequence(SequenceNode seq) { |
+ YamlList visitSequence(SequenceNode seq) { |
var anchor = getAnchor(seq); |
if (anchor != null) return anchor; |
- var dartSeq = setAnchor(seq, []); |
- dartSeq.addAll(super.visitSequence(seq)); |
+ var nodes = []; |
+ var dartSeq = setAnchor(seq, new YamlList(nodes, seq.span)); |
+ nodes.addAll(super.visitSequence(seq)); |
return dartSeq; |
} |
/// Converts a mapping into a Map of Dart objects. |
Bob Nystrom
2014/06/03 00:33:14
"Map" -> "[Map]".
nweiz
2014/06/03 02:03:21
Done.
|
- visitMapping(MappingNode map) { |
+ YamlMap visitMapping(MappingNode map) { |
var anchor = getAnchor(map); |
if (anchor != null) return anchor; |
- var dartMap = setAnchor(map, new YamlMap()); |
- super.visitMapping(map).forEach((k, v) { dartMap[k] = v; }); |
+ var nodes = deepEqualsMap(); |
+ var dartMap = setAnchor(map, new YamlMap(nodes, map.span)); |
+ super.visitMapping(map).forEach((k, v) => nodes[k] = v); |
return dartMap; |
} |
/// Returns the Dart object that already represents [anchored], if such a |
Bob Nystrom
2014/06/03 00:33:14
This is a bit confusing since it's a new object no
nweiz
2014/06/03 02:03:21
Done.
|
/// thing exists. |
- getAnchor(Node anchored) { |
+ YamlNode getAnchor(Node anchored) { |
if (anchored.anchor == null) return null; |
- if (_anchors.containsKey(anchored.anchor)) return _anchors[anchored.anchor]; |
+ if (!_anchors.containsKey(anchored.anchor)) return null; |
+ |
+ var value = _anchors[anchored.anchor]; |
Bob Nystrom
2014/06/03 00:33:14
Can this ever be null now? If not, use it for the
Bob Nystrom
2014/06/03 00:33:14
Add a comment explaining why these are copied. Is
nweiz
2014/06/03 02:03:21
Done.
nweiz
2014/06/03 02:03:21
Done.
|
+ if (value is YamlMap) return new YamlMap(value.nodes, anchored.span); |
+ if (value is YamlList) return new YamlList(value.nodes, anchored.span); |
+ assert(value is YamlScalar); |
+ return new YamlScalar(value.value, anchored.span); |
} |
/// Records that [value] is the Dart object representing [anchored]. |
- setAnchor(Node anchored, value) { |
+ YamlNode setAnchor(Node anchored, YamlNode value) { |
if (anchored.anchor == null) return value; |
_anchors[anchored.anchor] = value; |
return value; |