| 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 patch class RawServerSocket { | 5 patch class RawServerSocket { |
| 6 /* patch */ static Future<RawServerSocket> bind(address, | 6 /* patch */ static Future<RawServerSocket> bind(address, |
| 7 int port, | 7 int port, |
| 8 {int backlog: 0, | 8 {int backlog: 0, |
| 9 bool v6Only: false}) { | 9 bool v6Only: false}) { |
| 10 return _RawServerSocket.bind(address, port, backlog, v6Only); | 10 return _RawServerSocket.bind(address, port, backlog, v6Only); |
| (...skipping 1163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1174 Future<Socket> addStream(Stream<List<int>> stream) { | 1174 Future<Socket> addStream(Stream<List<int>> stream) { |
| 1175 socket._ensureRawSocketSubscription(); | 1175 socket._ensureRawSocketSubscription(); |
| 1176 streamCompleter = new Completer<Socket>(); | 1176 streamCompleter = new Completer<Socket>(); |
| 1177 if (socket._raw != null) { | 1177 if (socket._raw != null) { |
| 1178 subscription = stream.listen( | 1178 subscription = stream.listen( |
| 1179 (data) { | 1179 (data) { |
| 1180 assert(!paused); | 1180 assert(!paused); |
| 1181 assert(buffer == null); | 1181 assert(buffer == null); |
| 1182 buffer = data; | 1182 buffer = data; |
| 1183 offset = 0; | 1183 offset = 0; |
| 1184 write(); | 1184 try { |
| 1185 write(); |
| 1186 } catch (e) { |
| 1187 stop(); |
| 1188 socket._consumerDone(); |
| 1189 done(e); |
| 1190 } |
| 1185 }, | 1191 }, |
| 1186 onError: (error, [stackTrace]) { | 1192 onError: (error, [stackTrace]) { |
| 1187 socket._consumerDone(); | 1193 socket._consumerDone(); |
| 1188 done(error, stackTrace); | 1194 done(error, stackTrace); |
| 1189 }, | 1195 }, |
| 1190 onDone: () { | 1196 onDone: () { |
| 1191 done(); | 1197 done(); |
| 1192 }, | 1198 }, |
| 1193 cancelOnError: true); | 1199 cancelOnError: true); |
| 1194 } | 1200 } |
| 1195 return streamCompleter.future; | 1201 return streamCompleter.future; |
| 1196 } | 1202 } |
| 1197 | 1203 |
| 1198 Future<Socket> close() { | 1204 Future<Socket> close() { |
| 1199 socket._consumerDone(); | 1205 socket._consumerDone(); |
| 1200 return new Future.value(socket); | 1206 return new Future.value(socket); |
| 1201 } | 1207 } |
| 1202 | 1208 |
| 1203 void write() { | 1209 void write() { |
| 1204 try { | 1210 if (subscription == null) return; |
| 1205 if (subscription == null) return; | 1211 assert(buffer != null); |
| 1206 assert(buffer != null); | 1212 // Write as much as possible. |
| 1207 // Write as much as possible. | 1213 offset += socket._write(buffer, offset, buffer.length - offset); |
| 1208 offset += socket._write(buffer, offset, buffer.length - offset); | 1214 if (offset < buffer.length) { |
| 1209 if (offset < buffer.length) { | 1215 if (!paused) { |
| 1210 if (!paused) { | 1216 paused = true; |
| 1211 paused = true; | 1217 subscription.pause(); |
| 1212 subscription.pause(); | |
| 1213 } | |
| 1214 socket._enableWriteEvent(); | |
| 1215 } else { | |
| 1216 buffer = null; | |
| 1217 if (paused) { | |
| 1218 paused = false; | |
| 1219 subscription.resume(); | |
| 1220 } | |
| 1221 } | 1218 } |
| 1222 } catch (e) { | 1219 socket._enableWriteEvent(); |
| 1223 stop(); | 1220 } else { |
| 1224 socket._consumerDone(); | 1221 buffer = null; |
| 1225 done(e); | 1222 if (paused) { |
| 1223 paused = false; |
| 1224 subscription.resume(); |
| 1225 } |
| 1226 } | 1226 } |
| 1227 } | 1227 } |
| 1228 | 1228 |
| 1229 void done([error, stackTrace]) { | 1229 void done([error, stackTrace]) { |
| 1230 if (streamCompleter != null) { | 1230 if (streamCompleter != null) { |
| 1231 if (error != null) { | 1231 if (error != null) { |
| 1232 streamCompleter.completeError(error, stackTrace); | 1232 streamCompleter.completeError(error, stackTrace); |
| 1233 } else { | 1233 } else { |
| 1234 streamCompleter.complete(socket); | 1234 streamCompleter.complete(socket); |
| 1235 } | 1235 } |
| (...skipping 355 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1591 | 1591 |
| 1592 Datagram _makeDatagram(List<int> data, | 1592 Datagram _makeDatagram(List<int> data, |
| 1593 String address, | 1593 String address, |
| 1594 List<int> in_addr, | 1594 List<int> in_addr, |
| 1595 int port) { | 1595 int port) { |
| 1596 return new Datagram( | 1596 return new Datagram( |
| 1597 data, | 1597 data, |
| 1598 new _InternetAddress(address, null, in_addr), | 1598 new _InternetAddress(address, null, in_addr), |
| 1599 port); | 1599 port); |
| 1600 } | 1600 } |
| OLD | NEW |