From: Junio C Hamano <gitster@pobox.com>
To: Hoyoung Lee <lhywkd22@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH v4 1/1] test-delta: simplify delta helper with strbuf and better cleanup
Date: Thu, 24 Jul 2025 11:09:55 -0700 [thread overview]
Message-ID: <xmqqjz3xh34c.fsf@gitster.g> (raw)
In-Reply-To: <20250724093327.2261615-1-lhywkd22@gmail.com> (Hoyoung Lee's message of "Thu, 24 Jul 2025 09:33:27 +0000")
Hoyoung Lee <lhywkd22@gmail.com> writes:
> diff --git a/t/helper/test-delta.c b/t/helper/test-delta.c
> index f5811e96ad..1c4322b7c0 100644
> --- a/t/helper/test-delta.c
> +++ b/t/helper/test-delta.c
> @@ -11,76 +11,47 @@
> #include "test-tool.h"
> #include "git-compat-util.h"
> #include "delta.h"
> +#include "strbuf.h"
>
> static const char usage_str[] =
> "test-tool delta (-d|-p) <from_file> <data_file> <out_file>";
>
> int cmd__delta(int argc, const char **argv)
> {
> - int fd = -1;
> - struct stat st;
> - void *from_buf = NULL, *data_buf = NULL, *out_buf = NULL;
> - unsigned long from_size, data_size, out_size;
> - int ret = 1;
> + int fd;
> + struct strbuf from = STRBUF_INIT, data = STRBUF_INIT;
> + char *out_buf;
> + unsigned long out_size;
Mixed indentation. Make sure you indent with tabs, with tab-width
set to 8. Not limited to the above code block.
> - if (argc != 5 || (strcmp(argv[1], "-d") && strcmp(argv[1], "-p"))) {
> - fprintf(stderr, "usage: %s\n", usage_str);
> - return 1;
> - }
> + if (argc != 5 || (strcmp(argv[1], "-d") && strcmp(argv[1], "-p")))
> + usage(usage_str);
Nice.
> - fd = open(argv[2], O_RDONLY);
> - if (fd < 0 || fstat(fd, &st)) {
> - perror(argv[2]);
> - goto cleanup;
> - }
> - from_size = st.st_size;
> - from_buf = xmalloc(from_size);
> - if (read_in_full(fd, from_buf, from_size) < 0) {
> - perror(argv[2]);
> - goto cleanup;
> - }
> - close(fd);
> -
> - fd = open(argv[3], O_RDONLY);
> - if (fd < 0 || fstat(fd, &st)) {
> - perror(argv[3]);
> - goto cleanup;
> - }
> - data_size = st.st_size;
> - data_buf = xmalloc(data_size);
> - if (read_in_full(fd, data_buf, data_size) < 0) {
> - perror(argv[3]);
> - goto cleanup;
> - }
> - close(fd);
> + if (strbuf_read_file(&from, argv[2], 0) < 0)
> + die_errno("unable to read '%s'", argv[2]);
> + if (strbuf_read_file(&data, argv[3], 0) < 0)
> + die_errno("unable to read '%s'", argv[3]);
OK. from_buf/from_size has become strbuf from; data_buf/data_size
has become strbuf data. Very straight-forward and understandable.
> if (argv[1][1] == 'd')
> - out_buf = diff_delta(from_buf, from_size,
> - data_buf, data_size,
> - &out_size, 0);
> - else
> - out_buf = patch_delta(from_buf, from_size,
> - data_buf, data_size,
> - &out_size);
> - if (!out_buf) {
> - fprintf(stderr, "delta operation failed (returned NULL)\n");
> - goto cleanup;
> - }
> -
> - fd = open (argv[4], O_WRONLY|O_CREAT|O_TRUNC, 0666);
> - if (fd < 0 || write_in_full(fd, out_buf, out_size) < 0) {
> - perror(argv[4]);
> - goto cleanup;
> - }
> -
> - ret = 0;
> -cleanup:
> - free(from_buf);
> - free(data_buf);
> - free(out_buf);
> -
> - if (fd >= 0)
> - close(fd);
> -
> - return ret;
> + out_buf = diff_delta(from.buf, from.len,
> + data.buf, data.len,
> + &out_size, 0);
> + else
> + out_buf = patch_delta(from.buf, from.len,
> + data.buf, data.len,
> + &out_size);
OK, quite straight-forward again.
> + if (!out_buf)
> + die("delta operation failed (returned NULL)");
Nice again.
> + fd = xopen(argv[4], O_WRONLY | O_CREAT | O_TRUNC, 0666);
> + if (write_in_full(fd, out_buf, out_size) < 0)
> + die_errno("write(%s)", argv[4]);
> + if (close(fd) < 0)
> + die_errno("close(%s)", argv[4]);
> +
> + strbuf_release(&from);
> + strbuf_release(&data);
> + free(out_buf);
> +
> + return 0;
> }
OK. Except for the whitespace breakage, I didn't spot anything
glaringly wrong in the patch. Looking good.
Thanks.
next prev parent reply other threads:[~2025-07-24 18:09 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-24 9:33 [PATCH v4 1/1] test-delta: simplify delta helper with strbuf and better cleanup Hoyoung Lee
2025-07-24 18:09 ` Junio C Hamano [this message]
2025-07-25 11:15 ` Jeff King
2025-07-25 11:16 ` Jeff King
2025-07-25 14:42 ` Junio C Hamano
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=xmqqjz3xh34c.fsf@gitster.g \
--to=gitster@pobox.com \
--cc=git@vger.kernel.org \
--cc=lhywkd22@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.