projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix fesetround error checking
[musl]
/
src
/
stdio
/
__fdopen.c
diff --git
a/src/stdio/__fdopen.c
b/src/stdio/__fdopen.c
index
a6ae73a
..
116e78e
100644
(file)
--- a/
src/stdio/__fdopen.c
+++ b/
src/stdio/__fdopen.c
@@
-1,15
+1,15
@@
#include "stdio_impl.h"
#include <stdlib.h>
#include "stdio_impl.h"
#include <stdlib.h>
-#include <termios.h>
#include <sys/ioctl.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
#include <sys/ioctl.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
+#include "libc.h"
FILE *__fdopen(int fd, const char *mode)
{
FILE *f;
FILE *__fdopen(int fd, const char *mode)
{
FILE *f;
- struct
termios tio
;
+ struct
winsize wsz
;
/* Check for valid initial mode character */
if (!strchr("rwa", *mode)) {
/* Check for valid initial mode character */
if (!strchr("rwa", *mode)) {
@@
-43,7
+43,7
@@
FILE *__fdopen(int fd, const char *mode)
/* Activate line buffered mode for terminals */
f->lbf = EOF;
/* Activate line buffered mode for terminals */
f->lbf = EOF;
- if (!(f->flags & F_NOWR) && !__syscall(SYS_ioctl, fd, T
CGETS, &tio
))
+ if (!(f->flags & F_NOWR) && !__syscall(SYS_ioctl, fd, T
IOCGWINSZ, &wsz
))
f->lbf = '\n';
/* Initialize op ptrs. No problem if some are unneeded. */
f->lbf = '\n';
/* Initialize op ptrs. No problem if some are unneeded. */
@@
-55,13
+55,7
@@
FILE *__fdopen(int fd, const char *mode)
if (!libc.threaded) f->lock = -1;
/* Add new FILE to open file list */
if (!libc.threaded) f->lock = -1;
/* Add new FILE to open file list */
- OFLLOCK();
- f->next = libc.ofl_head;
- if (libc.ofl_head) libc.ofl_head->prev = f;
- libc.ofl_head = f;
- OFLUNLOCK();
-
- return f;
+ return __ofl_add(f);
}
weak_alias(__fdopen, fdopen);
}
weak_alias(__fdopen, fdopen);