blob: 8aa2c6287e8e6eb1c1c74d24304b66fa49af8878 [file] [log] [blame]
// 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 value_future;
import 'dart:async';
/// A [Future] wrapper that provides synchronous access to the value of the
/// wrapped [Future] once it's completed.
class ValueFuture<T> implements Future<T> {
/// The wrapped [Future].
Future<T> _future;
/// The [value] of the wrapped [Future], if it's completed succesfully. If it
/// hasn't completed yet or has completed with an error, this will be `null`.
T get value => _value;
T _value;
/// Whether the wrapped [Future] has completed successfully.
bool get hasValue => _hasValue;
var _hasValue = false;
ValueFuture(Future<T> future) {
_future = future.then((value) {
_value = value;
_hasValue = true;
return value;
});
}
Stream<T> asStream() => _future.asStream();
Future catchError(onError(Object error), {bool test(error)}) =>
_future.catchError(onError, test: test);
Future then(onValue(T value), {onError(Object error)}) =>
_future.then(onValue, onError: onError);
Future<T> whenComplete(action()) => _future.whenComplete(action);
}