How to predict size of outcome of vsprintf?
Paul Sander
paul at athertn.Atherton.COM
Tue Mar 21 13:08:00 AEST 1989
I seem to have missed the original posting, so I'll follow up Doug Gwyn's
followup...
In article <9872 at smoke.BRL.MIL>, gwyn at smoke.BRL.MIL (Doug Gwyn ) writes:
> In article <993 at etnibsd.UUCP> sean at etnibsd.UUCP (Sean McElroy) writes:
> >O.K. Unix/C gurus, since vsprintf requires the user to ensure that there
> >is enough space in the output string, how does one predict the size of
> >the output string? Is there a routine which returns the predicted
> >length of the output string (effectively preforming the printf conversions)
> >without actually producing the output string?
>
> 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).
>
> >Any suggestions welcome.
>
> Don't use *sprintf() when you can't be sure that the output length
> will be small enough. Seriously.
My guess is that Sean wants to malloc enough space for his output, since
he doesn't know how long it is. I like to do that from time to time myself
when I have to copy user data (which I have very little control over) into
an array of strings that I display later (e.g., in a scrollpane).
So far, I've been lucky in that my data are usually displayed in some
fixed format, followed by a variable length string. Calculating the length
of *sprintf is easy in this case (at least in a platform- and application-
dependent way) by summing the ceilings of the lengths of the fixed part of
the output, and adding the strlen of the variable length part (plus 1 for
the null).
It seems to me that it should be possible to write a printf-like function
that scans the format string and remaining arguments, returning the
ceiling of the length of the result of the *sprintf.
I realize that this problem can only be solved on a platform-by-platform
basis, but thisseems like a fundamental enough problem that someone somewhere
must have done it for some platforms. Has anyone tried?
--
Paul Sander (408) 734-9822 | Do YOU get nervous when a
paul at Atherton.COM | sys{op,adm,prg,engr} says
{decwrl,sun,hplabs!hpda}!athertn!paul | "oops..." ?
More information about the Comp.lang.c
mailing list