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

Side by Side Diff: sdk/lib/core/future.dart

Issue 11293132: Add a Futures.forEach function for asynchronously iterating over a collection. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | tests/corelib/futures_test.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 /** 5 /**
6 * A [Future] is used to obtain a value sometime in the future. Receivers of a 6 * A [Future] is used to obtain a value sometime in the future. Receivers of a
7 * [Future] can obtain the value by passing a callback to [then]. For example: 7 * [Future] can obtain the value by passing a callback to [then]. For example:
8 * 8 *
9 * Future<int> future = getFutureFromSomewhere(); 9 * Future<int> future = getFutureFromSomewhere();
10 * future.then((value) { 10 * future.then((value) {
(...skipping 241 matching lines...) Expand 10 before | Expand all | Expand 10 after
252 }); 252 });
253 future.handleException((exception) { 253 future.handleException((exception) {
254 if (!result.isComplete) { 254 if (!result.isComplete) {
255 completer.completeException(exception, future.stackTrace); 255 completer.completeException(exception, future.stackTrace);
256 } 256 }
257 return true; 257 return true;
258 }); 258 });
259 } 259 }
260 return result; 260 return result;
261 } 261 }
262
263 /// Runs [fn] for each element in [input] in order, moving to the next element
Siggi Cherem (dart-lang) 2012/11/06 23:23:51 nit: use /** */ docs (for consistency)
nweiz 2012/11/07 20:50:07 Done.
264 /// only when the [Future] returned by [fn] completes. Returns a [Future] that
265 /// completes when all elements have been processed.
266 ///
267 /// The return values of all [Future]s are discarded. Any errors will cause th e
Siggi Cherem (dart-lang) 2012/11/06 23:23:51 nit 80 col
Bob Nystrom 2012/11/07 01:09:43 Pub doesn't need a return value, but to be more ge
nweiz 2012/11/07 20:50:07 Done.
nweiz 2012/11/07 20:50:07 I liked this idea when you first proposed it, but
Bob Nystrom 2012/11/07 21:34:05 SGTM.
268 /// iteration to stop and will be piped through the return value.
Siggi Cherem (dart-lang) 2012/11/06 23:23:51 to avoid confusion with the returned values above,
nweiz 2012/11/07 20:50:07 Done.
269 static Future forEach(Iterable input, Future fn(element)) {
Siggi Cherem (dart-lang) 2012/11/06 23:23:51 nit: rename fn as f? (trying to match the signatur
nweiz 2012/11/07 20:50:07 Done.
270 var iterator = input.iterator();
271 Future nextElement(_) {
272 if (!iterator.hasNext) return new Future.immediate(null);
273 return fn(iterator.next()).chain(nextElement);
274 }
275 return nextElement(null);
276 }
262 } 277 }
OLDNEW
« no previous file with comments | « no previous file | tests/corelib/futures_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698