stop_progress_msg: convert sprintf to xsnprintf

The usual arguments for using xsnprintf over sprintf apply,
but this case is a little tricky. We print to a fixed-size
buffer if we have room, and otherwise to an allocated
buffer. So there should be no overflow here, but it is still
good to communicate our intention, as well as to check our
earlier math for how much space the string will need.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2015-09-24 17:06:46 -04:00 committed by Junio C Hamano
parent c3bb0ac796
commit f5691aa640

View File

@ -254,7 +254,7 @@ void stop_progress_msg(struct progress **p_progress, const char *msg)
throughput_string(&tp->display, tp->curr_total, rate); throughput_string(&tp->display, tp->curr_total, rate);
} }
progress_update = 1; progress_update = 1;
sprintf(bufp, ", %s.\n", msg); xsnprintf(bufp, len + 1, ", %s.\n", msg);
display(progress, progress->last_value, bufp); display(progress, progress->last_value, bufp);
if (buf != bufp) if (buf != bufp)
free(bufp); free(bufp);