瀏覽代碼

Merge pull request #42 from dlrobertson/use_va_list

fcntl: open should use a va_list
Jeremy Soller 7 年之前
父節點
當前提交
231d7a023a
共有 4 個文件被更改,包括 18 次插入4 次删除
  1. 13 0
      include/bits/fcntl.h
  2. 2 1
      src/fcntl/cbindgen.toml
  3. 2 2
      src/fcntl/src/lib.rs
  4. 1 1
      tests/dup.c

+ 13 - 0
include/bits/fcntl.h

@@ -0,0 +1,13 @@
+#ifndef _BITS_FCNTL_H
+#define _BITS_FCNTL_H
+
+int open(const char* filename, int flags, ...) {
+    mode_t mode = 0;
+	va_list ap;
+	va_start(ap, flags);
+    mode = va_arg(ap, mode_t);
+	va_end(ap);
+    return sys_open(filename, flags, mode);
+}
+
+#endif

+ 2 - 1
src/fcntl/cbindgen.toml

@@ -1,5 +1,6 @@
-sys_includes = ["sys/types.h"]
+sys_includes = ["stdarg.h", "sys/types.h"]
 include_guard = "_FCNTL_H"
+trailer = "#include <bits/fcntl.h>"
 language = "C"
 
 [enum]

+ 2 - 2
src/fcntl/src/lib.rs

@@ -33,7 +33,7 @@ pub const F_UNLCK: c_int = 2;
 
 #[no_mangle]
 pub extern "C" fn creat(path: *const c_char, mode: mode_t) -> c_int {
-    open(path, O_WRONLY | O_CREAT | O_TRUNC, mode)
+    sys_open(path, O_WRONLY | O_CREAT | O_TRUNC, mode)
 }
 
 #[no_mangle]
@@ -42,7 +42,7 @@ pub extern "C" fn fcntl(fildes: c_int, cmd: c_int, arg: c_int) -> c_int {
 }
 
 #[no_mangle]
-pub extern "C" fn open(path: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
+pub extern "C" fn sys_open(path: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
     platform::open(path, oflag, mode)
 }
 

+ 1 - 1
tests/dup.c

@@ -4,7 +4,7 @@
 
 int main(int argc, char** argv) {
     creat("dup.out", 0777);
-    int fd1 = open("dup.out", 0, 0);
+    int fd1 = open("dup.out", 0);
     int fd2 = dup(fd1);
     printf("fd %d duped into fd %d\n", fd1, fd2);
     close(fd1);