Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1459)

Unified Diff: lib/src/delegate/stream.dart

Issue 1870543004: Add typed wrapper functions to delegate classes. (Closed) Base URL: git@github.com:dart-lang/async.git@master
Patch Set: Code review changes Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: lib/src/delegate/stream.dart
diff --git a/lib/src/delegate/stream.dart b/lib/src/delegate/stream.dart
new file mode 100644
index 0000000000000000000000000000000000000000..75622187d252884d12587de21a0905dd08e2f7d0
--- /dev/null
+++ b/lib/src/delegate/stream.dart
@@ -0,0 +1,28 @@
+// Copyright (c) 2016, 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.
+
+import 'dart:async';
+
+import '../typed/stream.dart';
+
+/// Simple delegating wrapper around a [Stream].
+///
+/// Subclasses can override individual methods, or use this to expose only the
+/// [Stream] methods of a subclass.
+///
+/// Note that this is identical to [StreamView] in `dart:async`. It's provided
+/// under this name for consistency with other `Delegating*` classes.
+class DelegatingStream<T> extends StreamView<T> {
+ DelegatingStream(Stream<T> stream) : super(stream);
+
+ /// Creates a wrapper which throws if [stream]'s events aren't instances of
+ /// `T`.
+ ///
+ /// This soundly converts a [Stream] to a `Stream<T>`, regardless of its
+ /// original generic type, by asserting that its events are instances of `T`
+ /// whenever they're provided. If they're not, the stream throws a
+ /// [CastError].
+ static Stream/*<T>*/ typed/*<T>*/(Stream stream) =>
+ stream is Stream/*<T>*/ ? stream : new TypeSafeStream/*<T>*/(stream);
+}

Powered by Google App Engine
This is Rietveld 408576698