summaryrefslogtreecommitdiff
path: root/05/musl-0.6.0/src/stdio/fflush.c
diff options
context:
space:
mode:
authorpommicket <pommicket@gmail.com>2022-02-20 13:18:21 -0800
committerpommicket <pommicket@gmail.com>2022-02-20 13:18:21 -0800
commit9bc8a11afeed3569736b89754012e3ca22ee10f6 (patch)
tree5f0ec0d5c05f879b1ee86adfa654ed3ef2178d5f /05/musl-0.6.0/src/stdio/fflush.c
parent0f97a589b800bdb71dda05984192f0f66a52edaa (diff)
conclusion
Diffstat (limited to '05/musl-0.6.0/src/stdio/fflush.c')
-rw-r--r--05/musl-0.6.0/src/stdio/fflush.c54
1 files changed, 54 insertions, 0 deletions
diff --git a/05/musl-0.6.0/src/stdio/fflush.c b/05/musl-0.6.0/src/stdio/fflush.c
new file mode 100644
index 0000000..5b79fa8
--- /dev/null
+++ b/05/musl-0.6.0/src/stdio/fflush.c
@@ -0,0 +1,54 @@
+#include "stdio_impl.h"
+
+static int __fflush_unlocked(FILE *f)
+{
+ /* If writing, flush output. */
+ if (f->wpos > f->buf && __oflow(f)) return -1;
+
+ /* If reading, sync position, per POSIX */
+ if (f->rpos < f->rend) f->seek(f, f->rpos-f->rend, SEEK_CUR);
+ f->rpos = f->rend;
+
+ /* Hook for special behavior on flush */
+ if (f->flush) f->flush(f);
+
+ return (f->flags & F_ERR) ? EOF : 0;
+}
+
+#if 0
+/* stdout.c will override this if linked */
+static FILE *const __dummy = 0;
+weak_alias(__dummy, __stdout_to_flush);
+#else
+extern FILE *const __stdout_to_flush;
+#endif
+
+int fflush(FILE *f)
+{
+ int r;
+ FILE *next;
+
+ if (f) {
+ FLOCK(f);
+ r = __fflush_unlocked(f);
+ FUNLOCK(f);
+ return r;
+ }
+
+ r = __stdout_to_flush ? fflush(__stdout_to_flush) : 0;
+
+ OFLLOCK();
+ for (f=ofl_head; f; f=next) {
+ FLOCK(f);
+ OFLUNLOCK();
+ r |= __fflush_unlocked(f);
+ OFLLOCK();
+ next = f->next;
+ FUNLOCK(f);
+ }
+ OFLUNLOCK();
+
+ return r;
+}
+
+weak_alias(__fflush_unlocked, fflush_unlocked);