OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 library barback.asset_forwarder; | 5 library barback.asset.asset_forwarder; |
6 | 6 |
7 import 'dart:async'; | 7 import 'dart:async'; |
8 | 8 |
9 import 'asset_node.dart'; | 9 import 'asset_node.dart'; |
10 | 10 |
11 /// A wrapper for an [AssetNode] that forwards events to a new node. | 11 /// A wrapper for an [AssetNode] that forwards events to a new node. |
12 /// | 12 /// |
13 /// A forwarder is used when a class wants to forward an [AssetNode] that it | 13 /// A forwarder is used when a class wants to forward an [AssetNode] that it |
14 /// gets as an input, but also wants to have control over when that node is | 14 /// gets as an input, but also wants to have control over when that node is |
15 /// marked as removed. The forwarder can be closed, thus removing its output | 15 /// marked as removed. The forwarder can be closed, thus removing its output |
(...skipping 24 matching lines...) Expand all Loading... |
40 }); | 40 }); |
41 } | 41 } |
42 | 42 |
43 /// Closes the forwarder and marks [node] as removed. | 43 /// Closes the forwarder and marks [node] as removed. |
44 void close() { | 44 void close() { |
45 if (_controller.node.state.isRemoved) return; | 45 if (_controller.node.state.isRemoved) return; |
46 _subscription.cancel(); | 46 _subscription.cancel(); |
47 _controller.setRemoved(); | 47 _controller.setRemoved(); |
48 } | 48 } |
49 } | 49 } |
OLD | NEW |