revisions API users: use release_revisions() in builtin/log.c
In preparation for having the "log" family of functions make wider use of release_revisions() let's have them call it just before exiting. This changes the "log", "whatchanged", "show", "format-patch", etc. commands, all of which live in this file. The release_revisions() API still only frees the "pending" member, but will learn to release more members of "struct rev_info" in subsequent commits. In the case of "format-patch" revert the addition of UNLEAK() indee839a263
(format-patch: mark rev_info with UNLEAK, 2021-12-16), which will cause several tests that previously passed under "TEST_PASSES_SANITIZE_LEAK=true" to start failing. In subsequent commits we'll now be able to use those tests to check whether that part of the API is really leaking memory, and will fix all of those memory leaks. Removing the UNLEAK() allows us to make incremental progress in that direction. See [1] for further details about this approach. Note that the release_revisions() will not be sufficient to deal with the code in cmd_show() added in5d7eeee2ac
(git-show: grok blobs, trees and tags, too, 2006-12-14) which clobbers the "pending" array in the case of "OBJ_COMMIT". That will need to be dealt with by some future follow-up work. 1. https://lore.kernel.org/git/220218.861r00ib86.gmgdl@evledraar.gmail.com/ Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
b78ce337de
commit
f6bfea0ad0
@ -295,6 +295,12 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,
|
||||
cmd_log_init_finish(argc, argv, prefix, rev, opt);
|
||||
}
|
||||
|
||||
static int cmd_log_deinit(int ret, struct rev_info *rev)
|
||||
{
|
||||
release_revisions(rev);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/*
|
||||
* This gives a rough estimate for how many commits we
|
||||
* will print out in the list.
|
||||
@ -558,7 +564,7 @@ int cmd_whatchanged(int argc, const char **argv, const char *prefix)
|
||||
cmd_log_init(argc, argv, prefix, &rev, &opt);
|
||||
if (!rev.diffopt.output_format)
|
||||
rev.diffopt.output_format = DIFF_FORMAT_RAW;
|
||||
return cmd_log_walk(&rev);
|
||||
return cmd_log_deinit(cmd_log_walk(&rev), &rev);
|
||||
}
|
||||
|
||||
static void show_tagger(const char *buf, struct rev_info *rev)
|
||||
@ -677,7 +683,7 @@ int cmd_show(int argc, const char **argv, const char *prefix)
|
||||
cmd_log_init(argc, argv, prefix, &rev, &opt);
|
||||
|
||||
if (!rev.no_walk)
|
||||
return cmd_log_walk(&rev);
|
||||
return cmd_log_deinit(cmd_log_walk(&rev), &rev);
|
||||
|
||||
count = rev.pending.nr;
|
||||
objects = rev.pending.objects;
|
||||
@ -732,8 +738,7 @@ int cmd_show(int argc, const char **argv, const char *prefix)
|
||||
ret = error(_("unknown type: %d"), o->type);
|
||||
}
|
||||
}
|
||||
free(objects);
|
||||
return ret;
|
||||
return cmd_log_deinit(ret, &rev);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -761,7 +766,7 @@ int cmd_log_reflog(int argc, const char **argv, const char *prefix)
|
||||
rev.always_show_header = 1;
|
||||
cmd_log_init_finish(argc, argv, prefix, &rev, &opt);
|
||||
|
||||
return cmd_log_walk(&rev);
|
||||
return cmd_log_deinit(cmd_log_walk(&rev), &rev);
|
||||
}
|
||||
|
||||
static void log_setup_revisions_tweak(struct rev_info *rev,
|
||||
@ -792,7 +797,7 @@ int cmd_log(int argc, const char **argv, const char *prefix)
|
||||
opt.revarg_opt = REVARG_COMMITTISH;
|
||||
opt.tweak = log_setup_revisions_tweak;
|
||||
cmd_log_init(argc, argv, prefix, &rev, &opt);
|
||||
return cmd_log_walk(&rev);
|
||||
return cmd_log_deinit(cmd_log_walk(&rev), &rev);
|
||||
}
|
||||
|
||||
/* format-patch */
|
||||
@ -2289,8 +2294,7 @@ done:
|
||||
if (rev.ref_message_ids)
|
||||
string_list_clear(rev.ref_message_ids, 0);
|
||||
free(rev.ref_message_ids);
|
||||
UNLEAK(rev);
|
||||
return 0;
|
||||
return cmd_log_deinit(0, &rev);
|
||||
}
|
||||
|
||||
static int add_pending_commit(const char *arg, struct rev_info *revs, int flags)
|
||||
|
@ -2,8 +2,6 @@
|
||||
|
||||
test_description='apply empty'
|
||||
|
||||
|
||||
TEST_PASSES_SANITIZE_LEAK=true
|
||||
. ./test-lib.sh
|
||||
|
||||
test_expect_success setup '
|
||||
|
Loading…
Reference in New Issue
Block a user