mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-05-28 08:12:28 +00:00
Apply even more fixups
- Finish cleaning up the stdio unlocked APIs - Make __cxa_finalize() properly thread safe - Don't log locks if threads aren't being used - Add some more mutex guards to places using _mmi - Specific lock names now appear in the --ftrace logs - Fix mkdeps.com generating invalid Makefiles sometimes - Simplify and fix bugs in the test runner infrastructure - Fix issue where sometimes some functions wouldn't be logged
This commit is contained in:
parent
4ddfc47d6e
commit
8cdec62f5b
87 changed files with 955 additions and 899 deletions
|
@ -16,18 +16,7 @@
|
|||
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
||||
│ PERFORMANCE OF THIS SOFTWARE. │
|
||||
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||
#include "libc/calls/calls.h"
|
||||
#include "libc/calls/internal.h"
|
||||
#include "libc/calls/struct/iovec.h"
|
||||
#include "libc/errno.h"
|
||||
#include "libc/fmt/conv.h"
|
||||
#include "libc/macros.internal.h"
|
||||
#include "libc/runtime/runtime.h"
|
||||
#include "libc/sock/sock.h"
|
||||
#include "libc/stdio/internal.h"
|
||||
#include "libc/stdio/stdio.h"
|
||||
#include "libc/str/str.h"
|
||||
#include "libc/sysv/consts/o.h"
|
||||
|
||||
/**
|
||||
* Writes data to stream.
|
||||
|
@ -35,54 +24,12 @@
|
|||
* @param stride specifies the size of individual items
|
||||
* @param count is the number of strides to write
|
||||
* @return count on success, [0,count) on EOF, 0 on error or count==0
|
||||
* @threadsafe
|
||||
*/
|
||||
size_t fwrite_unlocked(const void *data, size_t stride, size_t count, FILE *f) {
|
||||
ldiv_t d;
|
||||
ssize_t rc;
|
||||
size_t n, m;
|
||||
const char *p;
|
||||
struct iovec iov[2];
|
||||
if ((f->iomode & O_ACCMODE) == O_RDONLY) {
|
||||
f->state = errno = EBADF;
|
||||
return 0;
|
||||
}
|
||||
n = stride * count;
|
||||
m = f->size - f->beg;
|
||||
if (n <= m && f->bufmode != _IONBF) {
|
||||
memcpy(f->buf + f->beg, data, n);
|
||||
f->beg += n;
|
||||
if (f->fd != -1 && f->bufmode == _IOLBF &&
|
||||
(p = memrchr(f->buf, '\n', f->beg))) {
|
||||
n = p + 1 - f->buf;
|
||||
if ((rc = write(f->fd, f->buf, n)) == -1) {
|
||||
if (errno == EINTR || errno == EAGAIN) return count;
|
||||
f->state = errno;
|
||||
return 0;
|
||||
}
|
||||
n = rc;
|
||||
memmove(f->buf, f->buf + n, f->beg - n);
|
||||
f->beg -= n;
|
||||
}
|
||||
return count;
|
||||
}
|
||||
if (f->fd == -1) {
|
||||
n = MIN(n, m);
|
||||
d = ldiv(n, stride);
|
||||
n -= d.rem;
|
||||
memcpy(f->buf + f->beg, data, n);
|
||||
f->beg += n;
|
||||
f->state = -1;
|
||||
return d.quot;
|
||||
}
|
||||
iov[0].iov_base = f->buf;
|
||||
iov[0].iov_len = f->beg;
|
||||
iov[1].iov_base = data;
|
||||
iov[1].iov_len = n;
|
||||
n += f->beg;
|
||||
if (WritevUninterruptible(f->fd, iov, 2) == -1) {
|
||||
f->state = errno;
|
||||
return 0;
|
||||
}
|
||||
f->beg = 0;
|
||||
return count;
|
||||
size_t fwrite(const void *data, size_t stride, size_t count, FILE *f) {
|
||||
size_t rc;
|
||||
flockfile(f);
|
||||
rc = fwrite_unlocked(data, stride, count, f);
|
||||
funlockfile(f);
|
||||
return rc;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue