On Wed, 9 Aug 2017 08:24:40 -0400
Jeff King <p...@peff.net> wrote:

> diff --git a/t/t7513-interpret-trailers.sh b/t/t7513-interpret-trailers.sh
> index e5b0718ef6..525fd53e5b 100755
> --- a/t/t7513-interpret-trailers.sh
> +++ b/t/t7513-interpret-trailers.sh
> @@ -1312,4 +1312,19 @@ test_expect_success 'only-trailers omits non-trailer 
> in middle of block' '
>       test_cmp expected actual
>  '
>  
> +test_expect_success 'only existing' '
> +     cat >expected <<-\EOF &&
> +             existing: existing-value
> +     EOF
> +     git interpret-trailers \
> +             --only-trailers --only-existing >actual <<-\EOF &&
> +             my subject
> +
> +             my body
> +
> +             existing: existing-value
> +     EOF
> +     test_cmp expected actual

Would it be worth asserting that the "sign" trailer is configured here
and would normally appear? Maybe through a grep on the output of "git
config".

> +'
> +
>  test_done
> diff --git a/trailer.c b/trailer.c
> index a4ff99f98a..88f6efe523 100644
> --- a/trailer.c
> +++ b/trailer.c
> @@ -991,9 +991,10 @@ void process_trailers(const char *file, struct 
> process_trailer_options *opts,
>       trailer_end = process_input_file(opts->only_trailers ? NULL : outfile,
>                                        sb.buf, &head);
>  
> -     process_command_line_args(&arg_head, trailers);
> -
> -     process_trailers_lists(&head, &arg_head);
> +     if (!opts->only_existing) {
> +             process_command_line_args(&arg_head, trailers);
> +             process_trailers_lists(&head, &arg_head);
> +     }

This is a bit confusing, but it is correct, since
process_command_line_args() processes both configured trailers and
command-line trailers.

Having said that, it might be worth declaring LIST_HEAD(arg_head) inside
the if block now.

Reply via email to