diff options
author | Linus Torvalds <torvalds@osdl.org> | 2007-01-11 22:04:11 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2007-01-11 22:19:18 +0100 |
commit | f6aa66cb959393b6605a3288a3080d92d0983d78 (patch) | |
tree | 66811d1ac2f8343498b8028b76b5a8f8a2f500be /write_or_die.c | |
parent | Document git-init (diff) | |
download | git-f6aa66cb959393b6605a3288a3080d92d0983d78.tar.xz git-f6aa66cb959393b6605a3288a3080d92d0983d78.zip |
write_in_full: really write in full or return error on disk full.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'write_or_die.c')
-rw-r--r-- | write_or_die.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/write_or_die.c b/write_or_die.c index a119e1d208..7f99a22aed 100644 --- a/write_or_die.c +++ b/write_or_die.c @@ -37,15 +37,14 @@ int write_in_full(int fd, const void *buf, size_t count) { const char *p = buf; ssize_t total = 0; - ssize_t written = 0; while (count > 0) { - written = xwrite(fd, p, count); - if (written <= 0) { - if (total) - return total; - else - return written; + size_t written = xwrite(fd, p, count); + if (written < 0) + return -1; + if (!written) { + errno = ENOSPC; + return -1; } count -= written; p += written; |