Skip to content

Commit 35b4c2f

Browse files
committed
---
yaml --- r: 82139 b: refs/heads/master c: a402fb2 h: refs/heads/master i: 82137: 328d1ee 82135: 1917e7b v: v3
1 parent 01a09ea commit 35b4c2f

File tree

2 files changed

+14
-3
lines changed

2 files changed

+14
-3
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
---
2-
refs/heads/master: c5295f9c4713e77dbb8dfc76bc91e10fceaabbb2
2+
refs/heads/master: a402fb27faabbe33f03d461d6684af4501db5ac4
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 6c08cc2db4f98e9f07ae7d50338396c4123c2f0a
55
refs/heads/try: 70152ff55722878cde684ee6462c14c65f2c4729

trunk/src/libstd/rt/uv/net.rs

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ use rt::uv::uvll;
1414
use rt::uv::uvll::*;
1515
use rt::uv::{AllocCallback, ConnectionCallback, ReadCallback, UdpReceiveCallback, UdpSendCallback};
1616
use rt::uv::{Loop, Watcher, Request, UvError, Buf, NativeHandle, NullCallback,
17-
status_to_maybe_uv_error};
17+
status_to_maybe_uv_error, vec_to_uv_buf};
1818
use rt::io::net::ip::{SocketAddr, Ipv4Addr, Ipv6Addr};
1919
use vec;
2020
use str;
@@ -147,7 +147,18 @@ impl StreamWatcher {
147147
data.read_cb = Some(cb);
148148
}
149149

150-
unsafe { uvll::read_start(self.native_handle(), alloc_cb, read_cb); }
150+
let ret = unsafe { uvll::read_start(self.native_handle(), alloc_cb, read_cb) };
151+
152+
if ret != 0 {
153+
// uvll::read_start failed, so read_cb will not be called.
154+
// Call it manually for scheduling.
155+
call_read_cb(self.native_handle(), ret as ssize_t);
156+
}
157+
158+
fn call_read_cb(stream: *uvll::uv_stream_t, errno: ssize_t) {
159+
#[fixed_stack_segment]; #[inline(never)];
160+
read_cb(stream, errno, vec_to_uv_buf(~[]));
161+
}
151162

152163
extern fn alloc_cb(stream: *uvll::uv_stream_t, suggested_size: size_t) -> Buf {
153164
let mut stream_watcher: StreamWatcher = NativeHandle::from_native_handle(stream);

0 commit comments

Comments
 (0)