El mié., 11 dic. 2019 a las 18:24, Junio C Hamano (<gitster@xxxxxxxxx>) escribió: > > Junio C Hamano <gitster@xxxxxxxxx> writes: > > > Subject: Re: [Outreachy] [PATCH v2] bisect--helper: avoid free-after-use > > It is surprising with multiple mentors, nobody noticed free-after-use > is perfectly fine---it is use-after-free we would want to avoid. > Yes, you are right. I will send another version with the correct title. Thank you, Miriam > > Miriam Rubio <mirucam@xxxxxxxxx> writes: > > > >> From: Tanushree Tumane <tanushreetumane@xxxxxxxxx> > >> > >> In 5e82c3dd22a (bisect--helper: `bisect_reset` shell function in C, > >> 2019-01-02), the `git bisect reset` subcommand was ported to C. When the > >> call to `git checkout` failed, an error message was reported to the > >> user. > >> > >> However, this error message used the `strbuf` that had just been > >> released already. Let's switch that around: first use it, then release > >> it. > >> > >> Mentored-by: Johannes Schindelin <Johannes.Schindelin@xxxxxx> > >> Mentored-by: Christian Couder <chriscool@xxxxxxxxxxxxx> > >> Signed-off-by: Tanushree Tumane <tanushreetumane@xxxxxxxxx> > >> Signed-off-by: Miriam Rubio <mirucam@xxxxxxxxx> > >> --- > >> This patch is a new version of > >> https://public-inbox.org/git/20191208172813.16518-1-mirucam@xxxxxxxxx/ > >> which itself has been sent previously by Tanushree > >> (https://public-inbox.org/git/64117cde718f0d56ebfa4c30f4d8fe2155f5cf65.1551003074.git.gitgitgadget@xxxxxxxxx/). > >> > >> builtin/bisect--helper.c | 7 ++++--- > >> 1 file changed, 4 insertions(+), 3 deletions(-) > >> > >> diff --git a/builtin/bisect--helper.c b/builtin/bisect--helper.c > >> index 1fbe156e67..3055b2bb50 100644 > >> --- a/builtin/bisect--helper.c > >> +++ b/builtin/bisect--helper.c > >> @@ -169,11 +169,12 @@ static int bisect_reset(const char *commit) > >> > >> argv_array_pushl(&argv, "checkout", branch.buf, "--", NULL); > >> if (run_command_v_opt(argv.argv, RUN_GIT_CMD)) { > >> + error(_("could not check out original" > >> + " HEAD '%s'. Try 'git bisect" > >> + " reset <commit>'."), branch.buf); > >> strbuf_release(&branch); > >> argv_array_clear(&argv); > >> - return error(_("could not check out original" > >> - " HEAD '%s'. Try 'git bisect" > >> - " reset <commit>'."), branch.buf); > > > > The original obviously was bad X-<. Will queue. Thanks. > > > >> + return -1; > >> } > >> argv_array_clear(&argv); > >> }