aboutsummaryrefslogtreecommitdiff
path: root/lib/std/event/loop.zig
diff options
context:
space:
mode:
authorLoris Cro <kappaloris@gmail.com>2020-06-19 23:00:17 +0200
committerLoris Cro <kappaloris@gmail.com>2020-09-24 22:03:12 +0200
commitbc35435ca6e51d0e120538398e3c708ada57f6de (patch)
treede167c9e77a13122d68f07262ef0524eea999b6f /lib/std/event/loop.zig
parent08364ac773bdc95b9407974b5c761dbdab863f4d (diff)
downloadzig-bc35435ca6e51d0e120538398e3c708ada57f6de.tar.gz
zig-bc35435ca6e51d0e120538398e3c708ada57f6de.zip
readv
Signed-off-by: Loris Cro <kappaloris@gmail.com>
Diffstat (limited to 'lib/std/event/loop.zig')
-rw-r--r--lib/std/event/loop.zig40
1 files changed, 26 insertions, 14 deletions
diff --git a/lib/std/event/loop.zig b/lib/std/event/loop.zig
index 7adc6e3a8f..96774e3f11 100644
--- a/lib/std/event/loop.zig
+++ b/lib/std/event/loop.zig
@@ -855,23 +855,35 @@ pub const Loop = struct {
/// Performs an async `os.readv` using a separate thread.
/// `fd` must block and not return EAGAIN.
- pub fn readv(self: *Loop, fd: os.fd_t, iov: []const os.iovec) os.ReadError!usize {
- var req_node = Request.Node{
- .data = .{
- .msg = .{
- .readv = .{
- .fd = fd,
- .iov = iov,
- .result = undefined,
+ pub fn readv(self: *Loop, fd: os.fd_t, iov: []const os.iovec, simulate_evented: bool) os.ReadError!usize {
+ if (simulate_evented) {
+ var req_node = Request.Node{
+ .data = .{
+ .msg = .{
+ .readv = .{
+ .fd = fd,
+ .iov = iov,
+ .result = undefined,
+ },
},
+ .finish = .{ .TickNode = .{ .data = @frame() } },
},
- .finish = .{ .TickNode = .{ .data = @frame() } },
- },
- };
- suspend {
- self.posixFsRequest(&req_node);
+ };
+ suspend {
+ self.posixFsRequest(&req_node);
+ }
+ return req_node.data.msg.readv.result;
+ } else {
+ while (true) {
+ return os.readv(fd, iov) catch |err| switch (err) {
+ error.WouldBlock => {
+ self.waitUntilFdReadable(fd);
+ continue;
+ },
+ else => return err,
+ };
+ }
}
- return req_node.data.msg.readv.result;
}
/// Performs an async `os.pread` using a separate thread.