OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 library substitute_future; | 5 library substitute_future; |
6 | 6 |
7 import 'dart:async'; | 7 import 'dart:async'; |
8 | 8 |
9 /// A wrapper for [Future] that allows other [Future]s to be substituted in as | 9 /// A wrapper for [Future] that allows other [Future]s to be substituted in as |
10 /// the wrapped [Future]. This is used for injecting timeout errors into | 10 /// the wrapped [Future]. This is used for injecting timeout errors into |
(...skipping 11 matching lines...) Expand all Loading... |
22 SubstituteFuture(Future wrapped) { | 22 SubstituteFuture(Future wrapped) { |
23 substitute(wrapped); | 23 substitute(wrapped); |
24 } | 24 } |
25 | 25 |
26 Stream<T> asStream() => _completer.future.asStream(); | 26 Stream<T> asStream() => _completer.future.asStream(); |
27 Future catchError(Function onError, {bool test(error)}) => | 27 Future catchError(Function onError, {bool test(error)}) => |
28 _completer.future.catchError(onError, test: test); | 28 _completer.future.catchError(onError, test: test); |
29 Future then(onValue(T value), {Function onError}) => | 29 Future then(onValue(T value), {Function onError}) => |
30 _completer.future.then(onValue, onError: onError); | 30 _completer.future.then(onValue, onError: onError); |
31 Future<T> whenComplete(action()) => _completer.future.whenComplete(action); | 31 Future<T> whenComplete(action()) => _completer.future.whenComplete(action); |
| 32 Future timeout(Duration timeLimit, [void onTimeout()]) => |
| 33 _completer.future.timeout(timeLimit, onTimeout); |
32 | 34 |
33 /// Substitutes [newFuture] for the currently wrapped [Future], which is | 35 /// Substitutes [newFuture] for the currently wrapped [Future], which is |
34 /// returned. | 36 /// returned. |
35 Future<T> substitute(Future<T> newFuture) { | 37 Future<T> substitute(Future<T> newFuture) { |
36 if (_complete) { | 38 if (_complete) { |
37 throw new StateError("You may not call substitute on a SubstituteFuture " | 39 throw new StateError("You may not call substitute on a SubstituteFuture " |
38 "that's already complete."); | 40 "that's already complete."); |
39 } | 41 } |
40 | 42 |
41 var oldFuture = _inner; | 43 var oldFuture = _inner; |
42 _inner = newFuture; | 44 _inner = newFuture; |
43 _inner.then((value) { | 45 _inner.then((value) { |
44 if (_inner != newFuture) return; | 46 if (_inner != newFuture) return; |
45 _completer.complete(value); | 47 _completer.complete(value); |
46 _complete = true; | 48 _complete = true; |
47 }).catchError((error, stackTrace) { | 49 }).catchError((error, stackTrace) { |
48 if (_inner != newFuture) return; | 50 if (_inner != newFuture) return; |
49 _completer.completeError(error, stackTrace); | 51 _completer.completeError(error, stackTrace); |
50 _complete = true; | 52 _complete = true; |
51 }); | 53 }); |
52 return oldFuture; | 54 return oldFuture; |
53 } | 55 } |
54 } | 56 } |
OLD | NEW |