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 class $CLASSNAME$EXTENDS$IMPLEMENTS$NATIVESPEC { | 5 class $CLASSNAME$EXTENDS$IMPLEMENTS$NATIVESPEC { |
6 _NodeListImpl get nodes() { | 6 _NodeListImpl get nodes() { |
7 final list = _childNodes; | 7 final list = _childNodes; |
8 list._parent = this; | 8 list._parent = this; |
9 return list; | 9 return list; |
10 } | 10 } |
11 | 11 |
12 void set nodes(Collection<Node> value) { | 12 void set nodes(Collection<Node> value) { |
13 // Copy list first since we don't want liveness during iteration. | 13 // Copy list first since we don't want liveness during iteration. |
14 // TODO(jacobr): there is a better way to do this. | 14 // TODO(jacobr): there is a better way to do this. |
15 List copy = new List.from(value); | 15 List copy = new List.from(value); |
vsm
2012/03/05 21:37:36
I don't think this extra copy is buying anything.
Jacob
2012/03/05 21:55:30
This code already has a TODO that it is doing thin
| |
16 nodes.clear(); | 16 text = ''; |
sra1
2012/03/05 21:44:59
What does this do? Does setting text like this re
Jacob
2012/03/05 21:55:30
that's the goal. remove all the old nodes and add
| |
17 nodes.addAll(copy); | 17 for (Node node in copy) { |
18 _appendChild(node); | |
19 } | |
18 } | 20 } |
19 | 21 |
20 // TODO(jacobr): should we throw an exception if parent is already null? | 22 // TODO(jacobr): should we throw an exception if parent is already null? |
21 _NodeImpl remove() { | 23 _NodeImpl remove() { |
22 if (this.parent != null) { | 24 if (this.parent != null) { |
23 this.parent._removeChild(this); | 25 this.parent._removeChild(this); |
24 } | 26 } |
25 return this; | 27 return this; |
26 } | 28 } |
27 | 29 |
28 _NodeImpl replaceWith(Node otherNode) { | 30 _NodeImpl replaceWith(Node otherNode) { |
29 try { | 31 try { |
30 this.parent._replaceChild(otherNode, this); | 32 this.parent._replaceChild(otherNode, this); |
31 } catch(var e) { | 33 } catch(var e) { |
32 | 34 |
33 }; | 35 }; |
34 return this; | 36 return this; |
35 } | 37 } |
36 | 38 |
37 $!MEMBERS | 39 $!MEMBERS |
38 } | 40 } |
OLD | NEW |