OLD | NEW |
(Empty) | |
| 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 |
| 3 // BSD-style license that can be found in the LICENSE file. |
| 4 |
| 5 library barback.utils.cancelable_future; |
| 6 |
| 7 import 'dart:async'; |
| 8 |
| 9 /// A wrapper for [Future] that can be cancelled. |
| 10 /// |
| 11 /// When this is cancelled, that means it won't complete either successfully or |
| 12 /// with an error, regardless of whether the wrapped Future completes. |
| 13 /// Cancelling this won't stop whatever code is feeding the wrapped future from |
| 14 /// running. |
| 15 class CancelableFuture<T> implements Future<T> { |
| 16 bool _canceled = false; |
| 17 final _completer = new Completer<T>.sync(); |
| 18 |
| 19 CancelableFuture(Future<T> inner) { |
| 20 inner.then((result) { |
| 21 if (_canceled) return; |
| 22 _completer.complete(result); |
| 23 }).catchError((error, stackTrace) { |
| 24 if (_canceled) return; |
| 25 _completer.completeError(error, stackTrace); |
| 26 }); |
| 27 } |
| 28 |
| 29 Stream<T> asStream() => _completer.future.asStream(); |
| 30 Future catchError(Function onError, {bool test(error)}) => |
| 31 _completer.future.catchError(onError, test: test); |
| 32 Future then(onValue(T value), {Function onError}) => |
| 33 _completer.future.then(onValue, onError: onError); |
| 34 Future<T> whenComplete(action()) => _completer.future.whenComplete(action); |
| 35 Future timeout(Duration timeLimit, {void onTimeout()}) => |
| 36 _completer.future.timeout(timeLimit, onTimeout: onTimeout); |
| 37 /// Cancels this future. |
| 38 void cancel() { |
| 39 _canceled = true; |
| 40 } |
| 41 } |
OLD | NEW |