Chromium Code Reviews| Index: lib/src/delegate/stream_sink.dart |
| diff --git a/lib/src/delegate/stream_sink.dart b/lib/src/delegate/stream_sink.dart |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9742b4ce066a115b12badf2f873fc5bae9693884 |
| --- /dev/null |
| +++ b/lib/src/delegate/stream_sink.dart |
| @@ -0,0 +1,30 @@ |
| +// Copyright (c) 2015, 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 async.delegate.stream_sink; |
| + |
| +import 'dart:async'; |
| + |
| +/// Simple delegating wrapper around a [StreamSink]. |
| +/// |
| +/// Subclasses can override individual methods, or use this to expose only the |
| +/// [StreamSink] methods of a subclass. |
| +class DelegatingStreamSink<T> implements StreamSink<T> { |
|
Lasse Reichstein Nielsen
2015/07/02 09:38:39
If this was in the same package, you could extend
nweiz
2015/07/06 20:40:30
Yeah, I thought about doing that, but it seemed mo
|
| + final StreamSink _sink; |
| + |
| + Future get done => _sink.done; |
| + |
| + /// Create delegating sink forwarding calls to [sink]. |
| + DelegatingStreamSink(StreamSink sink) |
| + : _sink = sink; |
| + |
| + void add(T data) => _sink.add(data); |
| + |
| + void addError(error, [StackTrace stackTrace]) => |
| + _sink.addError(error, stackTrace); |
| + |
| + Future addStream(Stream<T> stream) => _sink.addStream(stream); |
| + |
| + Future close() => _sink.close(); |
| +} |