2004-11-24 08:45:41 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 1990 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms are permitted
|
|
|
|
* provided that the above copyright notice and this paragraph are
|
|
|
|
* duplicated in all such forms and that any documentation,
|
|
|
|
* advertising materials, and other materials related to such
|
|
|
|
* distribution and use acknowledge that the software was developed
|
|
|
|
* by the University of California, Berkeley. The name of the
|
|
|
|
* University 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 WITHOUT ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
FUNCTION
|
2007-05-04 10:55:16 +08:00
|
|
|
<<viprintf>>, <<vfiprintf>>, <<vsiprintf>>, <<vsniprintf>>, <<vasiprintf>>, <<vasniprintf>>---format argument list (integer only)
|
2004-11-24 08:45:41 +08:00
|
|
|
|
|
|
|
INDEX
|
|
|
|
viprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_viprintf_r
|
2004-11-24 08:45:41 +08:00
|
|
|
INDEX
|
|
|
|
vfiprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_vfiprintf_r
|
2004-11-24 08:45:41 +08:00
|
|
|
INDEX
|
|
|
|
vsiprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_vsiprintf_r
|
2004-11-24 08:45:41 +08:00
|
|
|
INDEX
|
|
|
|
vsniprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_vsniprintf_r
|
2007-05-04 10:55:16 +08:00
|
|
|
INDEX
|
|
|
|
vasiprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_vasiprintf_r
|
2007-05-04 10:55:16 +08:00
|
|
|
INDEX
|
|
|
|
vasniprintf
|
2008-11-01 05:08:03 +08:00
|
|
|
INDEX
|
|
|
|
_vasniprintf_r
|
2004-11-24 08:45:41 +08:00
|
|
|
|
2017-11-30 16:05:02 +08:00
|
|
|
SYNOPSIS
|
2004-11-24 08:45:41 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
int viprintf(const char *<[fmt]>, va_list <[list]>);
|
|
|
|
int vfiprintf(FILE *<[fp]>, const char *<[fmt]>, va_list <[list]>);
|
|
|
|
int vsiprintf(char *<[str]>, const char *<[fmt]>, va_list <[list]>);
|
2005-10-29 05:38:59 +08:00
|
|
|
int vsniprintf(char *<[str]>, size_t <[size]>, const char *<[fmt]>,
|
|
|
|
va_list <[list]>);
|
2007-05-04 10:55:16 +08:00
|
|
|
int vasiprintf(char **<[strp]>, const char *<[fmt]>, va_list <[list]>);
|
|
|
|
char *vasniprintf(char *<[str]>, size_t *<[size]>, const char *<[fmt]>,
|
|
|
|
va_list <[list]>);
|
2004-11-24 08:45:41 +08:00
|
|
|
|
|
|
|
int _viprintf_r(struct _reent *<[reent]>, const char *<[fmt]>,
|
|
|
|
va_list <[list]>);
|
2005-10-29 05:38:59 +08:00
|
|
|
int _vfiprintf_r(struct _reent *<[reent]>, FILE *<[fp]>,
|
|
|
|
const char *<[fmt]>, va_list <[list]>);
|
|
|
|
int _vsiprintf_r(struct _reent *<[reent]>, char *<[str]>,
|
|
|
|
const char *<[fmt]>, va_list <[list]>);
|
2007-05-04 10:55:16 +08:00
|
|
|
int _vsniprintf_r(struct _reent *<[reent]>, char *<[str]>,
|
2008-11-01 05:08:03 +08:00
|
|
|
size_t <[size]>, const char *<[fmt]>, va_list <[list]>);
|
2007-05-04 10:55:16 +08:00
|
|
|
int _vasiprintf_r(struct _reent *<[reent]>, char **<[str]>,
|
|
|
|
const char *<[fmt]>, va_list <[list]>);
|
|
|
|
char *_vasniprintf_r(struct _reent *<[reent]>, char *<[str]>,
|
2008-11-01 05:08:03 +08:00
|
|
|
size_t *<[size]>, const char *<[fmt]>, va_list <[list]>);
|
2004-11-24 08:45:41 +08:00
|
|
|
|
|
|
|
DESCRIPTION
|
2007-05-04 10:55:16 +08:00
|
|
|
<<viprintf>>, <<vfiprintf>>, <<vasiprintf>>, <<vsiprintf>>,
|
|
|
|
<<vsniprintf>>, and <<vasniprintf>> are (respectively) variants of
|
|
|
|
<<iprintf>>, <<fiprintf>>, <<asiprintf>>, <<siprintf>>, <<sniprintf>>,
|
|
|
|
and <<asniprintf>>. They differ only in allowing their caller to pass
|
|
|
|
the variable argument list as a <<va_list>> object (initialized by
|
|
|
|
<<va_start>>) rather than directly accepting a variable number of
|
|
|
|
arguments. The caller is responsible for calling <<va_end>>.
|
|
|
|
|
|
|
|
<<_viprintf_r>>, <<_vfiprintf_r>>, <<_vasiprintf_r>>,
|
|
|
|
<<_vsiprintf_r>>, <<_vsniprintf_r>>, and <<_vasniprintf_r>> are
|
|
|
|
reentrant versions of the above.
|
2004-11-24 08:45:41 +08:00
|
|
|
|
|
|
|
RETURNS
|
|
|
|
The return values are consistent with the corresponding functions:
|
|
|
|
|
|
|
|
PORTABILITY
|
2007-05-04 10:55:16 +08:00
|
|
|
All of these functions are newlib extensions.
|
2004-11-24 08:45:41 +08:00
|
|
|
|
|
|
|
Supporting OS subroutines required: <<close>>, <<fstat>>, <<isatty>>,
|
|
|
|
<<lseek>>, <<read>>, <<sbrk>>, <<write>>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <_ansi.h>
|
|
|
|
#include <reent.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include "local.h"
|
|
|
|
|
|
|
|
#ifndef _REENT_ONLY
|
|
|
|
|
|
|
|
int
|
2017-12-04 11:43:30 +08:00
|
|
|
viprintf (const char *fmt,
|
2004-11-24 08:45:41 +08:00
|
|
|
va_list ap)
|
|
|
|
{
|
2013-04-30 05:06:23 +08:00
|
|
|
struct _reent *reent = _REENT;
|
|
|
|
|
|
|
|
_REENT_SMALL_CHECK_INIT (reent);
|
|
|
|
return _vfiprintf_r (reent, _stdout_r (reent), fmt, ap);
|
2004-11-24 08:45:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !_REENT_ONLY */
|
|
|
|
|
|
|
|
int
|
2017-12-04 11:43:30 +08:00
|
|
|
_viprintf_r (struct _reent *ptr,
|
2017-12-04 10:25:16 +08:00
|
|
|
const char *fmt,
|
2004-11-24 08:45:41 +08:00
|
|
|
va_list ap)
|
|
|
|
{
|
2005-02-08 09:33:19 +08:00
|
|
|
_REENT_SMALL_CHECK_INIT (ptr);
|
2004-11-24 08:45:41 +08:00
|
|
|
return _vfiprintf_r (ptr, _stdout_r (ptr), fmt, ap);
|
|
|
|
}
|