#ifndef VSPRINTF_H #define VSPRINTF_H /** @file * * printf() and friends * * Etherboot's printf() functions understand the following subset of * the standard C printf()'s format specifiers: * * - Flag characters * - '#' - Alternate form (i.e. "0x" prefix) * - '0' - Zero-pad * - Field widths * - Length modifiers * - 'hh' - Signed / unsigned char * - 'h' - Signed / unsigned short * - 'l' - Signed / unsigned long * - 'll' - Signed / unsigned long long * - 'z' - Signed / unsigned size_t * - Conversion specifiers * - 'd' - Signed decimal * - 'x','X' - Unsigned hexadecimal * - 'c' - Character * - 's' - String * - 'p' - Pointer * * Hexadecimal numbers are always zero-padded to the specified field * width (if any); decimal numbers are always space-padded. Decimal * long longs are not supported. * */ #include #define PRINTF_NO_LENGTH ( ( size_t ) -1 ) extern int vsnprintf ( char *buf, size_t size, const char *fmt, va_list args ); extern int vprintf ( const char *fmt, va_list args ); extern int __attribute__ (( format ( printf, 3, 4 ) )) snprintf ( char *buf, size_t size, const char *fmt, ... ); extern int __attribute__ (( format ( printf, 1, 2 ) )) printf ( const char *fmt, ... ); /** * Write a formatted string to a buffer * * @v buf Buffer into which to write the string * @v fmt Format string * @v ... Arguments corresponding to the format string * @ret len Length of formatted string */ #define sprintf( buf, fmt, ... ) \ snprintf ( (buf), PRINTF_NO_LENGTH, (fmt), ## __VA_ARGS__ ) /** * Write a formatted string to a buffer * * @v buf Buffer into which to write the string * @v fmt Format string * @v args Arguments corresponding to the format string * @ret len Length of formatted string */ static inline int vsprintf ( char *buf, const char *fmt, va_list args ) { return vsnprintf ( buf, PRINTF_NO_LENGTH, fmt, args ); } #endif /* VSPRINTF_H */