Proposal comment for spprintf/snprintf header. When nobody objects i commit
this to spprintf.h and make a notice in snprintf.h.
/*
Comparing: sprintf, snprintf, spprintf
sprintf offers the ability to make a lot of falures since it does not know
the size of the buffer it uses. Therefore usage of sprintf often
results in possible entries for buffer overrun attacks.
SO PLEASE DO NOT USE IT!
snprintf knows the buffers size and will not write behind it. but you will
have to use either a static buffer or allocate one dynamic buffer
before beeing able to call the function. In other words you must
be sure that you really know the maximum size of the buffer required.
A bad thing is if you hav a big maximum and in most cases you only
need a small buffer.
spprintf Is the dynamical version of snprintf it allocates the buffer in size
as neede and allows a maximum setting as snprintf (turn this feature
of by setting max_len to 0). spprintf is a little bit slower than
snprintf and offers possible memory leakes if you miss freeing the
buffer allocated by the function. Therfore this function should be
used where either no maximum is known or the maximum is much bigger
then normal size required.
Example:
char *buffer;
#define MAX 1024
spprintf(&buffer, MAX, "text");
if (!buffer)
return OUT_OF_MEMORY
action_with_buffer();
efree(buffer);
*/
--
PHP Development Mailing List <http://www.php.net/>
To unsubscribe, visit: http://www.php.net/unsub.php