| Index: pkg/collection_helpers/lib/unmodifiable_wrappers.dart
|
| diff --git a/pkg/unmodifiable_collection/lib/unmodifiable_collection.dart b/pkg/collection_helpers/lib/unmodifiable_wrappers.dart
|
| similarity index 57%
|
| rename from pkg/unmodifiable_collection/lib/unmodifiable_collection.dart
|
| rename to pkg/collection_helpers/lib/unmodifiable_wrappers.dart
|
| index 9fd35e8a4c6db9338dcc3189d3b81a13ff54c31d..b44337f844a6eb8820e36e0416de1b99183024be 100644
|
| --- a/pkg/unmodifiable_collection/lib/unmodifiable_collection.dart
|
| +++ b/pkg/collection_helpers/lib/unmodifiable_wrappers.dart
|
| @@ -3,7 +3,7 @@
|
| // BSD-style license that can be found in the LICENSE file.
|
|
|
| /**
|
| - * Wrappers that prevent List, Set, or Map objects from being modified.
|
| + * Wrappers that prevent a List, Set, or Map object from being modified.
|
| *
|
| * The [Set] and [Map] wrappers allow reading from the wrapped collection,
|
| * but prohibit writing.
|
| @@ -11,69 +11,36 @@
|
| * The [List] wrapper prevents changes to the length of the wrapped list,
|
| * but allows changes to the contents.
|
| */
|
| -library unmodifiable_collection;
|
| -
|
| -import "dart:math" show Random;
|
| -export "dart:collection" show UnmodifiableListView;
|
| +part of dart.collection_helpers.wrappers;
|
|
|
| /**
|
| * A fixed-length list.
|
| *
|
| - * A NonGrowableListView contains a [List] object and ensures that
|
| + * A `NonGrowableListView` contains a [List] object and ensures that
|
| * its length does not change.
|
| * Methods that would change the length of the list,
|
| * such as [add] and [remove], throw an [UnsupportedError].
|
| + * All other methods work directly on the underlying list.
|
| *
|
| * This class _does_ allow changes to the contents of the wrapped list.
|
| * You can, for example, [sort] the list.
|
| * Permitted operations defer to the wrapped list.
|
| */
|
| -class NonGrowableListView<E> extends _IterableView<E>
|
| - implements List<E> {
|
| - List<E> _source;
|
| - NonGrowableListView(List<E> source) : _source = source;
|
| +class NonGrowableListView<E> extends DelegatingList<E>
|
| + with NonGrowableListMixin<E> {
|
| + NonGrowableListView(List<E> listBase) : super(listBase);
|
| +}
|
|
|
| +/**
|
| + * Mixin class that implements a throwing version of all list operations that
|
| + * change the List's length.
|
| + */
|
| +abstract class NonGrowableListMixin<E> implements List<E> {
|
| static void _throw() {
|
| throw new UnsupportedError(
|
| "Cannot change the length of a fixed-length list");
|
| }
|
|
|
| - int get length => _source.length;
|
| -
|
| - E operator [](int index) => _source[index];
|
| -
|
| - int indexOf(E element, [int start = 0]) => _source.indexOf(element, start);
|
| -
|
| - int lastIndexOf(E element, [int start])
|
| - => _source.lastIndexOf(element, start);
|
| -
|
| - Iterable<E> getRange(int start, int end) => _source.getRange(start, end);
|
| -
|
| - List<E> sublist(int start, [int end]) => _source.sublist(start, end);
|
| -
|
| - Iterable<E> get reversed => _source.reversed;
|
| -
|
| - Map<int, E> asMap() => _source.asMap();
|
| -
|
| - void operator []=(int index, E value) { _source[index] = value; }
|
| -
|
| - void sort([int compare(E a, E b)]) { _source.sort(compare); }
|
| -
|
| - void shuffle([Random random]) { _source.shuffle(random); }
|
| -
|
| - void setRange(int start, int end, Iterable<E> iterable, [int skipCount = 0]) {
|
| - _source.setRange(start, end, iterable, skipCount);
|
| - }
|
| -
|
| - void fillRange(int start, int end, [E fillValue]) {
|
| - _source.fillRange(start, end, fillValue);
|
| - }
|
| -
|
| - void setAll(int index, Iterable<E> iterable) {
|
| - _source.setAll(index, iterable);
|
| - }
|
| -
|
| -
|
| /**
|
| * Throws an [UnsupportedError];
|
| * operations that change the length of the list are disallowed.
|
| @@ -164,25 +131,20 @@ class NonGrowableListView<E> extends _IterableView<E>
|
| * such as [add] and [remove], throw an [UnsupportedError].
|
| * Permitted operations defer to the wrapped set.
|
| */
|
| -class UnmodifiableSetView<E> extends _IterableView<E>
|
| - implements Set<E> {
|
| - Set<E> _source;
|
| - UnmodifiableSetView(Set<E> source) : _source = source;
|
| +class UnmodifiableSetView<E> extends DelegatingSet<E>
|
| + with UnmodifiableSetMixin<E> {
|
| + UnmodifiableSetView(Set<E> setBase) : super(setBase);
|
| +}
|
|
|
| +/**
|
| + * Mixin class that implements a throwing version of all set operations that
|
| + * change the Set.
|
| + */
|
| +abstract class UnmodifiableSetMixin<E> implements Set<E> {
|
| void _throw() {
|
| throw new UnsupportedError("Cannot modify an unmodifiable Set");
|
| }
|
|
|
| - bool containsAll(Iterable<E> other) => _source.containsAll(other);
|
| -
|
| - Set<E> intersection(Set<E> other) => _source.intersection(other);
|
| -
|
| - Set<E> union(Set<E> other) => _source.union(other);
|
| -
|
| - Set<E> difference(Set<E> other) => _source.difference(other);
|
| -
|
| - E lookup(Object object) => _source.lookup(object);
|
| -
|
| /**
|
| * Throws an [UnsupportedError];
|
| * operations that change the set are disallowed.
|
| @@ -243,33 +205,20 @@ class UnmodifiableSetView<E> extends _IterableView<E>
|
| * such as [addAll] and [remove], throw an [UnsupportedError].
|
| * Permitted operations defer to the wrapped map.
|
| */
|
| -class UnmodifiableMapView<K, V> implements Map<K, V> {
|
| - Map<K, V> _source;
|
| - UnmodifiableMapView(Map<K, V> source) : _source = source;
|
| +class UnmodifiableMapView<K, V> extends DelegatingMap<K, V>
|
| + with UnmodifiableMapMixin<K, V> {
|
| + UnmodifiableMapView(Map<K, V> baseMap) : super(baseMap);
|
| +}
|
|
|
| +/**
|
| + * Mixin class that implements a throwing version of all map operations that
|
| + * change the Map.
|
| + */
|
| +abstract class UnmodifiableMapMixin<K, V> implements Map<K, V> {
|
| static void _throw() {
|
| throw new UnsupportedError("Cannot modify an unmodifiable Map");
|
| }
|
|
|
| - int get length => _source.length;
|
| -
|
| - bool get isEmpty => _source.isEmpty;
|
| -
|
| - bool get isNotEmpty => _source.isNotEmpty;
|
| -
|
| - V operator [](K key) => _source[key];
|
| -
|
| - bool containsKey(K key) => _source.containsKey(key);
|
| -
|
| - bool containsValue(V value) => _source.containsValue(value);
|
| -
|
| - void forEach(void f(K key, V value)) => _source.forEach(f);
|
| -
|
| - Iterable<K> get keys => _source.keys;
|
| -
|
| - Iterable<V> get values => _source.values;
|
| -
|
| -
|
| /**
|
| * Throws an [UnsupportedError];
|
| * operations that change the map are disallowed.
|
| @@ -300,65 +249,3 @@ class UnmodifiableMapView<K, V> implements Map<K, V> {
|
| */
|
| void clear() => _throw();
|
| }
|
| -
|
| -abstract class _IterableView<E> {
|
| - Iterable<E> get _source;
|
| -
|
| - bool any(bool test(E element)) => _source.any(test);
|
| -
|
| - bool contains(E element) => _source.contains(element);
|
| -
|
| - E elementAt(int index) => _source.elementAt(index);
|
| -
|
| - bool every(bool test(E element)) => _source.every(test);
|
| -
|
| - Iterable expand(Iterable f(E element)) => _source.expand(f);
|
| -
|
| - E get first => _source.first;
|
| -
|
| - E firstWhere(bool test(E element), { E orElse() })
|
| - => _source.firstWhere(test, orElse: orElse);
|
| -
|
| - dynamic fold(var initialValue,
|
| - dynamic combine(var previousValue, E element))
|
| - => _source.fold(initialValue, combine);
|
| -
|
| - void forEach(void f(E element)) => _source.forEach(f);
|
| -
|
| - bool get isEmpty => _source.isEmpty;
|
| -
|
| - bool get isNotEmpty => _source.isNotEmpty;
|
| -
|
| - Iterator<E> get iterator => _source.iterator;
|
| -
|
| - String join([String separator = ""]) => _source.join(separator);
|
| -
|
| - E get last => _source.last;
|
| -
|
| - E lastWhere(bool test(E element), {E orElse()})
|
| - => _source.lastWhere(test, orElse: orElse);
|
| -
|
| - int get length => _source.length;
|
| -
|
| - Iterable map(f(E element)) => _source.map(f);
|
| -
|
| - E reduce(E combine(E value, E element)) => _source.reduce(combine);
|
| -
|
| - E get single => _source.single;
|
| -
|
| - E singleWhere(bool test(E element)) => _source.singleWhere(test);
|
| -
|
| - Iterable<E> skip(int n) => _source.skip(n);
|
| -
|
| - Iterable<E> skipWhile(bool test(E value)) => _source.skipWhile(test);
|
| -
|
| - Iterable<E> take(int n) => _source.take(n);
|
| -
|
| - Iterable<E> takeWhile(bool test(E value)) => _source.takeWhile(test);
|
| -
|
| - List<E> toList({ bool growable: true }) => _source.toList(growable: growable);
|
| -
|
| - Set<E> toSet() => _source.toSet();
|
| -
|
| - Iterable<E> where(bool test(E element)) => _source.where(test);
|
| -}
|
|
|