mirror of
https://github.com/git/git.git
synced 2024-11-24 18:33:43 +08:00
upload-archive: convert sprintf to strbuf
When we report an error to the client, we format it into a fixed-size buffer using vsprintf(). This can't actually overflow in practice, since we only format a very tame subset of strings (mostly strerror() output). However, it's hard to tell immediately, so let's just use a strbuf so readers do not have to wonder. We do add an allocation here, but the performance is not important; the next step is to call die() anyway. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
495127dbcb
commit
0cb9d6d6b6
@ -49,15 +49,14 @@ int cmd_upload_archive_writer(int argc, const char **argv, const char *prefix)
|
||||
__attribute__((format (printf, 1, 2)))
|
||||
static void error_clnt(const char *fmt, ...)
|
||||
{
|
||||
char buf[1024];
|
||||
struct strbuf buf = STRBUF_INIT;
|
||||
va_list params;
|
||||
int len;
|
||||
|
||||
va_start(params, fmt);
|
||||
len = vsprintf(buf, fmt, params);
|
||||
strbuf_vaddf(&buf, fmt, params);
|
||||
va_end(params);
|
||||
send_sideband(1, 3, buf, len, LARGE_PACKET_MAX);
|
||||
die("sent error to the client: %s", buf);
|
||||
send_sideband(1, 3, buf.buf, buf.len, LARGE_PACKET_MAX);
|
||||
die("sent error to the client: %s", buf.buf);
|
||||
}
|
||||
|
||||
static ssize_t process_input(int child_fd, int band)
|
||||
|
Loading…
Reference in New Issue
Block a user