How to predict size of outcome of vsprintf?
Mike Haertel
mike at thor.acc.stolaf.edu
Mon Mar 20 04:34:04 AEST 1989
In article <9872 at smoke.BRL.MIL> gwyn at brl.arpa (Doug Gwyn (VLD/VMB) <gwyn>) writes:
>No. Sometimes you can accurately predict an upper bound on the output
>string length; for example if the format is "%d" and the numerical
>argument is known to lie between 0 and 5000, the maximum number of
>characters for the *sprintf() output will be 5 (including the null
>byte at the end).
>
...
>
>Don't use *sprintf() when you can't be sure that the output length
>will be small enough. Seriously.
The (unreleased) GNU C library contains routines something like:
int snprintf(char *str, size_t len, const char *fmt, ...);
int vsnprintf(char *str, size_t len, const char *fmt, va_list ap);
that do bounds checking on their output. Richard Stallman suggested to
ANSI that they include such routines in the C standard; I am of the
impression that various other people independently made the same or a
similar suggestion. I also recall a posting by Chris Torek a few
months ago that included an excerpt from a <stdio.h> that included
a routine that looked something like:
FILE *fmemopen(void *mem, size_t len, const char *how);
This solves the same problem, and offers additional advantages as well.
I do not understand why the pANS does not address this problem in some way.
--
Mike Haertel <mike at stolaf.edu>
In Hell they run VMS.
More information about the Comp.lang.c
mailing list