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

Side by Side Diff: lib/src/delegate/sink.dart

Issue 2660333005: Change generic comment syntax to real generic syntax. (Closed)
Patch Set: Created 3 years, 10 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 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. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 /// Simple delegating wrapper around a [Sink]. 5 /// Simple delegating wrapper around a [Sink].
6 /// 6 ///
7 /// Subclasses can override individual methods, or use this to expose only the 7 /// Subclasses can override individual methods, or use this to expose only the
8 /// [Sink] methods of a subclass. 8 /// [Sink] methods of a subclass.
9 class DelegatingSink<T> implements Sink<T> { 9 class DelegatingSink<T> implements Sink<T> {
10 final Sink _sink; 10 final Sink _sink;
11 11
12 /// Create a delegating sink forwarding calls to [sink]. 12 /// Create a delegating sink forwarding calls to [sink].
13 DelegatingSink(Sink<T> sink) : _sink = sink; 13 DelegatingSink(Sink<T> sink) : _sink = sink;
14 14
15 DelegatingSink._(this._sink); 15 DelegatingSink._(this._sink);
16 16
17 /// Creates a wrapper that coerces the type of [sink]. 17 /// Creates a wrapper that coerces the type of [sink].
18 /// 18 ///
19 /// Unlike [new DelegatingSink], this only requires its argument to be an 19 /// Unlike [new DelegatingSink], this only requires its argument to be an
20 /// instance of `Sink`, not `Sink<T>`. This means that calls to [add] may 20 /// instance of `Sink`, not `Sink<T>`. This means that calls to [add] may
21 /// throw a [CastError] if the argument type doesn't match the reified type of 21 /// throw a [CastError] if the argument type doesn't match the reified type of
22 /// [sink]. 22 /// [sink].
23 static Sink/*<T>*/ typed/*<T>*/(Sink sink) => 23 static Sink<T> typed<T>(Sink sink) => sink is Sink<T>
24 sink is Sink/*<T>*/ ? sink : new DelegatingSink._(sink); 24 ? sink
25 : new DelegatingSink._(sink);
25 26
26 void add(T data) { 27 void add(T data) {
27 _sink.add(data); 28 _sink.add(data);
28 } 29 }
29 30
30 void close() { 31 void close() {
31 _sink.close(); 32 _sink.close();
32 } 33 }
33 } 34 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698