mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
dupvprintf: fix signedness of return from vsnprintf.
It's defined in the C standard to return an int, not a size_t, and we should honour that since the subsequent code checks it for <0. A knock-on effect is that I reorganise the addends in one of the sgrowarrays, to be extra careful about overflow when adding something to that int.
This commit is contained in:
parent
bde7b6b158
commit
0ceb73fb10
8
utils.c
8
utils.c
@ -340,15 +340,13 @@ int string_length_for_printf(size_t s)
|
|||||||
static char *dupvprintf_inner(char *buf, size_t oldlen, size_t *sizeptr,
|
static char *dupvprintf_inner(char *buf, size_t oldlen, size_t *sizeptr,
|
||||||
const char *fmt, va_list ap)
|
const char *fmt, va_list ap)
|
||||||
{
|
{
|
||||||
size_t len, size;
|
size_t size = *sizeptr;
|
||||||
|
|
||||||
size = *sizeptr;
|
|
||||||
sgrowarrayn_nm(buf, size, oldlen, 512);
|
sgrowarrayn_nm(buf, size, oldlen, 512);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
va_list aq;
|
va_list aq;
|
||||||
va_copy(aq, ap);
|
va_copy(aq, ap);
|
||||||
len = vsnprintf(buf + oldlen, size - oldlen, fmt, aq);
|
int len = vsnprintf(buf + oldlen, size - oldlen, fmt, aq);
|
||||||
va_end(aq);
|
va_end(aq);
|
||||||
|
|
||||||
if (len >= 0 && len < size) {
|
if (len >= 0 && len < size) {
|
||||||
@ -359,7 +357,7 @@ static char *dupvprintf_inner(char *buf, size_t oldlen, size_t *sizeptr,
|
|||||||
} else if (len > 0) {
|
} else if (len > 0) {
|
||||||
/* This is the C99 error condition: the returned length is
|
/* This is the C99 error condition: the returned length is
|
||||||
* the required buffer size not counting the NUL. */
|
* the required buffer size not counting the NUL. */
|
||||||
sgrowarrayn_nm(buf, size, oldlen, len + 1);
|
sgrowarrayn_nm(buf, size, oldlen + 1, len);
|
||||||
} else {
|
} else {
|
||||||
/* This is the pre-C99 glibc error condition: <0 means the
|
/* This is the pre-C99 glibc error condition: <0 means the
|
||||||
* buffer wasn't big enough, so we enlarge it a bit and hope. */
|
* buffer wasn't big enough, so we enlarge it a bit and hope. */
|
||||||
|
Loading…
Reference in New Issue
Block a user