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

Unified Diff: lib/core/collection.dart

Issue 11169004: Add "contains" method to Collection. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fixed last illegal-access Created 8 years, 2 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
« no previous file with comments | « lib/compiler/implementation/lib/interceptors.dart ('k') | lib/core/core.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: lib/core/collection.dart
diff --git a/lib/core/collection.dart b/lib/core/collection.dart
index ffad48d6c76913e76bb79efee8548fc3708b6b72..22381ab1e051e2e7a9963e7dea6b45212c557ec9 100644
--- a/lib/core/collection.dart
+++ b/lib/core/collection.dart
@@ -3,26 +3,57 @@
// BSD-style license that can be found in the LICENSE file.
/**
- * The [Collection] interface is the public interface of all
- * collections.
+ * The common interface of all collections.
+ *
+ * The [Collection] class contains a skeleton implementation of
+ * an iterator based collection.
*/
abstract class Collection<E> extends Iterable<E> {
/**
- * Applies the function [f] to each element of this collection.
- */
- void forEach(void f(E element));
-
- /**
* Returns a new collection with the elements [: f(e) :]
* for each element [:e:] of this collection.
*
- * Note on typing: the return type of f() could be an arbitrary
- * type and consequently the returned collection's
- * typeis Collection.
+ * Subclasses of [Collection] should implement the [map] method
+ * to return a collection of the same general type as themselves.
+ * E.g., [List.map] should return a [List].
*/
Collection map(f(E element));
/**
+ * Returns a collection with the elements of this collection
+ * that satisfy the predicate [f].
+ *
+ * The returned collection should be of the same type as the collection
+ * creating it.
+ *
+ * An element satisfies the predicate [f] if [:f(element):]
+ * returns true.
+ */
+ Collection<E> filter(bool f(E element));
+
+ /**
+ * Returns the number of elements in this collection.
+ */
+ int get length;
+
+ /**
+ * Check whether the collection contains an element equal to [element].
+ */
+ bool contains(E element) {
+ for (E e in this) {
+ if (e == element) return true;
+ }
+ return false;
+ }
+
+ /**
+ * Applies the function [f] to each element of this collection.
+ */
+ void forEach(void f(E element)) {
+ for (E element in this) f(element);
+ }
+
+ /**
* Reduce a collection to a single value by iteratively combining each element
* of the collection with an existing value using the provided function.
* Use [initialValue] as the initial value, and the function [combine] to
@@ -32,37 +63,37 @@ abstract class Collection<E> extends Iterable<E> {
*
* collection.reduce(0, (prev, element) => prev + element);
*/
- Dynamic reduce(Dynamic initialValue,
- Dynamic combine(Dynamic previousValue, E element));
-
- /**
- * Returns a new collection with the elements of this collection
- * that satisfy the predicate [f].
- *
- * An element satisfies the predicate [f] if [:f(element):]
- * returns true.
- */
- Collection<E> filter(bool f(E element));
+ Dynamic reduce(var initialValue,
+ Dynamic combine(var previousValue, E element)) {
+ var value = initialValue;
+ for (E element in this) value = combine(value, element);
+ return value;
+ }
/**
* Returns true if every elements of this collection satisify the
* predicate [f]. Returns false otherwise.
*/
- bool every(bool f(E element));
+ bool every(bool f(E element)) {
+ for (E element in this) {
+ if (!f(element)) return false;
+ }
+ return true;
+ }
/**
* Returns true if one element of this collection satisfies the
* predicate [f]. Returns false otherwise.
*/
- bool some(bool f(E element));
+ bool some(bool f(E element)) {
+ for (E element in this) {
+ if (f(element)) return true;
+ }
+ return false;
+ }
/**
* Returns true if there is no element in this collection.
*/
- bool isEmpty();
-
- /**
- * Returns the number of elements in this collection.
- */
- int get length;
+ bool isEmpty() => !iterator().hasNext();
}
« no previous file with comments | « lib/compiler/implementation/lib/interceptors.dart ('k') | lib/core/core.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698