summaryrefslogtreecommitdiff
path: root/system/lib/libc/musl/src/stdio/fwrite.c
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2014-06-02 16:16:43 -0700
committerAlon Zakai <alonzakai@gmail.com>2014-06-02 16:16:43 -0700
commitacb8d1e6339fdae6285b90c5cd0740a079a3e2ed (patch)
tree918bfabd8b19ce35cda0a1f9afdbf913084e55cb /system/lib/libc/musl/src/stdio/fwrite.c
parentc9823a494a96e2058f391a1778ad199f733c0423 (diff)
parent894fdda0c1f7f70939229a91a4ba9df977b37218 (diff)
Merge pull request #2364 from juj/musl_stdio
Musl stdio
Diffstat (limited to 'system/lib/libc/musl/src/stdio/fwrite.c')
-rw-r--r--system/lib/libc/musl/src/stdio/fwrite.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/system/lib/libc/musl/src/stdio/fwrite.c b/system/lib/libc/musl/src/stdio/fwrite.c
new file mode 100644
index 00000000..bf68b794
--- /dev/null
+++ b/system/lib/libc/musl/src/stdio/fwrite.c
@@ -0,0 +1,41 @@
+#include "stdio_impl.h"
+#include <string.h>
+
+size_t __fwritex(const unsigned char *restrict s, size_t l, FILE *restrict f)
+{
+ size_t i=0;
+
+ if (!f->wend && __towrite(f)) return 0;
+
+ if (l > f->wend - f->wpos) return f->write(f, s, l);
+
+ if (f->lbf >= 0) {
+ /* Match /^(.*\n|)/ */
+ for (i=l; i && s[i-1] != '\n'; i--);
+ if (i) {
+ if (f->write(f, s, i) < i)
+ return i;
+ s += i;
+ l -= i;
+ }
+ }
+
+ memcpy(f->wpos, s, l);
+ f->wpos += l;
+ return l+i;
+}
+
+// XXX Emscripten: Not used, since we are not currently using musl file IO.
+#if 0
+size_t fwrite(const void *restrict src, size_t size, size_t nmemb, FILE *restrict f)
+{
+ size_t k, l = size*nmemb;
+ if (!l) return l;
+ FLOCK(f);
+ k = __fwritex(src, l, f);
+ FUNLOCK(f);
+ return k==l ? nmemb : k/size;
+}
+#endif
+
+weak_alias(fwrite, fwrite_unlocked);