clean up stdio_impl.h
[musl] / src / stdio / __fdopen.c
index 6ad7c57..59690f6 100644 (file)
@@ -1,13 +1,21 @@
 #include "stdio_impl.h"
+#include <stdlib.h>
+#include <termios.h>
+#include <sys/ioctl.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <string.h>
 
 FILE *__fdopen(int fd, const char *mode)
 {
        FILE *f;
        struct termios tio;
-       int plus = !!strchr(mode, '+');
 
        /* Check for valid initial mode character */
-       if (!strchr("rwa", *mode)) return 0;
+       if (!strchr("rwa", *mode)) {
+               errno = EINVAL;
+               return 0;
+       }
 
        /* Allocate FILE+buffer or fail */
        if (!(f=malloc(sizeof *f + UNGET + BUFSIZ))) return 0;
@@ -16,12 +24,15 @@ FILE *__fdopen(int fd, const char *mode)
        memset(f, 0, sizeof *f);
 
        /* Impose mode restrictions */
-       if (!plus) f->flags = (*mode == 'r') ? F_NOWR : F_NORD;
+       if (!strchr(mode, '+')) f->flags = (*mode == 'r') ? F_NOWR : F_NORD;
+
+       /* Apply close-on-exec flag */
+       if (strchr(mode, 'e')) __syscall(SYS_fcntl, fd, F_SETFD, FD_CLOEXEC);
 
        /* Set append mode on fd if opened for append */
        if (*mode == 'a') {
-               int flags = __syscall_fcntl(fd, F_GETFL, 0);
-               __syscall_fcntl(fd, F_SETFL, flags | O_APPEND);
+               int flags = __syscall(SYS_fcntl, fd, F_GETFL);
+               __syscall(SYS_fcntl, fd, F_SETFL, flags | O_APPEND);
        }
 
        f->fd = fd;
@@ -30,7 +41,7 @@ FILE *__fdopen(int fd, const char *mode)
 
        /* Activate line buffered mode for terminals */
        f->lbf = EOF;
-       if (!(f->flags & F_NOWR) && !__syscall_ioctl(fd, TCGETS, &tio))
+       if (!(f->flags & F_NOWR) && !__syscall(SYS_ioctl, fd, TCGETS, &tio))
                f->lbf = '\n';
 
        /* Initialize op ptrs. No problem if some are unneeded. */
@@ -39,11 +50,13 @@ FILE *__fdopen(int fd, const char *mode)
        f->seek = __stdio_seek;
        f->close = __stdio_close;
 
+       if (!libc.threaded) f->lock = -1;
+
        /* Add new FILE to open file list */
        OFLLOCK();
-       f->next = ofl_head;
-       if (ofl_head) ofl_head->prev = f;
-       ofl_head = f;
+       f->next = libc.ofl_head;
+       if (libc.ofl_head) libc.ofl_head->prev = f;
+       libc.ofl_head = f;
        OFLUNLOCK();
 
        return f;