Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(706)

Unified Diff: sdk/lib/collection/collections.dart

Issue 14173003: Remove Collection, Collections and clean up List/Set/Queue implementations of retain/remove. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: sdk/lib/collection/collections.dart
diff --git a/sdk/lib/collection/collections.dart b/sdk/lib/collection/collections.dart
index 2ff2228cc4a69c6877e069b990a345ce0ef9ccf5..400ce90482e9fe861b060f9c9353f0e828bc9e90 100644
--- a/sdk/lib/collection/collections.dart
+++ b/sdk/lib/collection/collections.dart
@@ -59,71 +59,6 @@ class IterableMixinWorkaround {
}
/**
- * Simple implementation for [Collection.removeAll].
- *
- * This implementation assumes that [Collection.remove] on [collection]
- * is efficient. The [:remove:] method on [List] objects is typically
- * not efficient since it requires linear search to find an element.
- */
- static void removeAll(Collection collection, Iterable elementsToRemove) {
- for (Object object in elementsToRemove) {
- collection.remove(object);
- }
- }
-
- /**
- * Implementation of [Collection.removeAll] for lists.
- *
- * This implementation assumes that [Collection.remove] is not efficient
- * (as it usually isn't on a [List]) and uses [Collection.removeMathcing]
- * instead of just repeatedly calling remove.
- */
- static void removeAllList(Collection collection, Iterable elementsToRemove) {
- Set setToRemove;
- // Assume [contains] is efficient on a Set.
- if (elementsToRemove is Set) {
- setToRemove = elementsToRemove;
- } else {
- setToRemove = elementsToRemove.toSet();
- }
- collection.removeWhere(setToRemove.contains);
- }
-
- /**
- * Simple implemenation for [Collection.retainAll].
- *
- * This implementation assumes that [Collecton.retainWhere] on [collection]
- * is efficient.
- */
- static void retainAll(Collection collection, Iterable elementsToRetain) {
- Set lookup;
- if (elementsToRetain is Set) {
- lookup = elementsToRetain;
- } else {
- lookup = elementsToRetain.toSet();
- }
- if (lookup.isEmpty) {
- collection.clear();
- return;
- }
- collection.retainWhere(lookup.contains);
- }
-
- /**
- * Simple implemenation for [Collection.removeWhere].
- *
- * This implementation assumes that [Collecton.removeAll] on [collection] is
- * efficient.
- */
- static void removeWhere(Collection collection, bool test(var element)) {
- List elementsToRemove = [];
- for (var element in collection) {
- if (test(element)) elementsToRemove.add(element);
- }
- collection.removeAll(elementsToRemove);
- }
-
- /**
* Removes elements matching [test] from [list].
*
* This is performed in two steps, to avoid exposing an inconsistent state
@@ -149,20 +84,6 @@ class IterableMixinWorkaround {
}
}
- /**
- * Simple implemenation for [Collection.retainWhere].
- *
- * This implementation assumes that [Collecton.removeAll] on [collection] is
- * efficient.
- */
- static void retainWhere(Collection collection, bool test(var element)) {
- List elementsToRemove = [];
- for (var element in collection) {
- if (!test(element)) elementsToRemove.add(element);
- }
- collection.removeAll(elementsToRemove);
- }
-
static bool isEmpty(Iterable iterable) {
return !iterable.iterator.moveNext();
}
@@ -187,32 +108,6 @@ class IterableMixinWorkaround {
return result;
}
- static dynamic min(Iterable iterable, [int compare(var a, var b)]) {
- if (compare == null) compare = Comparable.compare;
- Iterator it = iterable.iterator;
- if (!it.moveNext()) {
- return null;
- }
- var min = it.current;
- while (it.moveNext()) {
- if (compare(min, it.current) > 0) min = it.current;
- }
- return min;
- }
-
- static dynamic max(Iterable iterable, [int compare(var a, var b)]) {
- if (compare == null) compare = Comparable.compare;
- Iterator it = iterable.iterator;
- if (!it.moveNext()) {
- return null;
- }
- var max = it.current;
- while (it.moveNext()) {
- if (compare(max, it.current) < 0) max = it.current;
- }
- return max;
- }
-
static dynamic single(Iterable iterable) {
Iterator it = iterable.iterator;
if (!it.moveNext()) throw new StateError("No elements");
@@ -432,11 +327,6 @@ class IterableMixinWorkaround {
}
}
-class Collections {
- static String collectionToString(Collection c)
- => ToString.collectionToString(c);
-}
-
/**
* An unmodifiable [List] view of another List.
*
« no previous file with comments | « sdk/lib/_internal/compiler/implementation/universe/function_set.dart ('k') | sdk/lib/collection/hash_set.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698