Message ID | 85f45a57f3529a90324ded07856fca610f7b5eda.1714934950.git.gitgitgadget@gmail.com (mailing list archive) |
---|---|
State | Accepted |
Commit | 56740f9910218a03374b5e410b3a2d204d7c33ed |
Headers | show |
Series | builtin/tag.c: add --trailer option | expand |
On Sun, May 5, 2024 at 2:49 PM John Passaro via GitGitGadget <gitgitgadget@gmail.com> wrote: > Thank you for queuing the patch series! Hopeful and excited that this may go in a future release. > From: John Passaro <john.a.passaro@gmail.com> > > Replace git-commit's callback for --trailer with the standard > OPT_PASSTHRU_ARGV macro. The callback only adds its values to a strvec > and sanity-checking that `unset` is always false; both of these are > already implemented in the parse-option API. > > Signed-off-by: John Passaro <john.a.passaro@gmail.com> Looking over the patch series I notice that I left a grammar error in this description, if the patch makes it to the "next" branch I hope you can amend the message first, as follows: Replace git-commit's callback for --trailer with the standard OPT_PASSTHRU_ARGV macro. The callback only adds its values to a strvec and sanity-checks that `unset` is always false; both of these are already implemented in the parse-option API. > --- > builtin/commit.c | 10 +--------- > 1 file changed, 1 insertion(+), 9 deletions(-) > > diff --git a/builtin/commit.c b/builtin/commit.c > index 6e1484446b0..5a3248370db 100644 > --- a/builtin/commit.c > +++ b/builtin/commit.c > @@ -142,14 +142,6 @@ static struct strbuf message = STRBUF_INIT; > > static enum wt_status_format status_format = STATUS_FORMAT_UNSPECIFIED; > > -static int opt_pass_trailer(const struct option *opt, const char *arg, int unset) > -{ > - BUG_ON_OPT_NEG(unset); > - > - strvec_pushl(opt->value, "--trailer", arg, NULL); > - return 0; > -} > - > static int opt_parse_porcelain(const struct option *opt, const char *arg, int unset) > { > enum wt_status_format *value = (enum wt_status_format *)opt->value; > @@ -1673,7 +1665,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix) > OPT_STRING(0, "fixup", &fixup_message, N_("[(amend|reword):]commit"), N_("use autosquash formatted message to fixup or amend/reword specified commit")), > OPT_STRING(0, "squash", &squash_message, N_("commit"), N_("use autosquash formatted message to squash specified commit")), > OPT_BOOL(0, "reset-author", &renew_authorship, N_("the commit is authored by me now (used with -C/-c/--amend)")), > - OPT_CALLBACK_F(0, "trailer", &trailer_args, N_("trailer"), N_("add custom trailer(s)"), PARSE_OPT_NONEG, opt_pass_trailer), > + OPT_PASSTHRU_ARGV(0, "trailer", &trailer_args, N_("trailer"), N_("add custom trailer(s)"), PARSE_OPT_NONEG), > OPT_BOOL('s', "signoff", &signoff, N_("add a Signed-off-by trailer")), > OPT_FILENAME('t', "template", &template_file, N_("use specified template file")), > OPT_BOOL('e', "edit", &edit_flag, N_("force edit of commit")), > -- > gitgitgadget >
John Passaro <john.a.passaro@gmail.com> writes: >> From: John Passaro <john.a.passaro@gmail.com> >> >> Replace git-commit's callback for --trailer with the standard >> OPT_PASSTHRU_ARGV macro. The callback only adds its values to a strvec >> and sanity-checking that `unset` is always false; both of these are >> already implemented in the parse-option API. >> >> Signed-off-by: John Passaro <john.a.passaro@gmail.com> > > Looking over the patch series I notice that I left a grammar error in > this description, > if the patch makes it to the "next" branch I hope you can amend the > message first, > as follows: > > Replace git-commit's callback for --trailer with the standard > OPT_PASSTHRU_ARGV macro. The callback only adds its values to a strvec > and sanity-checks that `unset` is always false; both of these are > already implemented in the parse-option API. Thanks for stopping me before the topic got merged to 'next'. Amended.
diff --git a/builtin/commit.c b/builtin/commit.c index 6e1484446b0..5a3248370db 100644 --- a/builtin/commit.c +++ b/builtin/commit.c @@ -142,14 +142,6 @@ static struct strbuf message = STRBUF_INIT; static enum wt_status_format status_format = STATUS_FORMAT_UNSPECIFIED; -static int opt_pass_trailer(const struct option *opt, const char *arg, int unset) -{ - BUG_ON_OPT_NEG(unset); - - strvec_pushl(opt->value, "--trailer", arg, NULL); - return 0; -} - static int opt_parse_porcelain(const struct option *opt, const char *arg, int unset) { enum wt_status_format *value = (enum wt_status_format *)opt->value; @@ -1673,7 +1665,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix) OPT_STRING(0, "fixup", &fixup_message, N_("[(amend|reword):]commit"), N_("use autosquash formatted message to fixup or amend/reword specified commit")), OPT_STRING(0, "squash", &squash_message, N_("commit"), N_("use autosquash formatted message to squash specified commit")), OPT_BOOL(0, "reset-author", &renew_authorship, N_("the commit is authored by me now (used with -C/-c/--amend)")), - OPT_CALLBACK_F(0, "trailer", &trailer_args, N_("trailer"), N_("add custom trailer(s)"), PARSE_OPT_NONEG, opt_pass_trailer), + OPT_PASSTHRU_ARGV(0, "trailer", &trailer_args, N_("trailer"), N_("add custom trailer(s)"), PARSE_OPT_NONEG), OPT_BOOL('s', "signoff", &signoff, N_("add a Signed-off-by trailer")), OPT_FILENAME('t', "template", &template_file, N_("use specified template file")), OPT_BOOL('e', "edit", &edit_flag, N_("force edit of commit")),