diff options
| author | Emily Shaffer <emilyshaffer@google.com> | 2025-12-26 14:23:31 +0200 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2025-12-28 14:02:07 +0900 |
| commit | 5ab5872a53296b009cca43d412efd1a74ea4f149 (patch) | |
| tree | 627ecb21a0ef8e2e5b0a33170f1e13a1b2d3d6a8 /run-command.h | |
| parent | 857f047e40f796aa43c6e7c754d8a32ee64e4f4d (diff) | |
| download | git-5ab5872a53296b009cca43d412efd1a74ea4f149.tar.xz | |
run-command: allow capturing of collated output
Some callers, for example server-side hooks which wish to relay hook
output to clients across a transport, want to capture what would
normally print to stderr and do something else with it. Allow that via a
callback.
By calling the callback regardless of whether there's output available,
we allow clients to send e.g. a keepalive if necessary.
Because we expose a strbuf, not a fd or FILE*, there's no need to create
a temporary pipe or similar - we can just skip the print to stderr and
instead hand it to the caller.
Signed-off-by: Emily Shaffer <emilyshaffer@google.com>
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Adrian Ratiu <adrian.ratiu@collabora.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'run-command.h')
| -rw-r--r-- | run-command.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/run-command.h b/run-command.h index e1ca965b5b..7093252863 100644 --- a/run-command.h +++ b/run-command.h @@ -436,6 +436,17 @@ typedef int (*feed_pipe_fn)(int child_in, void *pp_task_cb); /** + * If this callback is provided, output is collated into a new pipe instead + * of the process stderr. Then `consume_output_fn` will be called repeatedly + * with output contained in the `output` arg. It will also be called with an + * empty `output` to allow for keepalives or similar operations if necessary. + * + * pp_cb is the callback cookie as passed into run_processes_parallel. + * No task cookie is provided because the callback receives collated output. + */ +typedef void (*consume_output_fn)(struct strbuf *output, void *pp_cb); + +/** * This callback is called on every child process that finished processing. * * See run_processes_parallel() below for a discussion of the "struct @@ -494,6 +505,12 @@ struct run_process_parallel_opts */ feed_pipe_fn feed_pipe; + /* + * consume_output: see consume_output_fn() above. This can be NULL + * to omit any special handling. + */ + consume_output_fn consume_output; + /** * task_finished: See task_finished_fn() above. This can be * NULL to omit any special handling. |
