/* Copyright 2005, 2007 Shaun Jackman * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ /* FUNCTION <>, <>---print to a file descriptor INDEX dprintf INDEX _dprintf_r INDEX vdprintf INDEX _vdprintf_r SYNOPSIS #include #include int dprintf(int <[fd]>, const char *restrict <[format]>, ...); int vdprintf(int <[fd]>, const char *restrict <[format]>, va_list <[ap]>); int dprintf( int <[fd]>, const char *restrict <[format]>, ...); int vdprintf( int <[fd]>, const char *restrict <[format]>, va_list <[ap]>); DESCRIPTION <> and <> allow printing a format, similarly to <>, but write to a file descriptor instead of to a <> stream. The functions <<_dprintf_r>> and <<_vdprintf_r>> are simply reentrant versions of the functions above. RETURNS The return value and errors are exactly as for <>, except that <> may also be set to <> if the heap is exhausted. PORTABILITY This function is originally a GNU extension in glibc and is not portable. Supporting OS subroutines required: <>, <>. */ #define _DEFAULT_SOURCE #include <_ansi.h> #include #include #include #include "local.h" int dprintf (int fd, const char *__restrict format, ...) { va_list ap; int n; _REENT_SMALL_CHECK_INIT (ptr); va_start (ap, format); n = vdprintf ( fd, format, ap); va_end (ap); return n; } #ifdef _NANO_FORMATTED_IO int diprintf (int, const char *, ...) _ATTRIBUTE ((__alias__("dprintf"))); #endif