OLD | NEW |
| (Empty) |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | |
2 // for details. All rights reserved. Use of this source code is governed by a | |
3 // BSD-style license that can be found in the LICENSE file. | |
4 | |
5 /// Base class for any AST item. Roughly corresponds to Node in the DOM. Will | |
6 /// be either an Element or Text. | |
7 abstract class Node { | |
8 void accept(NodeVisitor visitor); | |
9 } | |
10 | |
11 /// A named tag that can contain other nodes. | |
12 class Element implements Node { | |
13 final String tag; | |
14 final List<Node> children; | |
15 final Map<String, String> attributes; | |
16 | |
17 Element(this.tag, this.children) | |
18 : attributes = <String, String>{}; | |
19 | |
20 Element.empty(this.tag) | |
21 : children = null, | |
22 attributes = <String, String>{}; | |
23 | |
24 Element.withTag(this.tag) | |
25 : children = [], | |
26 attributes = <String, String>{}; | |
27 | |
28 Element.text(this.tag, String text) | |
29 : children = [new Text(text)], | |
30 attributes = <String, String>{}; | |
31 | |
32 bool get isEmpty => children == null; | |
33 | |
34 void accept(NodeVisitor visitor) { | |
35 if (visitor.visitElementBefore(this)) { | |
36 for (final child in children) child.accept(visitor); | |
37 visitor.visitElementAfter(this); | |
38 } | |
39 } | |
40 } | |
41 | |
42 /// A plain text element. | |
43 class Text implements Node { | |
44 final String text; | |
45 Text(this.text); | |
46 | |
47 void accept(NodeVisitor visitor) => visitor.visitText(this); | |
48 } | |
49 | |
50 /// Visitor pattern for the AST. Renderers or other AST transformers should | |
51 /// implement this. | |
52 abstract class NodeVisitor { | |
53 /// Called when a Text node has been reached. | |
54 void visitText(Text text); | |
55 | |
56 /// Called when an Element has been reached, before its children have been | |
57 /// visited. Return `false` to skip its children. | |
58 bool visitElementBefore(Element element); | |
59 | |
60 /// Called when an Element has been reached, after its children have been | |
61 /// visited. Will not be called if [visitElementBefore] returns `false`. | |
62 void visitElementAfter(Element element); | |
63 } | |
OLD | NEW |