mirror of
https://git.musl-libc.org/git/musl
synced 2025-02-13 16:54:16 +03:00
add support for caller-provided buffers to setvbuf
This commit is contained in:
parent
6019459251
commit
0b80a7b040
@ -1,22 +1,25 @@
|
||||
#include "stdio_impl.h"
|
||||
|
||||
/* This function makes no attempt to protect the user from his/her own
|
||||
* stupidity. If called any time but when then ISO C standard specifically
|
||||
* allows it, all hell can and will break loose, especially with threads!
|
||||
*
|
||||
* This implementation ignores all arguments except the buffering type,
|
||||
* and uses the existing buffer allocated alongside the FILE object.
|
||||
* In the case of stderr where the preexisting buffer is length 1, it
|
||||
* is not possible to set line buffering or full buffering. */
|
||||
/* The behavior of this function is undefined except when it is the first
|
||||
* operation on the stream, so the presence or absence of lockign is not
|
||||
* observable in a program whose behavior is defined. Thus no locking is
|
||||
* performed here. No allocation of buffers is performed, but a buffer
|
||||
* provided by the caller is used as long as it is suitably sized. */
|
||||
|
||||
int setvbuf(FILE *restrict f, char *restrict buf, int type, size_t size)
|
||||
{
|
||||
f->lbf = EOF;
|
||||
|
||||
if (type == _IONBF)
|
||||
if (type == _IONBF) {
|
||||
f->buf_size = 0;
|
||||
else if (type == _IOLBF)
|
||||
f->lbf = '\n';
|
||||
} else {
|
||||
if (buf && size >= UNGET) {
|
||||
f->buf = (void *)buf;
|
||||
f->buf_size = size - UNGET;
|
||||
}
|
||||
if (type == _IOLBF && f->buf_size)
|
||||
f->lbf = '\n';
|
||||
}
|
||||
|
||||
f->flags |= F_SVB;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user