xref: /freebsd/lib/libc/stdio/printf.3 (revision 9c727d2ca92826945a583d93d4ee78b148c08f83)
1.\" Copyright (c) 1990, 1991, 1993
2.\"	The Regents of the University of California.  All rights reserved.
3.\"
4.\" This code is derived from software contributed to Berkeley by
5.\" Chris Torek and the American National Standards Committee X3,
6.\" on Information Processing Systems.
7.\"
8.\" Redistribution and use in source and binary forms, with or without
9.\" modification, are permitted provided that the following conditions
10.\" are met:
11.\" 1. Redistributions of source code must retain the above copyright
12.\"    notice, this list of conditions and the following disclaimer.
13.\" 2. Redistributions in binary form must reproduce the above copyright
14.\"    notice, this list of conditions and the following disclaimer in the
15.\"    documentation and/or other materials provided with the distribution.
16.\" 3. All advertising materials mentioning features or use of this software
17.\"    must display the following acknowledgement:
18.\"	This product includes software developed by the University of
19.\"	California, Berkeley and its contributors.
20.\" 4. Neither the name of the University nor the names of its contributors
21.\"    may be used to endorse or promote products derived from this software
22.\"    without specific prior written permission.
23.\"
24.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34.\" SUCH DAMAGE.
35.\"
36.\"     @(#)printf.3	8.1 (Berkeley) 6/4/93
37.\"
38.Dd June 4, 1993
39.Dt PRINTF 3
40.Os
41.Sh NAME
42.Nm printf ,
43.Nm fprintf ,
44.Nm sprintf ,
45.Nm snprintf ,
46.Nm asprintf ,
47.Nm vprintf ,
48.Nm vfprintf,
49.Nm vsprintf ,
50.Nm vsnprintf ,
51.Nm vasprintf
52.Nd formatted output conversion
53.Sh SYNOPSIS
54.Fd #include <stdio.h>
55.Ft int
56.Fn printf "const char *format" ...
57.Ft int
58.Fn fprintf "FILE *stream" "const char *format" ...
59.Ft int
60.Fn sprintf "char *str" "const char *format" ...
61.Ft int
62.Fn snprintf "char *str" "size_t size" "const char *format" ...
63.Ft int
64.Fn asprintf "char **ret" "const char *format" ...
65.Fd #include <stdarg.h>
66.Ft int
67.Fn vprintf "const char *format" "va_list ap"
68.Ft int
69.Fn vfprintf "FILE *stream" "const char *format" "va_list ap"
70.Ft int
71.Fn vsprintf "char *str" "const char *format" "va_list ap"
72.Ft int
73.Fn vsnprintf "char *str" "size_t size" "const char *format" "va_list ap"
74.Ft int
75.Fn vasprintf "char **ret" "const char *format" "va_list ap"
76.Sh DESCRIPTION
77The
78.Fn printf
79family of functions produces output according to a
80.Fa format
81as described below.
82.Fn Printf
83and
84.Fn vprintf
85write output to
86.Em stdout,
87the standard output stream;
88.Fn fprintf
89and
90.Fn vfprintf
91write output to the given output
92.Fa stream ;
93.Fn sprintf ,
94.Fn snprintf ,
95.Fn vsprintf ,
96and
97.Fn vsnprintf
98write to the character string
99.Fa str ;
100and
101.Fn asprintf
102and
103.Fn vasprintf
104dynamically allocate a new string with
105.Xr malloc 3
106/
107.Xr realloc 3 .
108.Pp
109These functions write the output under the control of a
110.Fa format
111string that specifies how subsequent arguments
112(or arguments accessed via the variable-length argument facilities of
113.Xr stdarg 3 )
114are converted for output.
115.Pp
116These functions return
117the number of characters printed
118(not including the trailing
119.Ql \e0
120used to end output to strings).
121.Pp
122.Fn Asprintf
123and
124.Fn vasprintf
125return a pointer to a buffer sufficiently large to hold the
126string in the
127.Fa ret
128argument;
129This pointer should be passed to
130.Xr free 3
131to release the allocated storage when it is no longer needed.
132If sufficient space cannot be allocated,
133.Fn asprintf
134and
135.Fn vasprintf
136will return -1 and set
137.Fa ret
138to be a NULL pointer.
139.Pp
140.Fn Snprintf
141and
142.Fn vsnprintf
143will write at most
144.Fa size Ns \-1
145of the characters printed into the output string
146(the
147.Fa size Ns 'th
148character then gets the terminating
149.Ql \e0 ) ;
150if the return value is greater than or equal to the
151.Fa size
152argument, the string was too short
153and some of the printed characters were discarded.
154.Pp
155.Fn Sprintf
156and
157.Fn vsprintf
158effectively assume an infinite
159.Fa size .
160.Pp
161The format string is composed of zero or more directives:
162ordinary
163.\" multibyte
164characters (not
165.Cm % ) ,
166which are copied unchanged to the output stream;
167and conversion specifications, each of which results
168in fetching zero or more subsequent arguments.
169Each conversion specification is introduced by
170the character
171.Cm % .
172The arguments must correspond properly (after type promotion)
173with the conversion specifier.
174After the
175.Cm % ,
176the following appear in sequence:
177.Bl -bullet
178.It
179An optional field, consisting of a decimal digit string followed by a
180.Cm $ ,
181specifying the next argument to access .
182If this field is not provided, the argument following the last
183argument accessed will be used.
184Arguments are numbered starting at
185.Cm 1 .
186If unaccessed arguments in the format string are interspersed with ones that
187are accessed the results will be indeterminate.
188.It
189Zero or more of the following flags:
190.Bl -hyphen
191.It
192A
193.Cm #
194character
195specifying that the value should be converted to an ``alternate form''.
196For
197.Cm c ,
198.Cm d ,
199.Cm i ,
200.Cm n ,
201.Cm p ,
202.Cm s ,
203and
204.Cm u ,
205conversions, this option has no effect.
206For
207.Cm o
208conversions, the precision of the number is increased to force the first
209character of the output string to a zero (except if a zero value is printed
210with an explicit precision of zero).
211For
212.Cm x
213and
214.Cm X
215conversions, a non-zero result has the string
216.Ql 0x
217(or
218.Ql 0X
219for
220.Cm X
221conversions) prepended to it.
222For
223.Cm e ,
224.Cm E ,
225.Cm f ,
226.Cm g ,
227and
228.Cm G ,
229conversions, the result will always contain a decimal point, even if no
230digits follow it (normally, a decimal point appears in the results of
231those conversions only if a digit follows).
232For
233.Cm g
234and
235.Cm G
236conversions, trailing zeros are not removed from the result as they
237would otherwise be.
238.It
239A zero
240.Sq Cm \&0
241character specifying zero padding.
242For all conversions except
243.Cm n ,
244the converted value is padded on the left with zeros rather than blanks.
245If a precision is given with a numeric conversion
246.Pf ( Cm d ,
247.Cm i ,
248.Cm o ,
249.Cm u ,
250.Cm i ,
251.Cm x ,
252and
253.Cm X ) ,
254the
255.Sq Cm \&0
256flag is ignored.
257.It
258A negative field width flag
259.Sq Cm \-
260indicates the converted value is to be left adjusted on the field boundary.
261Except for
262.Cm n
263conversions, the converted value is padded on the right with blanks,
264rather than on the left with blanks or zeros.
265A
266.Sq Cm \-
267overrides a
268.Sq Cm \&0
269if both are given.
270.It
271A space, specifying that a blank should be left before a positive number
272produced by a signed conversion
273.Pf ( Cm d ,
274.Cm e ,
275.Cm E ,
276.Cm f ,
277.Cm g ,
278.Cm G ,
279or
280.Cm i ) .
281.It
282A
283.Sq Cm +
284character specifying that a sign always be placed before a
285number produced by a signed conversion.
286A
287.Sq Cm +
288overrides a space if both are used.
289.El
290.It
291An optional decimal digit string specifying a minimum field width.
292If the converted value has fewer characters than the field width, it will
293be padded with spaces on the left (or right, if the left-adjustment
294flag has been given) to fill out
295the field width.
296.It
297An optional precision, in the form of a period
298.Sq Cm \&.
299followed by an
300optional digit string.  If the digit string is omitted, the precision
301is taken as zero.  This gives the minimum number of digits to appear for
302.Cm d ,
303.Cm i ,
304.Cm o ,
305.Cm u ,
306.Cm x ,
307and
308.Cm X
309conversions, the number of digits to appear after the decimal-point for
310.Cm e ,
311.Cm E ,
312and
313.Cm f
314conversions, the maximum number of significant digits for
315.Cm g
316and
317.Cm G
318conversions, or the maximum number of characters to be printed from a
319string for
320.Cm s
321conversions.
322.It
323The optional character
324.Cm h ,
325specifying that a following
326.Cm d ,
327.Cm i ,
328.Cm o ,
329.Cm u ,
330.Cm x ,
331or
332.Cm X
333conversion corresponds to a
334.Em short int
335or
336.Em unsigned short int
337argument, or that a following
338.Cm n
339conversion corresponds to a pointer to a
340.Em short int
341argument.
342.It
343The optional character
344.Cm l
345(ell) specifying that a following
346.Cm d ,
347.Cm i ,
348.Cm o ,
349.Cm u ,
350.Cm x ,
351or
352.Cm X
353conversion applies to a pointer to a
354.Em long int
355or
356.Em unsigned long int
357argument, or that a following
358.Cm n
359conversion corresponds to a pointer to a
360.Em long int
361argument.
362.It
363The optional character
364.Cm q ,
365specifying that a following
366.Cm d ,
367.Cm i ,
368.Cm o ,
369.Cm u ,
370.Cm x ,
371or
372.Cm X
373conversion corresponds to a
374.Em quad int
375or
376.Em unsigned quad int
377argument, or that a following
378.Cm n
379conversion corresponds to a pointer to a
380.Em quad int
381argument.
382.It
383The character
384.Cm L
385specifying that a following
386.Cm e ,
387.Cm E ,
388.Cm f ,
389.Cm g ,
390or
391.Cm G
392conversion corresponds to a
393.Em long double
394argument (but note that long double values are not currently supported
395by the
396.Tn VAX
397and
398.Tn Tahoe
399compilers).
400.It
401A character that specifies the type of conversion to be applied.
402.El
403.Pp
404A field width or precision, or both, may be indicated by
405an asterisk
406.Ql *
407or an asterisk followed by one or more decimal digits and a
408.Ql $
409instead of a
410digit string.
411In this case, an
412.Em int
413argument supplies the field width or precision.
414A negative field width is treated as a left adjustment flag followed by a
415positive field width; a negative precision is treated as though it were
416missing.
417If a single format directive mixes positional (nn$)
418and non-positional arguments, the results are undefined.
419.Pp
420The conversion specifiers and their meanings are:
421.Bl -tag -width "diouxX"
422.It Cm diouxX
423The
424.Em int
425(or appropriate variant) argument is converted to signed decimal
426.Pf ( Cm d
427and
428.Cm i ) ,
429unsigned octal
430.Pq Cm o ,
431unsigned decimal
432.Pq Cm u ,
433or unsigned hexadecimal
434.Pf ( Cm x
435and
436.Cm X )
437notation.  The letters
438.Cm abcdef
439are used for
440.Cm x
441conversions; the letters
442.Cm ABCDEF
443are used for
444.Cm X
445conversions.
446The precision, if any, gives the minimum number of digits that must
447appear; if the converted value requires fewer digits, it is padded on
448the left with zeros.
449.It Cm DOU
450The
451.Em long int
452argument is converted to signed decimal, unsigned octal, or unsigned
453decimal, as if the format had been
454.Cm ld ,
455.Cm lo ,
456or
457.Cm lu
458respectively.
459These conversion characters are deprecated, and will eventually disappear.
460.It Cm eE
461The
462.Em double
463argument is rounded and converted in the style
464.Sm off
465.Pf [\-]d Cm \&. No ddd Cm e No \\*(Pmdd
466.Sm on
467where there is one digit before the
468decimal-point character
469and the number of digits after it is equal to the precision;
470if the precision is missing,
471it is taken as 6; if the precision is
472zero, no decimal-point character appears.
473An
474.Cm E
475conversion uses the letter
476.Cm E
477(rather than
478.Cm e )
479to introduce the exponent.
480The exponent always contains at least two digits; if the value is zero,
481the exponent is 00.
482.It Cm f
483The
484.Em double
485argument is rounded and converted to decimal notation in the style
486.Sm off
487.Pf [-]ddd Cm \&. No ddd ,
488.Sm on
489where the number of digits after the decimal-point character
490is equal to the precision specification.
491If the precision is missing, it is taken as 6; if the precision is
492explicitly zero, no decimal-point character appears.
493If a decimal point appears, at least one digit appears before it.
494.It Cm g
495The
496.Em double
497argument is converted in style
498.Cm f
499or
500.Cm e
501(or
502.Cm E
503for
504.Cm G
505conversions).
506The precision specifies the number of significant digits.
507If the precision is missing, 6 digits are given; if the precision is zero,
508it is treated as 1.
509Style
510.Cm e
511is used if the exponent from its conversion is less than -4 or greater than
512or equal to the precision.
513Trailing zeros are removed from the fractional part of the result; a
514decimal point appears only if it is followed by at least one digit.
515.It Cm c
516The
517.Em int
518argument is converted to an
519.Em unsigned char ,
520and the resulting character is written.
521.It Cm s
522The
523.Dq Em char *
524argument is expected to be a pointer to an array of character type (pointer
525to a string).
526Characters from the array are written up to (but not including)
527a terminating
528.Dv NUL
529character;
530if a precision is specified, no more than the number specified are
531written.
532If a precision is given, no null character
533need be present; if the precision is not specified, or is greater than
534the size of the array, the array must contain a terminating
535.Dv NUL
536character.
537.It Cm p
538The
539.Dq Em void *
540pointer argument is printed in hexadecimal (as if by
541.Ql %#x
542or
543.Ql %#lx ) .
544.It Cm n
545The number of characters written so far is stored into the
546integer indicated by the
547.Dq Em int *
548(or variant) pointer argument.
549No argument is converted.
550.It Cm %
551A
552.Ql %
553is written. No argument is converted. The complete conversion specification
554is
555.Ql %% .
556.El
557.Pp
558In no case does a non-existent or small field width cause truncation of
559a field; if the result of a conversion is wider than the field width, the
560field is expanded to contain the conversion result.
561.Pp
562.Sh EXAMPLES
563.br
564To print a date and time in the form `Sunday, July 3, 10:02',
565where
566.Em weekday
567and
568.Em month
569are pointers to strings:
570.Bd -literal -offset indent
571#include <stdio.h>
572fprintf(stdout, "%s, %s %d, %.2d:%.2d\en",
573	weekday, month, day, hour, min);
574.Ed
575.Pp
576To print \*(Pi
577to five decimal places:
578.Bd -literal -offset indent
579#include <math.h>
580#include <stdio.h>
581fprintf(stdout, "pi = %.5f\en", 4 * atan(1.0));
582.Ed
583.Pp
584To allocate a 128 byte string and print into it:
585.Bd -literal -offset indent
586#include <stdio.h>
587#include <stdlib.h>
588#include <stdarg.h>
589char *newfmt(const char *fmt, ...)
590{
591		char *p;
592		va_list ap;
593		if ((p = malloc(128)) == NULL)
594			return (NULL);
595		va_start(ap, fmt);
596		(void) vsnprintf(p, 128, fmt, ap);
597		va_end(ap);
598		return (p);
599}
600.Ed
601.Sh SEE ALSO
602.Xr printf 1 ,
603.Xr scanf 3
604.Sh STANDARDS
605The
606.Fn fprintf ,
607.Fn printf ,
608.Fn sprintf ,
609.Fn vprintf ,
610.Fn vfprintf ,
611and
612.Fn vsprintf
613functions
614conform to
615.St -ansiC .
616.Sh HISTORY
617The functions
618.Fn snprintf
619and
620.Fn vsnprintf
621are new to this release.
622.Pp
623The functions
624.Fn asprintf
625and
626.Fn vasprintf
627first appeared in the GNU C library.  This implementation is thought
628to be compatible but is not derived from the GNU code.  This implementation
629was written by Peter Wemm <peter@FreeBSD.org> and first appeared in
630.Fx 2.2 .
631.Sh BUGS
632The conversion formats
633.Cm \&%D ,
634.Cm \&%O ,
635and
636.Cm %U
637are not standard and
638are provided only for backward compatibility.
639The effect of padding the
640.Cm %p
641format with zeros (either by the
642.Sq Cm 0
643flag or by specifying a precision), and the benign effect (i.e., none)
644of the
645.Sq Cm #
646flag on
647.Cm %n
648and
649.Cm %p
650conversions, as well as other
651nonsensical combinations such as
652.Cm %Ld ,
653are not standard; such combinations
654should be avoided.
655.Pp
656Because
657.Fn sprintf
658and
659.Fn vsprintf
660assume an infinitely long string,
661callers must be careful not to overflow the actual space;
662this is often hard to assure.
663For safety, programmers should use the
664.Fn snprintf
665interface instead.
666Unfortunately, this interface is not portable.
667