OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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 part of dart.async; | 5 part of dart.async; |
6 | 6 |
7 // ------------------------------------------------------------------- | 7 // ------------------------------------------------------------------- |
8 // Controller for creating and adding events to a stream. | 8 // Controller for creating and adding events to a stream. |
9 // ------------------------------------------------------------------- | 9 // ------------------------------------------------------------------- |
10 | 10 |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 bool get hasListener => stream._hasListener; | 104 bool get hasListener => stream._hasListener; |
105 | 105 |
106 /** | 106 /** |
107 * Send or queue a data event. | 107 * Send or queue a data event. |
108 */ | 108 */ |
109 void add(T value) => stream._add(value); | 109 void add(T value) => stream._add(value); |
110 | 110 |
111 /** | 111 /** |
112 * Send or enqueue an error event. | 112 * Send or enqueue an error event. |
113 * | 113 * |
114 * If [error] is not an [AsyncError], [error] and an optional [stackTrace] | |
115 * is combined into an [AsyncError] and sent this stream's listeners. | |
116 * | |
117 * Otherwise, if [error] is an [AsyncError], it is used directly as the | |
118 * error object reported to listeners, and the [stackTrace] is ignored. | |
119 * | |
120 * If a subscription has requested to be unsubscribed on errors, | 114 * If a subscription has requested to be unsubscribed on errors, |
121 * it will be unsubscribed after receiving this event. | 115 * it will be unsubscribed after receiving this event. |
122 */ | 116 */ |
123 void addError(Object error, [Object stackTrace]) { | 117 void addError(Object error, [Object stackTrace]) { |
124 AsyncError asyncError; | 118 if (stackTrace != null) { |
125 if (error is AsyncError) { | 119 // Force stack trace overwrite. Even if the error already contained |
126 asyncError = error; | 120 // a stack trace. |
127 } else { | 121 _attachStackTrace(error, stackTrace); |
128 asyncError = new AsyncError(error, stackTrace); | |
129 } | 122 } |
130 stream._addError(asyncError); | 123 stream._addError(error); |
131 } | 124 } |
132 | 125 |
133 /** | 126 /** |
134 * Send or enqueue a "done" message. | 127 * Send or enqueue a "done" message. |
135 * | 128 * |
136 * The "done" message should be sent at most once by a stream, and it | 129 * The "done" message should be sent at most once by a stream, and it |
137 * should be the last message sent. | 130 * should be the last message sent. |
138 */ | 131 */ |
139 void close() { stream._close(); } | 132 void close() { stream._close(); } |
140 } | 133 } |
141 | 134 |
142 typedef void _NotificationHandler(); | 135 typedef void _NotificationHandler(); |
143 | 136 |
144 class _MultiControllerStream<T> extends _MultiStreamImpl<T> { | 137 class _MultiControllerStream<T> extends _MultiStreamImpl<T> { |
145 _NotificationHandler _subscriptionHandler; | 138 _NotificationHandler _subscriptionHandler; |
146 _NotificationHandler _pauseHandler; | 139 _NotificationHandler _pauseHandler; |
147 | 140 |
148 _MultiControllerStream(this._subscriptionHandler, this._pauseHandler); | 141 _MultiControllerStream(this._subscriptionHandler, this._pauseHandler); |
149 | 142 |
150 void _onSubscriptionStateChange() { | 143 void _onSubscriptionStateChange() { |
151 if (_subscriptionHandler != null) { | 144 if (_subscriptionHandler != null) { |
152 try { | 145 try { |
153 _subscriptionHandler(); | 146 _subscriptionHandler(); |
154 } catch (e, s) { | 147 } catch (e, s) { |
155 new AsyncError(e, s).throwDelayed(); | 148 _throwDelayed(e, s); |
156 } | 149 } |
157 } | 150 } |
158 } | 151 } |
159 | 152 |
160 void _onPauseStateChange() { | 153 void _onPauseStateChange() { |
161 if (_pauseHandler != null) { | 154 if (_pauseHandler != null) { |
162 try { | 155 try { |
163 _pauseHandler(); | 156 _pauseHandler(); |
164 } catch (e, s) { | 157 } catch (e, s) { |
165 new AsyncError(e, s).throwDelayed(); | 158 _throwDelayed(e, s); |
166 } | 159 } |
167 } | 160 } |
168 } | 161 } |
169 } | 162 } |
170 | 163 |
171 class _SingleControllerStream<T> extends _SingleStreamImpl<T> { | 164 class _SingleControllerStream<T> extends _SingleStreamImpl<T> { |
172 _NotificationHandler _subscriptionHandler; | 165 _NotificationHandler _subscriptionHandler; |
173 _NotificationHandler _pauseHandler; | 166 _NotificationHandler _pauseHandler; |
174 | 167 |
175 _SingleControllerStream(this._subscriptionHandler, this._pauseHandler); | 168 _SingleControllerStream(this._subscriptionHandler, this._pauseHandler); |
176 | 169 |
177 void _onSubscriptionStateChange() { | 170 void _onSubscriptionStateChange() { |
178 if (_subscriptionHandler != null) { | 171 if (_subscriptionHandler != null) { |
179 try { | 172 try { |
180 _subscriptionHandler(); | 173 _subscriptionHandler(); |
181 } catch (e, s) { | 174 } catch (e, s) { |
182 new AsyncError(e, s).throwDelayed(); | 175 _throwDelayed(e, s); |
183 } | 176 } |
184 } | 177 } |
185 } | 178 } |
186 | 179 |
187 void _onPauseStateChange() { | 180 void _onPauseStateChange() { |
188 if (_pauseHandler != null) { | 181 if (_pauseHandler != null) { |
189 try { | 182 try { |
190 _pauseHandler(); | 183 _pauseHandler(); |
191 } catch (e, s) { | 184 } catch (e, s) { |
192 new AsyncError(e, s).throwDelayed(); | 185 _throwDelayed(e, s); |
193 } | 186 } |
194 } | 187 } |
195 } | 188 } |
196 } | 189 } |
OLD | NEW |