mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-05 12:56:08 +00:00
Add implementations of the wprintf() family of functions, which perform
formatted wide-character output.
This commit is contained in:
parent
a5dd613ce6
commit
c5604d0a50
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=103739
@ -111,6 +111,7 @@ wchar_t *
|
||||
wint_t fputwc(wchar_t, struct __sFILE *);
|
||||
int fputws(const wchar_t * __restrict, struct __sFILE * __restrict);
|
||||
int fwide(struct __sFILE *, int);
|
||||
int fwprintf(struct __sFILE * __restrict, const wchar_t * __restrict, ...);
|
||||
wint_t getwc(struct __sFILE *);
|
||||
wint_t getwchar(void);
|
||||
size_t mbrlen(const char * __restrict, size_t, mbstate_t * __restrict);
|
||||
@ -121,7 +122,14 @@ size_t mbsrtowcs(wchar_t * __restrict, const char ** __restrict, size_t,
|
||||
mbstate_t * __restrict);
|
||||
wint_t putwc(wchar_t, struct __sFILE *);
|
||||
wint_t putwchar(wchar_t);
|
||||
int swprintf(wchar_t * __restrict, size_t n, const wchar_t * __restrict,
|
||||
...);
|
||||
wint_t ungetwc(wint_t, struct __sFILE *);
|
||||
int vfwprintf(struct __sFILE * __restrict, const wchar_t * __restrict,
|
||||
__va_list);
|
||||
int vswprintf(wchar_t * __restrict, size_t n, const wchar_t * __restrict,
|
||||
__va_list);
|
||||
int vwprintf(const wchar_t * __restrict, __va_list);
|
||||
size_t wcrtomb(char * __restrict, wchar_t, mbstate_t * __restrict);
|
||||
wchar_t *wcscat(wchar_t * __restrict, const wchar_t * __restrict);
|
||||
wchar_t *wcschr(const wchar_t *, wchar_t);
|
||||
@ -153,6 +161,7 @@ int wmemcmp(const wchar_t *, const wchar_t *, size_t);
|
||||
wchar_t *wmemcpy(wchar_t * __restrict, const wchar_t * __restrict, size_t);
|
||||
wchar_t *wmemmove(wchar_t *, const wchar_t *, size_t);
|
||||
wchar_t *wmemset(wchar_t *, wchar_t, size_t);
|
||||
int wprintf(const wchar_t * __restrict, ...);
|
||||
|
||||
#if __XSI_VISIBLE
|
||||
int wcswidth(const wchar_t *, size_t);
|
||||
|
@ -8,19 +8,21 @@ SRCS+= _flock_stub.c asprintf.c clrerr.c fclose.c fdopen.c feof.c ferror.c \
|
||||
fflush.c fgetc.c fgetln.c fgetpos.c fgets.c fgetwc.c fgetws.c \
|
||||
fileno.c findfp.c flags.c fopen.c fprintf.c fpurge.c fputc.c fputs.c \
|
||||
fputwc.c fputws.c fread.c freopen.c fscanf.c fseek.c fsetpos.c \
|
||||
ftell.c funopen.c fvwrite.c fwalk.c fwide.c fwrite.c getc.c \
|
||||
ftell.c funopen.c fvwrite.c fwalk.c fwide.c fwprintf.c fwrite.c getc.c \
|
||||
getchar.c gets.c getw.c getwc.c getwchar.c makebuf.c mktemp.c \
|
||||
perror.c printf.c putc.c putchar.c puts.c putw.c putwc.c putwchar.c \
|
||||
refill.c remove.c rewind.c rget.c scanf.c setbuf.c setbuffer.c \
|
||||
setvbuf.c snprintf.c sprintf.c sscanf.c stdio.c tempnam.c tmpfile.c \
|
||||
setvbuf.c snprintf.c sprintf.c sscanf.c stdio.c swprintf.c tempnam.c \
|
||||
tmpfile.c \
|
||||
tmpnam.c ungetc.c ungetwc.c vasprintf.c vfprintf.c vfscanf.c \
|
||||
vprintf.c vscanf.c vsnprintf.c vsprintf.c vsscanf.c wbuf.c wsetup.c
|
||||
vfwprintf.c vprintf.c vscanf.c vsnprintf.c vsprintf.c vsscanf.c \
|
||||
vswprintf.c vwprintf.c wbuf.c wprintf.c wsetup.c
|
||||
|
||||
.if ${LIB} == "c"
|
||||
MAN+= fclose.3 ferror.3 fflush.3 fgetln.3 fgets.3 fgetws.3 fopen.3 fputs.3 \
|
||||
fputws.3 fread.3 fseek.3 funopen.3 fwide.3 getc.3 getwc.3 mktemp.3 \
|
||||
printf.3 putc.3 putwc.3 remove.3 scanf.3 setbuf.3 stdio.3 tmpnam.3 \
|
||||
ungetc.3 ungetwc.3
|
||||
ungetc.3 ungetwc.3 wprintf.3
|
||||
|
||||
MLINKS+=ferror.3 clearerr.3 ferror.3 feof.3 ferror.3 fileno.3
|
||||
MLINKS+=fflush.3 fpurge.3
|
||||
@ -45,4 +47,6 @@ MLINKS+=scanf.3 fscanf.3 scanf.3 sscanf.3 scanf.3 vfscanf.3 scanf.3 vscanf.3 \
|
||||
scanf.3 vsscanf.3
|
||||
MLINKS+=setbuf.3 setbuffer.3 setbuf.3 setlinebuf.3 setbuf.3 setvbuf.3
|
||||
MLINKS+=tmpnam.3 tempnam.3 tmpnam.3 tmpfile.3
|
||||
MLINKS+=wprintf.3 fwprintf.3 wprintf.3 swprintf.3 \
|
||||
wprintf.3 vwprintf.3 wprintf.3 vfwprintf.3 wprintf.3 vswprintf.3
|
||||
.endif
|
||||
|
45
lib/libc/stdio/fwprintf.c
Normal file
45
lib/libc/stdio/fwprintf.c
Normal file
@ -0,0 +1,45 @@
|
||||
/*-
|
||||
* Copyright (c) 2002 Tim J. Robbins
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <wchar.h>
|
||||
|
||||
int
|
||||
fwprintf(FILE * __restrict fp, const wchar_t * __restrict fmt, ...)
|
||||
{
|
||||
int ret;
|
||||
va_list ap;
|
||||
|
||||
va_start(ap, fmt);
|
||||
ret = vfwprintf(fp, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
return (ret);
|
||||
}
|
@ -72,6 +72,7 @@ extern int __swsetup(FILE *);
|
||||
extern int __sflags(const char *, int *);
|
||||
extern int __ungetc(int, FILE *);
|
||||
extern int __vfprintf(FILE *, const char *, __va_list);
|
||||
extern int __vfwprintf(FILE *, const wchar_t *, __va_list);
|
||||
|
||||
extern int __sdidinit;
|
||||
|
||||
|
@ -268,6 +268,7 @@ library conforms to
|
||||
.It "funopen open a stream"
|
||||
.It "fwide set/get orientation of stream"
|
||||
.It "fwopen open a stream"
|
||||
.It "fwprintf formatted wide character output conversion"
|
||||
.It "fwrite binary stream input/output"
|
||||
.It "getc get next character or word from input stream"
|
||||
.It "getchar get next character or word from input stream"
|
||||
@ -297,6 +298,7 @@ library conforms to
|
||||
.It "sprintf formatted output conversion"
|
||||
.It "sscanf input format conversion"
|
||||
.It "strerror system error messages"
|
||||
.It "swprintf formatted wide character output conversion"
|
||||
.It "sys_errlist system error messages"
|
||||
.It "sys_nerr system error messages"
|
||||
.It "tempnam temporary file routines"
|
||||
@ -307,9 +309,13 @@ library conforms to
|
||||
.It "vasprintf formatted output conversion"
|
||||
.It "vfprintf formatted output conversion"
|
||||
.It "vfscanf input format conversion"
|
||||
.It "vfwprintf formatted wide character output conversion"
|
||||
.It "vprintf formatted output conversion"
|
||||
.It "vscanf input format conversion"
|
||||
.It "vsnprintf formatted output conversion"
|
||||
.It "vsprintf formatted output conversion"
|
||||
.It "vsscanf input format conversion"
|
||||
.It "vswprintf formatted wide character output conversion"
|
||||
.It "vwprintf formatted wide character output conversion"
|
||||
.It "wprintf formatted wide character output conversion"
|
||||
.El
|
||||
|
45
lib/libc/stdio/swprintf.c
Normal file
45
lib/libc/stdio/swprintf.c
Normal file
@ -0,0 +1,45 @@
|
||||
/*-
|
||||
* Copyright (c) 2002 Tim J. Robbins
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <wchar.h>
|
||||
|
||||
int
|
||||
swprintf(wchar_t * __restrict s, size_t n, const wchar_t * __restrict fmt, ...)
|
||||
{
|
||||
int ret;
|
||||
va_list ap;
|
||||
|
||||
va_start(ap, fmt);
|
||||
ret = vswprintf(s, n, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
return (ret);
|
||||
}
|
1538
lib/libc/stdio/vfwprintf.c
Normal file
1538
lib/libc/stdio/vfwprintf.c
Normal file
File diff suppressed because it is too large
Load Diff
89
lib/libc/stdio/vswprintf.c
Normal file
89
lib/libc/stdio/vswprintf.c
Normal file
@ -0,0 +1,89 @@
|
||||
/* $OpenBSD: vasprintf.c,v 1.4 1998/06/21 22:13:47 millert Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 1997 Todd C. Miller <Todd.Miller@courtesan.com>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. The name of the author may not be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
#if 0
|
||||
__FBSDID("FreeBSD: src/lib/libc/stdio/vasprintf.c,v 1.16 2002/08/21 16:19:57 mike Exp ");
|
||||
#endif
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <errno.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <wchar.h>
|
||||
#include "local.h"
|
||||
|
||||
int
|
||||
vswprintf(wchar_t * __restrict s, size_t n, const wchar_t * __restrict fmt,
|
||||
__va_list ap)
|
||||
{
|
||||
FILE f;
|
||||
struct __sFILEX ext;
|
||||
mbstate_t mbs;
|
||||
char *mbp;
|
||||
size_t mbresult;
|
||||
int ret;
|
||||
|
||||
if (n == 0) {
|
||||
errno = EINVAL;
|
||||
return (-1);
|
||||
}
|
||||
|
||||
f._file = -1;
|
||||
f._flags = __SWR | __SSTR | __SALC;
|
||||
f._bf._base = f._p = (unsigned char *)malloc(128);
|
||||
if (f._bf._base == NULL) {
|
||||
errno = ENOMEM;
|
||||
return (-1);
|
||||
}
|
||||
f._bf._size = f._w = 127; /* Leave room for the NUL */
|
||||
f._extra = &ext;
|
||||
INITEXTRA(&f);
|
||||
ret = __vfwprintf(&f, fmt, ap);
|
||||
*f._p = '\0';
|
||||
mbp = f._bf._base;
|
||||
memset(&mbs, 0, sizeof(mbs));
|
||||
/*
|
||||
* XXX Undo the conversion from wide characters to multibyte that
|
||||
* fputwc() did in __vfwprintf().
|
||||
*/
|
||||
if (mbsrtowcs(s, (const char **)&mbp, n, &mbs) == (size_t)-1) {
|
||||
free(f._bf._base);
|
||||
errno = EILSEQ;
|
||||
return (-1);
|
||||
}
|
||||
free(f._bf._base);
|
||||
if (s[n - 1] != L'\0') {
|
||||
s[n - 1] = L'\0';
|
||||
errno = EOVERFLOW;
|
||||
return (-1);
|
||||
}
|
||||
|
||||
return (ret);
|
||||
}
|
39
lib/libc/stdio/vwprintf.c
Normal file
39
lib/libc/stdio/vwprintf.c
Normal file
@ -0,0 +1,39 @@
|
||||
/*-
|
||||
* Copyright (c) 2002 Tim J. Robbins
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <wchar.h>
|
||||
|
||||
int
|
||||
vwprintf(const wchar_t * __restrict fmt, va_list ap)
|
||||
{
|
||||
|
||||
return (vfwprintf(stdout, fmt, ap));
|
||||
}
|
618
lib/libc/stdio/wprintf.3
Normal file
618
lib/libc/stdio/wprintf.3
Normal file
@ -0,0 +1,618 @@
|
||||
.\" Copyright (c) 1990, 1991, 1993
|
||||
.\" The Regents of the University of California. All rights reserved.
|
||||
.\"
|
||||
.\" This code is derived from software contributed to Berkeley by
|
||||
.\" Chris Torek and the American National Standards Committee X3,
|
||||
.\" on Information Processing Systems.
|
||||
.\"
|
||||
.\" Redistribution and use in source and binary forms, with or without
|
||||
.\" modification, are permitted provided that the following conditions
|
||||
.\" are met:
|
||||
.\" 1. Redistributions of source code must retain the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer.
|
||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer in the
|
||||
.\" documentation and/or other materials provided with the distribution.
|
||||
.\" 3. All advertising materials mentioning features or use of this software
|
||||
.\" must display the following acknowledgement:
|
||||
.\" This product includes software developed by the University of
|
||||
.\" California, Berkeley and its contributors.
|
||||
.\" 4. Neither the name of the University nor the names of its contributors
|
||||
.\" may be used to endorse or promote products derived from this software
|
||||
.\" without specific prior written permission.
|
||||
.\"
|
||||
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
.\" SUCH DAMAGE.
|
||||
.\"
|
||||
.\" @(#)printf.3 8.1 (Berkeley) 6/4/93
|
||||
.\" FreeBSD: src/lib/libc/stdio/printf.3,v 1.47 2002/09/06 11:23:55 tjr Exp
|
||||
.\" $FreeBSD$
|
||||
.\"
|
||||
.Dd September 18, 2002
|
||||
.Dt WPRINTF 3
|
||||
.Os
|
||||
.Sh NAME
|
||||
.Nm wprintf , fwprintf , swprintf ,
|
||||
.Nm vwprintf , vfwprintf , vswprintf
|
||||
.Nd formatted wide character output conversion
|
||||
.Sh LIBRARY
|
||||
.Lb libc
|
||||
.Sh SYNOPSIS
|
||||
.In stdio.h
|
||||
.In wchar.h
|
||||
.Ft int
|
||||
.Fn fwprintf "FILE * restrict stream" "const wchar_t * restrict format" ...
|
||||
.Ft int
|
||||
.Fn swprintf "wchar_t * restrict ws" "size_t n" "const wchar_t * restrict format" ...
|
||||
.Ft int
|
||||
.Fn wprintf "const wchar_t * restrict format" ...
|
||||
.In stdarg.h
|
||||
.Ft int
|
||||
.Fn vfwprintf "FILE * restrict stream" "const wchar_t * restrict" "va_list ap"
|
||||
.Ft int
|
||||
.Fn vswprintf "wchar_t * restrict ws" "size_t n" "const wchar_t *restrict format" "va_list ap"
|
||||
.Ft int
|
||||
.Fn vwprintf "const wchar_t * restrict format" "va_list ap"
|
||||
.Sh DESCRIPTION
|
||||
The
|
||||
.Fn wprintf
|
||||
family of functions produces output according to a
|
||||
.Fa format
|
||||
as described below.
|
||||
The
|
||||
.Fn wprintf
|
||||
and
|
||||
.Fn vwprintf
|
||||
functions
|
||||
write output to
|
||||
.Pa stdout ,
|
||||
the standard output stream;
|
||||
.Fn fwprintf
|
||||
and
|
||||
.Fn vfwprintf
|
||||
write output to the given output
|
||||
.Fa stream ;
|
||||
.Fn swprintf ,
|
||||
.Fn vswprintf ,
|
||||
and
|
||||
.Fn vsnprintf
|
||||
write to the wide character string
|
||||
.Fa ws .
|
||||
.Pp
|
||||
These functions write the output under the control of a
|
||||
.Fa format
|
||||
string that specifies how subsequent arguments
|
||||
(or arguments accessed via the variable-length argument facilities of
|
||||
.Xr stdarg 3 )
|
||||
are converted for output.
|
||||
.Pp
|
||||
These functions return the number of characters printed
|
||||
(not including the trailing
|
||||
.Ql \e0
|
||||
used to end output to strings).
|
||||
.Pp
|
||||
The
|
||||
.Fn swprintf
|
||||
and
|
||||
.Fn vswprintf
|
||||
functions will fail if
|
||||
.Fa n
|
||||
or more wide characters were requested to be written,
|
||||
.Pp
|
||||
The format string is composed of zero or more directives:
|
||||
ordinary
|
||||
characters (not
|
||||
.Cm % ) ,
|
||||
which are copied unchanged to the output stream;
|
||||
and conversion specifications, each of which results
|
||||
in fetching zero or more subsequent arguments.
|
||||
Each conversion specification is introduced by
|
||||
the
|
||||
.Cm %
|
||||
character.
|
||||
The arguments must correspond properly (after type promotion)
|
||||
with the conversion specifier.
|
||||
After the
|
||||
.Cm % ,
|
||||
the following appear in sequence:
|
||||
.Bl -bullet
|
||||
.It
|
||||
An optional field, consisting of a decimal digit string followed by a
|
||||
.Cm $ ,
|
||||
specifying the next argument to access.
|
||||
If this field is not provided, the argument following the last
|
||||
argument accessed will be used.
|
||||
Arguments are numbered starting at
|
||||
.Cm 1 .
|
||||
If unaccessed arguments in the format string are interspersed with ones that
|
||||
are accessed the results will be indeterminate.
|
||||
.It
|
||||
Zero or more of the following flags:
|
||||
.Bl -tag -width ".So \ Sc (space)"
|
||||
.It Sq Cm #
|
||||
The value should be converted to an
|
||||
.Dq alternate form .
|
||||
For
|
||||
.Cm c , d , i , n , p , s ,
|
||||
and
|
||||
.Cm u
|
||||
conversions, this option has no effect.
|
||||
For
|
||||
.Cm o
|
||||
conversions, the precision of the number is increased to force the first
|
||||
character of the output string to a zero (except if a zero value is printed
|
||||
with an explicit precision of zero).
|
||||
For
|
||||
.Cm x
|
||||
and
|
||||
.Cm X
|
||||
conversions, a non-zero result has the string
|
||||
.Ql 0x
|
||||
(or
|
||||
.Ql 0X
|
||||
for
|
||||
.Cm X
|
||||
conversions) prepended to it.
|
||||
For
|
||||
.Cm a , A , e , E , f , F , g ,
|
||||
and
|
||||
.Cm G
|
||||
conversions, the result will always contain a decimal point, even if no
|
||||
digits follow it (normally, a decimal point appears in the results of
|
||||
those conversions only if a digit follows).
|
||||
For
|
||||
.Cm g
|
||||
and
|
||||
.Cm G
|
||||
conversions, trailing zeros are not removed from the result as they
|
||||
would otherwise be.
|
||||
.It So Cm 0 Sc (zero)
|
||||
Zero padding.
|
||||
For all conversions except
|
||||
.Cm n ,
|
||||
the converted value is padded on the left with zeros rather than blanks.
|
||||
If a precision is given with a numeric conversion
|
||||
.Cm ( d , i , o , u , i , x ,
|
||||
and
|
||||
.Cm X ) ,
|
||||
the
|
||||
.Cm 0
|
||||
flag is ignored.
|
||||
.It Sq Cm \-
|
||||
A negative field width flag;
|
||||
the converted value is to be left adjusted on the field boundary.
|
||||
Except for
|
||||
.Cm n
|
||||
conversions, the converted value is padded on the right with blanks,
|
||||
rather than on the left with blanks or zeros.
|
||||
A
|
||||
.Cm \-
|
||||
overrides a
|
||||
.Cm 0
|
||||
if both are given.
|
||||
.It So "\ " Sc (space)
|
||||
A blank should be left before a positive number
|
||||
produced by a signed conversion
|
||||
.Cm ( a , A , d , e , E , f , F , g , G ,
|
||||
or
|
||||
.Cm i ) .
|
||||
.It Sq Cm +
|
||||
A sign must always be placed before a
|
||||
number produced by a signed conversion.
|
||||
A
|
||||
.Cm +
|
||||
overrides a space if both are used.
|
||||
.It Sq Cm '
|
||||
Decimal conversions
|
||||
.Cm ( d , u ,
|
||||
or
|
||||
.Cm i )
|
||||
or the integral portion of a floating point conversion
|
||||
.Cm ( f
|
||||
or
|
||||
.Cm F )
|
||||
should be grouped and separated by thousands using
|
||||
the non-monetary separator returned by
|
||||
.Xr localeconv 3 .
|
||||
.El
|
||||
.It
|
||||
An optional decimal digit string specifying a minimum field width.
|
||||
If the converted value has fewer characters than the field width, it will
|
||||
be padded with spaces on the left (or right, if the left-adjustment
|
||||
flag has been given) to fill out
|
||||
the field width.
|
||||
.It
|
||||
An optional precision, in the form of a period
|
||||
.Cm \&.
|
||||
followed by an
|
||||
optional digit string.
|
||||
If the digit string is omitted, the precision is taken as zero.
|
||||
This gives the minimum number of digits to appear for
|
||||
.Cm d , i , o , u , x ,
|
||||
and
|
||||
.Cm X
|
||||
conversions, the number of digits to appear after the decimal-point for
|
||||
.Cm a , A , e , E , f ,
|
||||
and
|
||||
.Cm F
|
||||
conversions, the maximum number of significant digits for
|
||||
.Cm g
|
||||
and
|
||||
.Cm G
|
||||
conversions, or the maximum number of characters to be printed from a
|
||||
string for
|
||||
.Cm s
|
||||
conversions.
|
||||
.It
|
||||
An optional length modifier, that specifies the size of the argument.
|
||||
The following length modifiers are valid for the
|
||||
.Cm d , i , n , o , u , x ,
|
||||
or
|
||||
.Cm X
|
||||
conversion:
|
||||
.Bl -column ".Cm q Em (deprecated)" ".Vt signed char" ".Vt unsigned long long" ".Vt long long *"
|
||||
.It Sy Modifier Ta Cm d , i Ta Cm o , u , x , X Ta Cm n
|
||||
.It Cm hh Ta Vt "signed char" Ta Vt "unsigned char" Ta Vt "signed char *"
|
||||
.It Cm h Ta Vt short Ta Vt "unsigned short" Ta Vt "short *"
|
||||
.It Cm l No (ell) Ta Vt long Ta Vt "unsigned long" Ta Vt "long *"
|
||||
.It Cm ll No (ell ell) Ta Vt "long long" Ta Vt "unsigned long long" Ta Vt "long long *"
|
||||
.It Cm j Ta Vt intmax_t Ta Vt uintmax_t Ta Vt "intmax_t *"
|
||||
.It Cm t Ta Vt ptrdiff_t Ta (see note) Ta Vt "ptrdiff_t *"
|
||||
.It Cm z Ta (see note) Ta Vt size_t Ta (see note)
|
||||
.It Cm q Em (deprecated) Ta Vt quad_t Ta Vt u_quad_t Ta Vt "quad_t *"
|
||||
.El
|
||||
.Pp
|
||||
Note:
|
||||
the
|
||||
.Cm t
|
||||
modifier, when applied to a
|
||||
.Cm o , u , x ,
|
||||
or
|
||||
.Cm X
|
||||
conversion, indicates that the argument is of an unsigned type
|
||||
equivalent in size to a
|
||||
.Vt ptrdiff_t .
|
||||
The
|
||||
.Cm z
|
||||
modifier, when applied to a
|
||||
.Cm d
|
||||
or
|
||||
.Cm i
|
||||
conversion, indicates that the argument is of a signed type equivalent in
|
||||
size to a
|
||||
.Vt size_t .
|
||||
Similarly, when applied to an
|
||||
.Cm n
|
||||
conversion, it indicates that the argument is a pointer to a signed type
|
||||
equivalent in size to a
|
||||
.Vt size_t .
|
||||
.Pp
|
||||
The following length modifier is valid for the
|
||||
.Cm a , A , e , E , f , F , g ,
|
||||
or
|
||||
.Cm G
|
||||
conversion:
|
||||
.Bl -column ".Sy Modifier" ".Cm a , A , e , E , f , F , g , G"
|
||||
.It Sy Modifier Ta Cm a , A , e , E , f , F , g , G
|
||||
.It Cm L Ta Vt "long double"
|
||||
.El
|
||||
.Pp
|
||||
The following length modifier is valid for the
|
||||
.Cm c
|
||||
or
|
||||
.Cm s
|
||||
conversion:
|
||||
.Bl -column ".Sy Modifier" ".Vt wint_t" ".Vt wchar_t *"
|
||||
.It Sy Modifier Ta Cm c Ta Cm s
|
||||
.It Cm l No (ell) Ta Vt wint_t Ta Vt "wchar_t *"
|
||||
.El
|
||||
.It
|
||||
A character that specifies the type of conversion to be applied.
|
||||
.El
|
||||
.Pp
|
||||
A field width or precision, or both, may be indicated by
|
||||
an asterisk
|
||||
.Ql *
|
||||
or an asterisk followed by one or more decimal digits and a
|
||||
.Ql $
|
||||
instead of a
|
||||
digit string.
|
||||
In this case, an
|
||||
.Vt int
|
||||
argument supplies the field width or precision.
|
||||
A negative field width is treated as a left adjustment flag followed by a
|
||||
positive field width; a negative precision is treated as though it were
|
||||
missing.
|
||||
If a single format directive mixes positional
|
||||
.Pq Li nn$
|
||||
and non-positional arguments, the results are undefined.
|
||||
.Pp
|
||||
The conversion specifiers and their meanings are:
|
||||
.Bl -tag -width ".Cm diouxX"
|
||||
.It Cm diouxX
|
||||
The
|
||||
.Vt int
|
||||
(or appropriate variant) argument is converted to signed decimal
|
||||
.Cm ( d
|
||||
and
|
||||
.Cm i ) ,
|
||||
unsigned octal
|
||||
.Pq Cm o ,
|
||||
unsigned decimal
|
||||
.Pq Cm u ,
|
||||
or unsigned hexadecimal
|
||||
.Cm ( x
|
||||
and
|
||||
.Cm X )
|
||||
notation.
|
||||
The letters
|
||||
.Dq Li abcdef
|
||||
are used for
|
||||
.Cm x
|
||||
conversions; the letters
|
||||
.Dq Li ABCDEF
|
||||
are used for
|
||||
.Cm X
|
||||
conversions.
|
||||
The precision, if any, gives the minimum number of digits that must
|
||||
appear; if the converted value requires fewer digits, it is padded on
|
||||
the left with zeros.
|
||||
.It Cm DOU
|
||||
The
|
||||
.Vt "long int"
|
||||
argument is converted to signed decimal, unsigned octal, or unsigned
|
||||
decimal, as if the format had been
|
||||
.Cm ld , lo ,
|
||||
or
|
||||
.Cm lu
|
||||
respectively.
|
||||
These conversion characters are deprecated, and will eventually disappear.
|
||||
.It Cm eE
|
||||
The
|
||||
.Vt double
|
||||
argument is rounded and converted in the style
|
||||
.Sm off
|
||||
.Oo \- Oc Ar d Li \&. Ar ddd Li e \\*[Pm] Ar dd
|
||||
.Sm on
|
||||
where there is one digit before the
|
||||
decimal-point character
|
||||
and the number of digits after it is equal to the precision;
|
||||
if the precision is missing,
|
||||
it is taken as 6; if the precision is
|
||||
zero, no decimal-point character appears.
|
||||
An
|
||||
.Cm E
|
||||
conversion uses the letter
|
||||
.Ql E
|
||||
(rather than
|
||||
.Ql e )
|
||||
to introduce the exponent.
|
||||
The exponent always contains at least two digits; if the value is zero,
|
||||
the exponent is 00.
|
||||
.Pp
|
||||
For
|
||||
.Cm a , A , e , E , f , F , g ,
|
||||
and
|
||||
.Cm G
|
||||
conversions, positive and negative infinity are represented as
|
||||
.Li inf
|
||||
and
|
||||
.Li -inf
|
||||
respectively when using the lowercase conversion character, and
|
||||
.Li INF
|
||||
and
|
||||
.Li -INF
|
||||
respectively when using the uppercase conversion character.
|
||||
Similarly, NaN is represented as
|
||||
.Li nan
|
||||
when using the lowercase conversion, and
|
||||
.Li NAN
|
||||
when using the uppercase conversion.
|
||||
.It Cm fF
|
||||
The
|
||||
.Vt double
|
||||
argument is rounded and converted to decimal notation in the style
|
||||
.Sm off
|
||||
.Oo \- Oc Ar ddd Li \&. Ar ddd ,
|
||||
.Sm on
|
||||
where the number of digits after the decimal-point character
|
||||
is equal to the precision specification.
|
||||
If the precision is missing, it is taken as 6; if the precision is
|
||||
explicitly zero, no decimal-point character appears.
|
||||
If a decimal point appears, at least one digit appears before it.
|
||||
.It Cm gG
|
||||
The
|
||||
.Vt double
|
||||
argument is converted in style
|
||||
.Cm f
|
||||
or
|
||||
.Cm e
|
||||
(or
|
||||
.Cm F
|
||||
or
|
||||
.Cm E
|
||||
for
|
||||
.Cm G
|
||||
conversions).
|
||||
The precision specifies the number of significant digits.
|
||||
If the precision is missing, 6 digits are given; if the precision is zero,
|
||||
it is treated as 1.
|
||||
Style
|
||||
.Cm e
|
||||
is used if the exponent from its conversion is less than \-4 or greater than
|
||||
or equal to the precision.
|
||||
Trailing zeros are removed from the fractional part of the result; a
|
||||
decimal point appears only if it is followed by at least one digit.
|
||||
.It Cm aA
|
||||
The
|
||||
.Vt double
|
||||
argument is converted to hexadecimal notation in the style
|
||||
.Sm off
|
||||
.Oo \- Oc Li 0x Ar h Li \&. Ar hhhp Oo \\*[Pm] Oc Ar d ,
|
||||
.Sm on
|
||||
where the number of digits after the hexadecimal-point character
|
||||
is equal to the precision specification.
|
||||
If the precision is missing, it is taken as enough to exactly
|
||||
represent the floating-point number; if the precision is
|
||||
explicitly zero, no hexadecimal-point character appears.
|
||||
This is an exact conversion of the mantissa+exponent internal
|
||||
floating point representation; the
|
||||
.Sm off
|
||||
.Oo \- Oc Li 0x Ar h Li \&. Ar hhh
|
||||
.Sm on
|
||||
portion represents exactly the mantissa; only denormalized
|
||||
mantissas have a zero value to the left of the hexadecimal
|
||||
point.
|
||||
The
|
||||
.Cm p
|
||||
is a literal character
|
||||
.Ql p ;
|
||||
the exponent is preceded by a positive or negative sign
|
||||
and is represented in decimal, using only enough characters
|
||||
to represent the exponent.
|
||||
The
|
||||
.Cm A
|
||||
conversion uses the prefix
|
||||
.Dq Li 0X
|
||||
(rather than
|
||||
.Dq Li 0x ) ,
|
||||
the letters
|
||||
.Dq Li ABCDEF
|
||||
(rather than
|
||||
.Dq Li abcdef )
|
||||
to represent the hex digits, and the letter
|
||||
.Ql P
|
||||
(rather than
|
||||
.Ql p )
|
||||
to separate the mantissa and exponent.
|
||||
.It Cm C
|
||||
Treated as
|
||||
.Cm c
|
||||
with the
|
||||
.Cm l
|
||||
(ell) modifier.
|
||||
.It Cm c
|
||||
The
|
||||
.Vt int
|
||||
argument is converted to an
|
||||
.Vt "unsigned char" ,
|
||||
then to a
|
||||
.Vt wchar_t
|
||||
as if by
|
||||
.Xr btowc 3 ,
|
||||
and the resulting character is written.
|
||||
.Pp
|
||||
If the
|
||||
.Cm l
|
||||
(ell) modifier is used, the
|
||||
.Vt wint_t
|
||||
argument is converted to a
|
||||
.Vt wchar_t
|
||||
and written.
|
||||
.It Cm S
|
||||
Treated as
|
||||
.Cm s
|
||||
with the
|
||||
.Cm l
|
||||
(ell) modifier.
|
||||
.It Cm s
|
||||
The
|
||||
.Vt "char *"
|
||||
argument is expected to be a pointer to an array of character type (pointer
|
||||
to a string) containing a multibyte sequence.
|
||||
Characters from the array are converted to wide characters and written up to
|
||||
(but not including)
|
||||
a terminating
|
||||
.Dv NUL
|
||||
character;
|
||||
if a precision is specified, no more than the number specified are
|
||||
written.
|
||||
If a precision is given, no null character
|
||||
need be present; if the precision is not specified, or is greater than
|
||||
the size of the array, the array must contain a terminating
|
||||
.Dv NUL
|
||||
character.
|
||||
.Pp
|
||||
If the
|
||||
.Cm l
|
||||
(ell) modifier is used, the
|
||||
.Vt "wchar_t *"
|
||||
argument is expected to be a pointer to an array of wide characters
|
||||
(pointer to a wide string).
|
||||
Each wide character in the string
|
||||
is written.
|
||||
Wide characters from the array are written up to (but not including)
|
||||
a terminating wide
|
||||
.Dv NUL
|
||||
character;
|
||||
if a precision is specified, no more than the number specified are
|
||||
written (including shift sequences).
|
||||
If a precision is given, no null character
|
||||
need be present; if the precision is not specified, or is greater than
|
||||
the number of characters in
|
||||
the string, the array must contain a terminating wide
|
||||
.Dv NUL
|
||||
character.
|
||||
.It Cm p
|
||||
The
|
||||
.Vt "void *"
|
||||
pointer argument is printed in hexadecimal (as if by
|
||||
.Ql %#x
|
||||
or
|
||||
.Ql %#lx ) .
|
||||
.It Cm n
|
||||
The number of characters written so far is stored into the
|
||||
integer indicated by the
|
||||
.Vt "int *"
|
||||
(or variant) pointer argument.
|
||||
No argument is converted.
|
||||
.It Cm %
|
||||
A
|
||||
.Ql %
|
||||
is written.
|
||||
No argument is converted.
|
||||
The complete conversion specification
|
||||
is
|
||||
.Ql %% .
|
||||
.El
|
||||
.Pp
|
||||
The decimal point
|
||||
character is defined in the program's locale (category
|
||||
.Dv LC_NUMERIC ) .
|
||||
.Pp
|
||||
In no case does a non-existent or small field width cause truncation of
|
||||
a numeric field; if the result of a conversion is wider than the field
|
||||
width, the
|
||||
field is expanded to contain the conversion result.
|
||||
.Sh SECURITY CONSIDERATIONS
|
||||
Refer to
|
||||
.Xr printf 3 .
|
||||
.Sh SEE ALSO
|
||||
.Xr printf 3 ,
|
||||
.Xr setlocale 3
|
||||
.Sh STANDARDS
|
||||
Subject to the caveats noted in the
|
||||
.Sx BUGS
|
||||
section
|
||||
of
|
||||
.Xr printf 3 ,
|
||||
the
|
||||
.Fn wprintf ,
|
||||
.Fn fwprintf ,
|
||||
.Fn swprintf ,
|
||||
.Fn vwprintf ,
|
||||
.Fn vfwprintf
|
||||
and
|
||||
.Fn vswprintf
|
||||
functions
|
||||
conform to
|
||||
.St -isoC-99 .
|
45
lib/libc/stdio/wprintf.c
Normal file
45
lib/libc/stdio/wprintf.c
Normal file
@ -0,0 +1,45 @@
|
||||
/*-
|
||||
* Copyright (c) 2002 Tim J. Robbins
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <wchar.h>
|
||||
|
||||
int
|
||||
wprintf(const wchar_t * __restrict fmt, ...)
|
||||
{
|
||||
int ret;
|
||||
va_list ap;
|
||||
|
||||
va_start(ap, fmt);
|
||||
ret = vfwprintf(stdout, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
return (ret);
|
||||
}
|
Loading…
Reference in New Issue
Block a user