xref: /freebsd/lib/libc/stdio/printf.3 (revision e627b39baccd1ec9129690167cf5e6d860509655)
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" "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
179Zero or more of the following flags:
180.Bl -hyphen
181.It
182A
183.Cm #
184character
185specifying that the value should be converted to an ``alternate form''.
186For
187.Cm c ,
188.Cm d ,
189.Cm i ,
190.Cm n ,
191.Cm p ,
192.Cm s ,
193and
194.Cm u ,
195conversions, this option has no effect.
196For
197.Cm o
198conversions, the precision of the number is increased to force the first
199character of the output string to a zero (except if a zero value is printed
200with an explicit precision of zero).
201For
202.Cm x
203and
204.Cm X
205conversions, a non-zero result has the string
206.Ql 0x
207(or
208.Ql 0X
209for
210.Cm X
211conversions) prepended to it.
212For
213.Cm e ,
214.Cm E ,
215.Cm f ,
216.Cm g ,
217and
218.Cm G ,
219conversions, the result will always contain a decimal point, even if no
220digits follow it (normally, a decimal point appears in the results of
221those conversions only if a digit follows).
222For
223.Cm g
224and
225.Cm G
226conversions, trailing zeros are not removed from the result as they
227would otherwise be.
228.It
229A zero
230.Sq Cm \&0
231character specifying zero padding.
232For all conversions except
233.Cm n ,
234the converted value is padded on the left with zeros rather than blanks.
235If a precision is given with a numeric conversion
236.Pf ( Cm d ,
237.Cm i ,
238.Cm o ,
239.Cm u ,
240.Cm i ,
241.Cm x ,
242and
243.Cm X ) ,
244the
245.Sq Cm \&0
246flag is ignored.
247.It
248A negative field width flag
249.Sq Cm \-
250indicates the converted value is to be left adjusted on the field boundary.
251Except for
252.Cm n
253conversions, the converted value is padded on the right with blanks,
254rather than on the left with blanks or zeros.
255A
256.Sq Cm \-
257overrides a
258.Sq Cm \&0
259if both are given.
260.It
261A space, specifying that a blank should be left before a positive number
262produced by a signed conversion
263.Pf ( Cm d ,
264.Cm e ,
265.Cm E ,
266.Cm f ,
267.Cm g ,
268.Cm G ,
269or
270.Cm i ) .
271.It
272A
273.Sq Cm +
274character specifying that a sign always be placed before a
275number produced by a signed conversion.
276A
277.Sq Cm +
278overrides a space if both are used.
279.El
280.It
281An optional decimal digit string specifying a minimum field width.
282If the converted value has fewer characters than the field width, it will
283be padded with spaces on the left (or right, if the left-adjustment
284flag has been given) to fill out
285the field width.
286.It
287An optional precision, in the form of a period
288.Sq Cm \&.
289followed by an
290optional digit string.  If the digit string is omitted, the precision
291is taken as zero.  This gives the minimum number of digits to appear for
292.Cm d ,
293.Cm i ,
294.Cm o ,
295.Cm u ,
296.Cm x ,
297and
298.Cm X
299conversions, the number of digits to appear after the decimal-point for
300.Cm e ,
301.Cm E ,
302and
303.Cm f
304conversions, the maximum number of significant digits for
305.Cm g
306and
307.Cm G
308conversions, or the maximum number of characters to be printed from a
309string for
310.Cm s
311conversions.
312.It
313The optional character
314.Cm h ,
315specifying that a following
316.Cm d ,
317.Cm i ,
318.Cm o ,
319.Cm u ,
320.Cm x ,
321or
322.Cm X
323conversion corresponds to a
324.Em short int
325or
326.Em unsigned short int
327argument, or that a following
328.Cm n
329conversion corresponds to a pointer to a
330.Em short int
331argument.
332.It
333The optional character
334.Cm l
335(ell) specifying that a following
336.Cm d ,
337.Cm i ,
338.Cm o ,
339.Cm u ,
340.Cm x ,
341or
342.Cm X
343conversion applies to a pointer to a
344.Em long int
345or
346.Em unsigned long int
347argument, or that a following
348.Cm n
349conversion corresponds to a pointer to a
350.Em long int
351argument.
352.It
353The optional character
354.Cm q ,
355specifying that a following
356.Cm d ,
357.Cm i ,
358.Cm o ,
359.Cm u ,
360.Cm x ,
361or
362.Cm X
363conversion corresponds to a
364.Em quad int
365or
366.Em unsigned quad int
367argument, or that a following
368.Cm n
369conversion corresponds to a pointer to a
370.Em quad int
371argument.
372.It
373The character
374.Cm L
375specifying that a following
376.Cm e ,
377.Cm E ,
378.Cm f ,
379.Cm g ,
380or
381.Cm G
382conversion corresponds to a
383.Em long double
384argument (but note that long double values are not currently supported
385by the
386.Tn VAX
387and
388.Tn Tahoe
389compilers).
390.It
391A character that specifies the type of conversion to be applied.
392.El
393.Pp
394A field width or precision, or both, may be indicated by
395an asterisk
396.Ql *
397instead of a
398digit string.
399In this case, an
400.Em int
401argument supplies the field width or precision.
402A negative field width is treated as a left adjustment flag followed by a
403positive field width; a negative precision is treated as though it were
404missing.
405.Pp
406The conversion specifiers and their meanings are:
407.Bl -tag -width "diouxX"
408.It Cm diouxX
409The
410.Em int
411(or appropriate variant) argument is converted to signed decimal
412.Pf ( Cm d
413and
414.Cm i ) ,
415unsigned octal
416.Pq Cm o ,
417unsigned decimal
418.Pq Cm u ,
419or unsigned hexadecimal
420.Pf ( Cm x
421and
422.Cm X )
423notation.  The letters
424.Cm abcdef
425are used for
426.Cm x
427conversions; the letters
428.Cm ABCDEF
429are used for
430.Cm X
431conversions.
432The precision, if any, gives the minimum number of digits that must
433appear; if the converted value requires fewer digits, it is padded on
434the left with zeros.
435.It Cm DOU
436The
437.Em long int
438argument is converted to signed decimal, unsigned octal, or unsigned
439decimal, as if the format had been
440.Cm ld ,
441.Cm lo ,
442or
443.Cm lu
444respectively.
445These conversion characters are deprecated, and will eventually disappear.
446.It Cm eE
447The
448.Em double
449argument is rounded and converted in the style
450.Sm off
451.Pf [\-]d Cm \&. No ddd Cm e No \\*(Pmdd
452.Sm on
453where there is one digit before the
454decimal-point character
455and the number of digits after it is equal to the precision;
456if the precision is missing,
457it is taken as 6; if the precision is
458zero, no decimal-point character appears.
459An
460.Cm E
461conversion uses the letter
462.Cm E
463(rather than
464.Cm e )
465to introduce the exponent.
466The exponent always contains at least two digits; if the value is zero,
467the exponent is 00.
468.It Cm f
469The
470.Em double
471argument is rounded and converted to decimal notation in the style
472.Sm off
473.Pf [-]ddd Cm \&. No ddd ,
474.Sm on
475where the number of digits after the decimal-point character
476is equal to the precision specification.
477If the precision is missing, it is taken as 6; if the precision is
478explicitly zero, no decimal-point character appears.
479If a decimal point appears, at least one digit appears before it.
480.It Cm g
481The
482.Em double
483argument is converted in style
484.Cm f
485or
486.Cm e
487(or
488.Cm E
489for
490.Cm G
491conversions).
492The precision specifies the number of significant digits.
493If the precision is missing, 6 digits are given; if the precision is zero,
494it is treated as 1.
495Style
496.Cm e
497is used if the exponent from its conversion is less than -4 or greater than
498or equal to the precision.
499Trailing zeros are removed from the fractional part of the result; a
500decimal point appears only if it is followed by at least one digit.
501.It Cm c
502The
503.Em int
504argument is converted to an
505.Em unsigned char ,
506and the resulting character is written.
507.It Cm s
508The
509.Dq Em char *
510argument is expected to be a pointer to an array of character type (pointer
511to a string).
512Characters from the array are written up to (but not including)
513a terminating
514.Dv NUL
515character;
516if a precision is specified, no more than the number specified are
517written.
518If a precision is given, no null character
519need be present; if the precision is not specified, or is greater than
520the size of the array, the array must contain a terminating
521.Dv NUL
522character.
523.It Cm p
524The
525.Dq Em void *
526pointer argument is printed in hexadecimal (as if by
527.Ql %#x
528or
529.Ql %#lx ) .
530.It Cm n
531The number of characters written so far is stored into the
532integer indicated by the
533.Dq Em int *
534(or variant) pointer argument.
535No argument is converted.
536.It Cm %
537A
538.Ql %
539is written. No argument is converted. The complete conversion specification
540is
541.Ql %% .
542.El
543.Pp
544In no case does a non-existent or small field width cause truncation of
545a field; if the result of a conversion is wider than the field width, the
546field is expanded to contain the conversion result.
547.Pp
548.Sh EXAMPLES
549.br
550To print a date and time in the form `Sunday, July 3, 10:02',
551where
552.Em weekday
553and
554.Em month
555are pointers to strings:
556.Bd -literal -offset indent
557#include <stdio.h>
558fprintf(stdout, "%s, %s %d, %.2d:%.2d\en",
559	weekday, month, day, hour, min);
560.Ed
561.Pp
562To print \*(Pi
563to five decimal places:
564.Bd -literal -offset indent
565#include <math.h>
566#include <stdio.h>
567fprintf(stdout, "pi = %.5f\en", 4 * atan(1.0));
568.Ed
569.Pp
570To allocate a 128 byte string and print into it:
571.Bd -literal -offset indent
572#include <stdio.h>
573#include <stdlib.h>
574#include <stdarg.h>
575char *newfmt(const char *fmt, ...)
576{
577		char *p;
578		va_list ap;
579		if ((p = malloc(128)) == NULL)
580			return (NULL);
581		va_start(ap, fmt);
582		(void) vsnprintf(p, 128, fmt, ap);
583		va_end(ap);
584		return (p);
585}
586.Ed
587.Sh SEE ALSO
588.Xr printf 1 ,
589.Xr scanf 3
590.Sh STANDARDS
591The
592.Fn fprintf ,
593.Fn printf ,
594.Fn sprintf ,
595.Fn vprintf ,
596.Fn vfprintf ,
597and
598.Fn vsprintf
599functions
600conform to
601.St -ansiC .
602.Sh HISTORY
603The functions
604.Fn snprintf
605and
606.Fn vsnprintf
607are new to this release.
608.Pp
609The functions
610.Fn asprintf
611and
612.Fn vasprintf
613first appeared in the GNU C library.  This implementation is thought
614to be compatable but is not derived from the GNU code.  This implementation
615was written by Peter Wemm <peter@FreeBSD.org> and first appeared in
616.Fx 2.2 .
617.Sh BUGS
618The conversion formats
619.Cm \&%D ,
620.Cm \&%O ,
621and
622.Cm %U
623are not standard and
624are provided only for backward compatibility.
625The effect of padding the
626.Cm %p
627format with zeros (either by the
628.Sq Cm 0
629flag or by specifying a precision), and the benign effect (i.e., none)
630of the
631.Sq Cm #
632flag on
633.Cm %n
634and
635.Cm %p
636conversions, as well as other
637nonsensical combinations such as
638.Cm %Ld ,
639are not standard; such combinations
640should be avoided.
641.Pp
642Because
643.Fn sprintf
644and
645.Fn vsprintf
646assume an infinitely long string,
647callers must be careful not to overflow the actual space;
648this is often hard to assure.
649For safety, programmers should use the
650.Fn snprintf
651interface instead.
652Unfortunately, this interface is not portable.
653