OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 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 | 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. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 String renderToHtml(List<Node> nodes) => new HtmlRenderer().render(nodes); | 5 String renderToHtml(List<Node> nodes) => new HtmlRenderer().render(nodes); |
6 | 6 |
7 /// Translates a parsed AST to HTML. | 7 /// Translates a parsed AST to HTML. |
8 class HtmlRenderer implements NodeVisitor { | 8 class HtmlRenderer implements NodeVisitor { |
9 static const _BLOCK_TAGS = const RegExp( | 9 static const _BLOCK_TAGS = const RegExp( |
10 'blockquote|h1|h2|h3|h4|h5|h6|hr|p|pre'); | 10 'blockquote|h1|h2|h3|h4|h5|h6|hr|p|pre'); |
11 | 11 |
12 StringBuffer buffer; | 12 StringBuffer buffer; |
13 | 13 |
14 HtmlRenderer(); | 14 HtmlRenderer(); |
15 | 15 |
16 String render(List<Node> nodes) { | 16 String render(List<Node> nodes) { |
17 buffer = new StringBuffer(); | 17 buffer = new StringBuffer(); |
18 | 18 |
19 for (final node in nodes) node.accept(this); | 19 for (final node in nodes) node.accept(this); |
20 | 20 |
21 return buffer.toString(); | 21 return buffer.toString(); |
22 } | 22 } |
23 | 23 |
24 void visitText(Text text) { | 24 void visitText(Text text) { |
25 buffer.add(text.text); | 25 buffer.add(text.text); |
26 } | 26 } |
27 | 27 |
28 bool visitElementBefore(Element element) { | 28 bool visitElementBefore(Element element) { |
29 // Hackish. Separate block-level elements with newlines. | 29 // Hackish. Separate block-level elements with newlines. |
30 if (!buffer.isEmpty() && | 30 if (!buffer.isEmpty && |
31 _BLOCK_TAGS.firstMatch(element.tag) != null) { | 31 _BLOCK_TAGS.firstMatch(element.tag) != null) { |
32 buffer.add('\n'); | 32 buffer.add('\n'); |
33 } | 33 } |
34 | 34 |
35 buffer.add('<${element.tag}'); | 35 buffer.add('<${element.tag}'); |
36 | 36 |
37 // Sort the keys so that we generate stable output. | 37 // Sort the keys so that we generate stable output. |
38 // TODO(rnystrom): This assumes getKeys() returns a fresh mutable | 38 // TODO(rnystrom): This assumes getKeys() returns a fresh mutable |
39 // collection. | 39 // collection. |
40 final attributeNames = element.attributes.getKeys(); | 40 final attributeNames = element.attributes.getKeys(); |
41 attributeNames.sort((a, b) => a.compareTo(b)); | 41 attributeNames.sort((a, b) => a.compareTo(b)); |
42 for (final name in attributeNames) { | 42 for (final name in attributeNames) { |
43 buffer.add(' $name="${element.attributes[name]}"'); | 43 buffer.add(' $name="${element.attributes[name]}"'); |
44 } | 44 } |
45 | 45 |
46 if (element.isEmpty) { | 46 if (element.isEmpty) { |
47 // Empty element like <hr/>. | 47 // Empty element like <hr/>. |
48 buffer.add(' />'); | 48 buffer.add(' />'); |
49 return false; | 49 return false; |
50 } else { | 50 } else { |
51 buffer.add('>'); | 51 buffer.add('>'); |
52 return true; | 52 return true; |
53 } | 53 } |
54 } | 54 } |
55 | 55 |
56 void visitElementAfter(Element element) { | 56 void visitElementAfter(Element element) { |
57 buffer.add('</${element.tag}>'); | 57 buffer.add('</${element.tag}>'); |
58 } | 58 } |
59 } | 59 } |
OLD | NEW |