mirror of
https://github.com/git/git.git
synced 2026-01-10 10:13:33 +00:00
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:
committed by
Junio C Hamano
parent
56c493ed1b
commit
fdbdb64f49
@@ -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
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
|
|||||||
@@ -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++)
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user