interpret-trailers: add an option to show only existing trailers

It can be useful to invoke interpret-trailers for the
primary purpose of parsing existing trailers. But in that
case, we don't want to apply existing ifMissing or ifExists
rules from the config. Let's add a special mode where we
avoid applying those rules. Coupled with --only-trailers,
this gives us a reasonable parsing tool.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King
2017-08-15 06:23:25 -04:00
committed by Junio C Hamano
parent 56c493ed1b
commit fdbdb64f49
5 changed files with 34 additions and 4 deletions

View File

@@ -83,6 +83,11 @@ OPTIONS
--only-trailers:: --only-trailers::
Output only the trailers, not any other parts of the input. Output only the trailers, not any other parts of the input.
--only-input::
Output only trailers that exist in the input; do not add any
from the command-line or by following configured `trailer.*`
rules.
CONFIGURATION VARIABLES CONFIGURATION VARIABLES
----------------------- -----------------------

View File

@@ -25,6 +25,7 @@ int cmd_interpret_trailers(int argc, const char **argv, const char *prefix)
OPT_BOOL(0, "in-place", &opts.in_place, N_("edit files in place")), OPT_BOOL(0, "in-place", &opts.in_place, N_("edit files in place")),
OPT_BOOL(0, "trim-empty", &opts.trim_empty, N_("trim empty trailers")), OPT_BOOL(0, "trim-empty", &opts.trim_empty, N_("trim empty trailers")),
OPT_BOOL(0, "only-trailers", &opts.only_trailers, N_("output only the trailers")), OPT_BOOL(0, "only-trailers", &opts.only_trailers, N_("output only the trailers")),
OPT_BOOL(0, "only-input", &opts.only_input, N_("do not apply config rules")),
OPT_STRING_LIST(0, "trailer", &trailers, N_("trailer"), OPT_STRING_LIST(0, "trailer", &trailers, N_("trailer"),
N_("trailer(s) to add")), N_("trailer(s) to add")),
OPT_END() OPT_END()
@@ -33,6 +34,12 @@ int cmd_interpret_trailers(int argc, const char **argv, const char *prefix)
argc = parse_options(argc, argv, prefix, options, argc = parse_options(argc, argv, prefix, options,
git_interpret_trailers_usage, 0); git_interpret_trailers_usage, 0);
if (opts.only_input && trailers.nr)
usage_msg_opt(
_("--trailer with --only-input does not make sense"),
git_interpret_trailers_usage,
options);
if (argc) { if (argc) {
int i; int i;
for (i = 0; i < argc; i++) for (i = 0; i < argc; i++)

View File

@@ -1314,4 +1314,20 @@ test_expect_success 'only-trailers omits non-trailer in middle of block' '
test_cmp expected actual test_cmp expected actual
' '
test_expect_success 'only input' '
git config trailer.sign.command "echo config-value" &&
cat >expected <<-\EOF &&
existing: existing-value
EOF
git interpret-trailers \
--only-trailers --only-input >actual <<-\EOF &&
my subject
my body
existing: existing-value
EOF
test_cmp expected actual
'
test_done test_done

View File

@@ -976,7 +976,6 @@ void process_trailers(const char *file,
struct string_list *trailers) struct string_list *trailers)
{ {
LIST_HEAD(head); LIST_HEAD(head);
LIST_HEAD(arg_head);
struct strbuf sb = STRBUF_INIT; struct strbuf sb = STRBUF_INIT;
int trailer_end; int trailer_end;
FILE *outfile = stdout; FILE *outfile = stdout;
@@ -991,9 +990,11 @@ void process_trailers(const char *file,
/* Print the lines before the trailers */ /* Print the lines before the trailers */
trailer_end = process_input_file(outfile, sb.buf, &head, opts); trailer_end = process_input_file(outfile, sb.buf, &head, opts);
process_command_line_args(&arg_head, trailers); if (!opts->only_input) {
LIST_HEAD(arg_head);
process_trailers_lists(&head, &arg_head); process_command_line_args(&arg_head, trailers);
process_trailers_lists(&head, &arg_head);
}
print_all(outfile, &head, opts); print_all(outfile, &head, opts);

View File

@@ -26,6 +26,7 @@ struct process_trailer_options {
int in_place; int in_place;
int trim_empty; int trim_empty;
int only_trailers; int only_trailers;
int only_input;
}; };
#define PROCESS_TRAILER_OPTIONS_INIT {0} #define PROCESS_TRAILER_OPTIONS_INIT {0}