]> git.ipfire.org Git - thirdparty/git.git/commitdiff
archive-tar: factor out write_block()
authorRené Scharfe <l.s.r@web.de>
Wed, 15 Jun 2022 17:01:14 +0000 (19:01 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 15 Jun 2022 20:19:47 +0000 (13:19 -0700)
All tar archive writes have the same size and are done to the same file
descriptor.  Move them to a common function, write_block(), to reduce
code duplication and make it easy to change the destination.

Original-patch-by: Rohit Ashiwal <rohit.ashiwal265@gmail.com>
Signed-off-by: René Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
archive-tar.c

index 2717e34a1d98c0e23cd290f2d6de832141984e9f..4e6a3deb8028ce3e849438bfa20866d1b2538531 100644 (file)
@@ -38,11 +38,16 @@ static int write_tar_filter_archive(const struct archiver *ar,
 #define USTAR_MAX_MTIME 077777777777ULL
 #endif
 
+static void write_block(const void *buf)
+{
+       write_or_die(1, buf, BLOCKSIZE);
+}
+
 /* writes out the whole block, but only if it is full */
 static void write_if_needed(void)
 {
        if (offset == BLOCKSIZE) {
-               write_or_die(1, block, BLOCKSIZE);
+               write_block(block);
                offset = 0;
        }
 }
@@ -66,7 +71,7 @@ static void do_write_blocked(const void *data, unsigned long size)
                write_if_needed();
        }
        while (size >= BLOCKSIZE) {
-               write_or_die(1, buf, BLOCKSIZE);
+               write_block(buf);
                size -= BLOCKSIZE;
                buf += BLOCKSIZE;
        }
@@ -101,10 +106,10 @@ static void write_trailer(void)
 {
        int tail = BLOCKSIZE - offset;
        memset(block + offset, 0, tail);
-       write_or_die(1, block, BLOCKSIZE);
+       write_block(block);
        if (tail < 2 * RECORDSIZE) {
                memset(block, 0, offset);
-               write_or_die(1, block, BLOCKSIZE);
+               write_block(block);
        }
 }