| Index: pkg/barback/lib/src/cancelable_future.dart
|
| diff --git a/pkg/barback/lib/src/cancelable_future.dart b/pkg/barback/lib/src/cancelable_future.dart
|
| deleted file mode 100644
|
| index 84c19f148e605903d8d9be13e38972f70f12248a..0000000000000000000000000000000000000000
|
| --- a/pkg/barback/lib/src/cancelable_future.dart
|
| +++ /dev/null
|
| @@ -1,41 +0,0 @@
|
| -// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
|
| -// for details. All rights reserved. Use of this source code is governed by a
|
| -// BSD-style license that can be found in the LICENSE file.
|
| -
|
| -library barback.cancelable_future;
|
| -
|
| -import 'dart:async';
|
| -
|
| -/// A wrapper for [Future] that can be cancelled.
|
| -///
|
| -/// When this is cancelled, that means it won't complete either successfully or
|
| -/// with an error, regardless of whether the wrapped Future completes.
|
| -/// Cancelling this won't stop whatever code is feeding the wrapped future from
|
| -/// running.
|
| -class CancelableFuture<T> implements Future<T> {
|
| - bool _canceled = false;
|
| - final _completer = new Completer<T>();
|
| -
|
| - CancelableFuture(Future<T> inner) {
|
| - inner.then((result) {
|
| - if (_canceled) return;
|
| - _completer.complete(result);
|
| - }).catchError((error, stackTrace) {
|
| - if (_canceled) return;
|
| - _completer.completeError(error, stackTrace);
|
| - });
|
| - }
|
| -
|
| - Stream<T> asStream() => _completer.future.asStream();
|
| - Future catchError(Function onError, {bool test(error)}) =>
|
| - _completer.future.catchError(onError, test: test);
|
| - Future then(onValue(T value), {Function onError}) =>
|
| - _completer.future.then(onValue, onError: onError);
|
| - Future<T> whenComplete(action()) => _completer.future.whenComplete(action);
|
| - Future timeout(Duration timeLimit, {void onTimeout()}) =>
|
| - _completer.future.timeout(timeLimit, onTimeout: onTimeout);
|
| - /// Cancels this future.
|
| - void cancel() {
|
| - _canceled = true;
|
| - }
|
| -}
|
|
|