diff options
| author | Stefan Beller <sbeller@google.com> | 2016-02-29 18:07:15 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2016-03-01 11:57:19 -0800 | 
| commit | 2dac9b5637abe580e8b8ea36e00dbbf28ec99af6 (patch) | |
| tree | 57b46bdae2fad445c5d06538e7bae6b4de59f16c | |
| parent | 8c6b5491182510f2344dae71784fcb5c3992d005 (diff) | |
| download | git-2dac9b5637abe580e8b8ea36e00dbbf28ec99af6.tar.gz | |
run_processes_parallel: treat output of children as byte array
We do not want the output to be interrupted by a NUL byte, so we
cannot use raw fputs. Introduce strbuf_write to avoid having long
arguments in run-command.c.
Reviewed-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Stefan Beller <sbeller@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | run-command.c | 8 | ||||
| -rw-r--r-- | strbuf.c | 6 | ||||
| -rw-r--r-- | strbuf.h | 6 | 
3 files changed, 16 insertions, 4 deletions
| diff --git a/run-command.c b/run-command.c index 8e3ad07ffe..bdda94006e 100644 --- a/run-command.c +++ b/run-command.c @@ -994,7 +994,7 @@ static void pp_cleanup(struct parallel_processes *pp)  	 * When get_next_task added messages to the buffer in its last  	 * iteration, the buffered output is non empty.  	 */ -	fputs(pp->buffered_output.buf, stderr); +	strbuf_write(&pp->buffered_output, stderr);  	strbuf_release(&pp->buffered_output);  	sigchain_pop_common(); @@ -1079,7 +1079,7 @@ static void pp_output(struct parallel_processes *pp)  	int i = pp->output_owner;  	if (pp->children[i].state == GIT_CP_WORKING &&  	    pp->children[i].err.len) { -		fputs(pp->children[i].err.buf, stderr); +		strbuf_write(&pp->children[i].err, stderr);  		strbuf_reset(&pp->children[i].err);  	}  } @@ -1117,11 +1117,11 @@ static int pp_collect_finished(struct parallel_processes *pp)  			strbuf_addbuf(&pp->buffered_output, &pp->children[i].err);  			strbuf_reset(&pp->children[i].err);  		} else { -			fputs(pp->children[i].err.buf, stderr); +			strbuf_write(&pp->children[i].err, stderr);  			strbuf_reset(&pp->children[i].err);  			/* Output all other finished child processes */ -			fputs(pp->buffered_output.buf, stderr); +			strbuf_write(&pp->buffered_output, stderr);  			strbuf_reset(&pp->buffered_output);  			/* @@ -395,6 +395,12 @@ ssize_t strbuf_read_once(struct strbuf *sb, int fd, size_t hint)  	return cnt;  } +ssize_t strbuf_write(struct strbuf *sb, FILE *f) +{ +	return sb->len ? fwrite(sb->buf, 1, sb->len, f) : 0; +} + +  #define STRBUF_MAXLINK (2*PATH_MAX)  int strbuf_readlink(struct strbuf *sb, const char *path, size_t hint) @@ -387,6 +387,12 @@ extern ssize_t strbuf_read_file(struct strbuf *sb, const char *path, size_t hint  extern int strbuf_readlink(struct strbuf *sb, const char *path, size_t hint);  /** + * Write the whole content of the strbuf to the stream not stopping at + * NUL bytes. + */ +extern ssize_t strbuf_write(struct strbuf *sb, FILE *stream); + +/**   * Read a line from a FILE *, overwriting the existing contents   * of the strbuf. The second argument specifies the line   * terminator character, typically `'\n'`. | 
