From: phillip.wood123@gmail.com
To: Li Chen <me@linux.beauty>, git@vger.kernel.org
Cc: Junio C Hamano <gitster@pobox.com>,
Phillip Wood <phillip.wood@dunelm.org.uk>,
Kristoffer Haugsbakk <kristofferhaugsbakk@fastmail.com>
Subject: Re: [PATCH v7 2/5] trailer: move process_trailers to trailer.h
Date: Mon, 2 Mar 2026 14:56:15 +0000 [thread overview]
Message-ID: <db8eda43-5b2b-41eb-91bf-1b5b4da817de@gmail.com> (raw)
In-Reply-To: <20260224070552.148591-3-me@linux.beauty>
On 24/02/2026 07:05, Li Chen wrote:
> Move process_trailers() from builtin/interpret-trailers.c into trailer.c
> and expose it via trailer.h.
>
> This lets other call sites reuse the same trailer rewriting logic.
This looks good, thanks
Phillip
> Signed-off-by: Li Chen <me@linux.beauty>
> ---
> v7:
> Rename the input parameter from sb to input.
>
> builtin/interpret-trailers.c | 36 ------------------------------------
> trailer.c | 36 ++++++++++++++++++++++++++++++++++++
> trailer.h | 3 +++
> 3 files changed, 39 insertions(+), 36 deletions(-)
>
> diff --git a/builtin/interpret-trailers.c b/builtin/interpret-trailers.c
> index 69f9d67ec0..1354109e0f 100644
> --- a/builtin/interpret-trailers.c
> +++ b/builtin/interpret-trailers.c
> @@ -136,42 +136,6 @@ static void read_input_file(struct strbuf *sb, const char *file)
> strbuf_complete_line(sb);
> }
>
> -static void process_trailers(const struct process_trailer_options *opts,
> - struct list_head *new_trailer_head,
> - struct strbuf *input, struct strbuf *out)
> -{
> - LIST_HEAD(head);
> - struct trailer_block *trailer_block;
> -
> - trailer_block = parse_trailers(opts, input->buf, &head);
> -
> - /* Print the lines before the trailer block */
> - if (!opts->only_trailers)
> - strbuf_add(out, input->buf, trailer_block_start(trailer_block));
> -
> - if (!opts->only_trailers && !blank_line_before_trailer_block(trailer_block))
> - strbuf_addch(out, '\n');
> -
> - if (!opts->only_input) {
> - LIST_HEAD(config_head);
> - LIST_HEAD(arg_head);
> - parse_trailers_from_config(&config_head);
> - parse_trailers_from_command_line_args(&arg_head, new_trailer_head);
> - list_splice(&config_head, &arg_head);
> - process_trailers_lists(&head, &arg_head);
> - }
> -
> - /* Print trailer block. */
> - format_trailers(opts, &head, out);
> - free_trailers(&head);
> -
> - /* Print the lines after the trailer block as is. */
> - if (!opts->only_trailers)
> - strbuf_add(out, input->buf + trailer_block_end(trailer_block),
> - input->len - trailer_block_end(trailer_block));
> - trailer_block_release(trailer_block);
> -}
> -
> static void interpret_trailers(const struct process_trailer_options *opts,
> struct list_head *new_trailer_head,
> const char *file)
> diff --git a/trailer.c b/trailer.c
> index 911a81ed99..0c9200506d 100644
> --- a/trailer.c
> +++ b/trailer.c
> @@ -1235,3 +1235,39 @@ int amend_file_with_trailers(const char *path, const struct strvec *trailer_args
> strvec_pushv(&run_trailer.args, trailer_args->v);
> return run_command(&run_trailer);
> }
> +
> +void process_trailers(const struct process_trailer_options *opts,
> + struct list_head *new_trailer_head,
> + struct strbuf *input, struct strbuf *out)
> +{
> + LIST_HEAD(head);
> + struct trailer_block *trailer_block;
> +
> + trailer_block = parse_trailers(opts, input->buf, &head);
> +
> + /* Print the lines before the trailer block */
> + if (!opts->only_trailers)
> + strbuf_add(out, input->buf, trailer_block_start(trailer_block));
> +
> + if (!opts->only_trailers && !blank_line_before_trailer_block(trailer_block))
> + strbuf_addch(out, '\n');
> +
> + if (!opts->only_input) {
> + LIST_HEAD(config_head);
> + LIST_HEAD(arg_head);
> + parse_trailers_from_config(&config_head);
> + parse_trailers_from_command_line_args(&arg_head, new_trailer_head);
> + list_splice(&config_head, &arg_head);
> + process_trailers_lists(&head, &arg_head);
> + }
> +
> + /* Print trailer block. */
> + format_trailers(opts, &head, out);
> + free_trailers(&head);
> +
> + /* Print the lines after the trailer block as is. */
> + if (!opts->only_trailers)
> + strbuf_add(out, input->buf + trailer_block_end(trailer_block),
> + input->len - trailer_block_end(trailer_block));
> + trailer_block_release(trailer_block);
> +}
> diff --git a/trailer.h b/trailer.h
> index 4740549586..531fa1a13f 100644
> --- a/trailer.h
> +++ b/trailer.h
> @@ -202,4 +202,7 @@ void trailer_iterator_release(struct trailer_iterator *iter);
> */
> int amend_file_with_trailers(const char *path, const struct strvec *trailer_args);
>
> +void process_trailers(const struct process_trailer_options *opts,
> + struct list_head *new_trailer_head,
> + struct strbuf *input, struct strbuf *out);
> #endif /* TRAILER_H */
next prev parent reply other threads:[~2026-03-02 14:56 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-24 7:05 [PATCH v7 0/5] rebase: support --trailer Li Chen
2026-02-24 7:05 ` [PATCH v7 1/5] interpret-trailers: factor trailer rewriting Li Chen
2026-03-02 14:56 ` Phillip Wood
2026-03-02 15:00 ` Li Chen
2026-02-24 7:05 ` [PATCH v7 2/5] trailer: move process_trailers to trailer.h Li Chen
2026-03-02 14:56 ` phillip.wood123 [this message]
2026-02-24 7:05 ` [PATCH v7 3/5] trailer: append trailers without fork/exec Li Chen
2026-03-02 14:56 ` Phillip Wood
2026-02-24 7:05 ` [PATCH v7 4/5] commit, tag: parse --trailer with OPT_STRVEC Li Chen
2026-03-02 14:56 ` Phillip Wood
2026-02-24 7:05 ` [PATCH v7 5/5] rebase: support --trailer Li Chen
2026-03-03 15:05 ` Phillip Wood
2026-03-03 20:36 ` Kristoffer Haugsbakk
2026-03-03 21:18 ` Junio C Hamano
2026-03-04 15:53 ` Phillip Wood
2026-03-04 17:22 ` Junio C Hamano
2026-02-26 16:52 ` [PATCH v7 0/5] " Junio C Hamano
2026-02-26 18:15 ` Phillip Wood
2026-02-26 21:12 ` Kristoffer Haugsbakk
2026-03-04 14:29 ` Phillip Wood
2026-03-05 13:49 ` Li Chen
2026-03-06 14:55 ` Phillip Wood
2026-03-06 14:53 ` [PATCH v8 0/6] " Phillip Wood
2026-03-06 14:53 ` [PATCH v8 1/6] interpret-trailers: factor trailer rewriting Phillip Wood
2026-03-06 21:04 ` Junio C Hamano
2026-03-09 10:36 ` Phillip Wood
2026-03-06 14:53 ` [PATCH v8 2/6] interpret-trailers: refactor create_in_place_tempfile() Phillip Wood
2026-03-06 21:05 ` Junio C Hamano
2026-03-06 14:53 ` [PATCH v8 3/6] trailer: libify a couple of functions Phillip Wood
2026-03-06 14:53 ` [PATCH v8 4/6] trailer: append trailers without fork/exec Phillip Wood
2026-03-06 14:53 ` [PATCH v8 5/6] commit, tag: parse --trailer with OPT_STRVEC Phillip Wood
2026-03-06 14:53 ` [PATCH v8 6/6] rebase: support --trailer Phillip Wood
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=db8eda43-5b2b-41eb-91bf-1b5b4da817de@gmail.com \
--to=phillip.wood123@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=kristofferhaugsbakk@fastmail.com \
--cc=me@linux.beauty \
--cc=phillip.wood@dunelm.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.