X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=csum-file.c;h=cfc1ac42b9fc9489237cd0bcd1652fb4df243512;hb=7bb1fcc6fcc5a2d0164f243fd10f346eb0822ddf;hp=9728a9954129246b96713d2f3b8dbd52541c416b;hpb=e708af6e587ae0ecb2a6480e3614c5ec4a164106;p=git.git diff --git a/csum-file.c b/csum-file.c index 9728a9954..cfc1ac42b 100644 --- a/csum-file.c +++ b/csum-file.c @@ -11,7 +11,7 @@ #include "progress.h" #include "csum-file.h" -static void sha1flush(struct sha1file *f, unsigned int count) +static void flush(struct sha1file *f, unsigned int count) { void *buf = f->buffer; @@ -32,21 +32,30 @@ static void sha1flush(struct sha1file *f, unsigned int count) } } -int sha1close(struct sha1file *f, unsigned char *result, int final) +void sha1flush(struct sha1file *f) { - int fd; unsigned offset = f->offset; + if (offset) { SHA1_Update(&f->ctx, f->buffer, offset); - sha1flush(f, offset); + flush(f, offset); f->offset = 0; } - if (final) { +} + +int sha1close(struct sha1file *f, unsigned char *result, unsigned int flags) +{ + int fd; + + sha1flush(f); + SHA1_Final(f->buffer, &f->ctx); + if (result) + hashcpy(result, f->buffer); + if (flags & (CSUM_CLOSE | CSUM_FSYNC)) { /* write checksum and close fd */ - SHA1_Final(f->buffer, &f->ctx); - if (result) - hashcpy(result, f->buffer); - sha1flush(f, 20); + flush(f, 20); + if (flags & CSUM_FSYNC) + fsync_or_die(f->fd, f->name); if (close(f->fd)) die("%s: sha1 file error on close (%s)", f->name, strerror(errno)); @@ -73,7 +82,7 @@ int sha1write(struct sha1file *f, void *buf, unsigned int count) left -= nr; if (!left) { SHA1_Update(&f->ctx, f->buffer, offset); - sha1flush(f, offset); + flush(f, offset); offset = 0; } f->offset = offset;