| Index: runtime/bin/socket_stream.dart
|
| diff --git a/runtime/bin/socket_stream.dart b/runtime/bin/socket_stream.dart
|
| index e3d0d725a3fae66337efbfd6e6965932ad4a6034..57e6e998d235f57bb7486ed60dbef8d271d50100 100644
|
| --- a/runtime/bin/socket_stream.dart
|
| +++ b/runtime/bin/socket_stream.dart
|
| @@ -3,9 +3,7 @@
|
| // BSD-style license that can be found in the LICENSE file.
|
|
|
| class SocketInputStream implements InputStream {
|
| - SocketInputStream(Socket socket) {
|
| - _socket = socket;
|
| - }
|
| + SocketInputStream(Socket socket) : _socket = socket;
|
|
|
| List<int> read([int len]) {
|
| int bytesToRead = available();
|
| @@ -56,10 +54,7 @@ class SocketInputStream implements InputStream {
|
|
|
| class SocketOutputStream implements OutputStream {
|
| SocketOutputStream(Socket socket)
|
| - : _socket = socket, _pendingWrites = new _BufferList() {
|
| - _socket.writeHandler = _writeHandler;
|
| - _socket.errorHandler = _errorHandler;
|
| - }
|
| + : _socket = socket, _pendingWrites = new _BufferList();
|
|
|
| bool write(List<int> buffer, [bool copyBuffer = true]) {
|
| return _write(buffer, 0, buffer.length, copyBuffer);
|
| @@ -91,7 +86,9 @@ class SocketOutputStream implements OutputStream {
|
|
|
| void set noPendingWriteHandler(void callback()) {
|
| _noPendingWriteHandler = callback;
|
| - _socket.writeHandler = _writeHandler;
|
| + if (_noPendingWriteHandler != null) {
|
| + _socket.writeHandler = _writeHandler;
|
| + }
|
| }
|
|
|
| void set closeHandler(void callback()) {
|
| @@ -100,6 +97,11 @@ class SocketOutputStream implements OutputStream {
|
|
|
| void set errorHandler(void callback()) {
|
| _streamErrorHandler = callback;
|
| + if (_streamErrorHandler != null) {
|
| + _socket.errorHandler = _errorHandler;
|
| + } else {
|
| + _socket.errorHandler = null;
|
| + }
|
| }
|
|
|
| bool _write(List<int> buffer, int offset, int len, bool copyBuffer) {
|
| @@ -122,6 +124,7 @@ class SocketOutputStream implements OutputStream {
|
| assert(offset + len == buffer.length);
|
| _pendingWrites.add(buffer, notWrittenOffset);
|
| }
|
| + _socket.writeHandler = _writeHandler;
|
| }
|
|
|
| void _writeHandler() {
|
| @@ -145,6 +148,7 @@ class SocketOutputStream implements OutputStream {
|
| } else {
|
| if (_noPendingWriteHandler != null) _noPendingWriteHandler();
|
| }
|
| + if (_noPendingWriteHandler == null) _socket.writeHandler = null;
|
| }
|
|
|
| void _errorHandler() {
|
|
|