vfprintf

Writes output to a stream under format control, using a variable argument list.

Library:LibC
Classification:ANSI
Service:File and Directory I/O

Syntax

  #include <stdarg.h> 
  #include <stdio.h> 
   
  int vfprintf (
     FILE         *fp,
     const char   *format,
     va_list       arg);
  

Parameters

fp

(IN) Points to the file.

format

(IN) Points to the format control string. See Print Format Control Strings.

arg

(IN) Specifies a variable argument list. The number of arguments is determined by the format string.

Return Values

If successful, returns the number of characters written. If an output error occurred, returns a negative value and sets errno to one of the following:

Decimal

Constant

Description

4

EBADF

The file descriptor is not a valid file descriptor open for writing.

5

ENOMEM

Insufficient storage space is available.

9

EINVAL

The format string contains insufficient arguments.

12

ENOSPC

No free space remains on the device containing the file.

24

EAGAIN

The O_NONBLOCK flag is set for the file descriptor, and the process cannot immediately perform the write operation.

25

ENXIO

A request was made of a nonexistent device, or the request was outside the capabilities of the device.

28

EIO

A physical I/O error has occurred.

32

EPIPE

An attempt was made to write to a pipe or FIFO that is not open for reading by any process.

63

EINTR

A signal interrupted the write operation.

71

EFBIG

An attempt was made to write to a file that exceeds the maximum file size.

101

EILSEQ

A wide-character code that does not correspond to a valid character has been detected.

Remarks

The vfprintf function writes output to the file pointed to by fp under control of the format parameter. The vfprintf function is equivalent to fprintf, with the variable arguments replaced with arg, which has been initialized by the va_start macro.

See Also