commit dcaaa241dfb7ce77b7070df8d6a939a9f0749e2c (tree)
parent c2a08d7c516899b4c794bd6c3fc07ddb22d5876a
Author: Matthew D. Steele <mdsteele@alum.mit.edu>
Date: Fri, 3 Aug 2018 11:45:23 -0400
Fix a type error in std.os.linux.getpid() (#1326)
syscall0() returns usize, but we were trying to @bitCast to i32.
Diffstat:
2 files changed, 5 insertions(+), 1 deletion(-)
diff --git a/std/os/linux/index.zig b/std/os/linux/index.zig
@@ -944,7 +944,7 @@ pub fn setgroups(size: usize, list: *const u32) usize {
}
pub fn getpid() i32 {
- return @bitCast(i32, u32(syscall0(SYS_getpid)));
+ return @bitCast(i32, @truncate(u32, syscall0(SYS_getpid)));
}
pub fn sigprocmask(flags: u32, noalias set: *const sigset_t, noalias oldset: ?*sigset_t) usize {
diff --git a/std/os/linux/test.zig b/std/os/linux/test.zig
@@ -3,6 +3,10 @@ const builtin = @import("builtin");
const linux = std.os.linux;
const assert = std.debug.assert;
+test "getpid" {
+ assert(linux.getpid() != 0);
+}
+
test "timer" {
const epoll_fd = linux.epoll_create();
var err = linux.getErrno(epoll_fd);