Chromium Code Reviews| Index: client/dom/templates/html/impl/impl_NodeList.darttemplate |
| diff --git a/client/dom/templates/html/impl/impl_NodeList.darttemplate b/client/dom/templates/html/impl/impl_NodeList.darttemplate |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7b6fcf8af470999664654354dc84000535d8062c |
| --- /dev/null |
| +++ b/client/dom/templates/html/impl/impl_NodeList.darttemplate |
| @@ -0,0 +1,171 @@ |
| +// 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. |
| + |
| +// TODO(nweiz): when all implementations we target have the same name for the |
| +// coreimpl implementation of List<E>, extend that rather than wrapping. |
| +class _ListWrapper<E> implements List<E> { |
| + List _list; |
| + |
| + _ListWrapper(List this._list); |
| + |
| + Iterator<E> iterator() => _list.iterator(); |
| + |
| + void forEach(void f(E element)) => _list.forEach(f); |
| + |
| + Collection map(f(E element)) => _list.map(f); |
| + |
| + List<E> filter(bool f(E element)) => _list.filter(f); |
| + |
| + bool every(bool f(E element)) => _list.every(f); |
| + |
| + bool some(bool f(E element)) => _list.some(f); |
| + |
| + bool isEmpty() => _list.isEmpty(); |
| + |
| + int get length() => _list.length; |
| + |
| + E operator [](int index) => _list[index]; |
| + |
| + void operator []=(int index, E value) { _list[index] = value; } |
| + |
| + void set length(int newLength) { _list.length = newLength; } |
| + |
| + void add(E value) => _list.add(value); |
| + |
| + void addLast(E value) => _list.addLast(value); |
| + |
| + void addAll(Collection<E> collection) => _list.addAll(collection); |
| + |
| + void sort(int compare(E a, E b)) => _list.sort(compare); |
| + |
| + int indexOf(E element, [int start = 0]) => _list.indexOf(element, start); |
| + |
| + int lastIndexOf(E element, [int start = 0]) => |
| + _list.lastIndexOf(element, start); |
| + |
| + void clear() => _list.clear(); |
| + |
| + E removeLast() => _list.removeLast(); |
| + |
| + E last() => _list.last(); |
| + |
| + List<E> getRange(int start, int length) => _list.getRange(start, length); |
| + |
| + void setRange(int start, int length, List<E> from, [int startFrom = 0]) => |
| + _list.setRange(start, length, from, startFrom); |
| + |
| + void removeRange(int start, int length) => _list.removeRange(start, length); |
| + |
| + void insertRange(int start, int length, [E initialValue = null]) => |
| + _list.insertRange(start, length, initialValue); |
| + |
| + E get first() => _list[0]; |
| +} |
| + |
| +/** |
| + * This class is used to insure the results of list operations are NodeLists |
| + * instead of lists. |
| + */ |
| +class _NodeListWrapper extends _ListWrapper<Node> implements NodeList { |
| + _NodeListWrapper(List list) : super(list); |
| + |
| + NodeList filter(bool f(Node element)) => |
| + new _NodeListWrapper(_list.filter(f)); |
| + |
| + NodeList getRange(int start, int length) => |
| + new _NodeListWrapper(_list.getRange(start, length)); |
| +} |
| + |
| +class $CLASSNAME$EXTENDS$IMPLEMENTS$NATIVESPEC { |
| + _NodeImpl _parent; |
| + |
| + // -- start List<Node> mixins. |
| + // Node is the element type. |
| + |
| + // From Iterable<Node>: |
| + |
| + Iterator<Node> iterator() { |
| + // Note: NodeLists are not fixed size. And most probably length shouldn't |
| + // be cached in both iterator _and_ forEach method. For now caching it |
| + // for consistency. |
| + return new _FixedSizeListIterator<Node>(this); |
| + } |
| + |
| + // From Collection<Node>: |
| + |
| + void add(_NodeImpl value) { |
| + _parent._appendChild(value); |
| + } |
| + |
| + void addLast(_NodeImpl value) { |
| + _parent._appendChild(value); |
| + } |
| + |
| + void addAll(Collection<_NodeImpl> collection) { |
| + for (_NodeImpl node in collection) { |
| + _parent._appendChild(node); |
| + } |
| + } |
| + |
| + _NodeImpl removeLast() { |
| + final last = this.last(); |
| + if (last != null) { |
| + _parent._removeChild(last); |
| + } |
| + return last; |
| + } |
| + |
| + void clear() { |
| + _parent.text = ''; |
| + } |
| + |
| + void operator []=(int index, _NodeImpl value) { |
| + _parent._replaceChild(value, this[index]); |
| + } |
| + |
| + void forEach(void f(Node element)) => _Collections.forEach(this, f); |
| + |
| + Collection map(f(Node element)) => _Collections.map(this, [], f); |
| + |
| + Collection<Node> filter(bool f(Node element)) => |
| + new _NodeListWrapper(_Collections.filter(this, <Node>[], f)); |
| + |
| + bool every(bool f(Node element)) => _Collections.every(this, f); |
| + |
| + bool some(bool f(Node element)) => _Collections.some(this, f); |
| + |
| + bool isEmpty() => this.length == 0; |
| + |
| + // From List<Node>: |
| + |
| + void sort(int compare(Node a, Node b)) { |
| + throw new UnsupportedOperationException("Cannot sort immutable List."); |
| + } |
| + |
| + int indexOf(Node element, [int start = 0]) => |
| + _Lists.indexOf(this, element, start, this.length); |
| + |
| + int lastIndexOf(Node element, [int start = 0]) => |
| + _Lists.lastIndexOf(this, element, start); |
| + |
| + Node last() => this[length - 1]; |
| + Node get first() => this[0]; |
| + |
| + // FIXME: implement thesee. |
|
nweiz
2012/03/01 21:18:03
I don't think anything needs to be implemented her
|
| + void setRange(int start, int length, List<Node> from, [int startFrom]) { |
| + throw new UnsupportedOperationException("Cannot setRange on immutable List."); |
| + } |
| + void removeRange(int start, int length) { |
| + throw new UnsupportedOperationException("Cannot removeRange on immutable List."); |
| + } |
| + void insertRange(int start, int length, [Node initialValue]) { |
| + throw new UnsupportedOperationException("Cannot insertRange on immutable List."); |
| + } |
| + NodeList getRange(int start, int length) => |
| + new _NodeListWrapper(_Lists.getRange(this, start, length, <Node>[])); |
| + |
| + // -- end List<Node> mixins. |
| + |
| +$!MEMBERS |
| +} |