|
|
@ -33,34 +33,38 @@ flushn( void ) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void ATTR_PRINTFLIKE(1, 0) |
|
|
|
static void ATTR_PRINTFLIKE(1, 0) |
|
|
|
printn( const char *msg, va_list va ) |
|
|
|
vprint( const char *msg, va_list va ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (*msg == '\v') |
|
|
|
|
|
|
|
msg++; |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
flushn(); |
|
|
|
|
|
|
|
vprintf( msg, va ); |
|
|
|
vprintf( msg, va ); |
|
|
|
fflush( stdout ); |
|
|
|
fflush( stdout ); |
|
|
|
|
|
|
|
need_nl = 0; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
|
vdebug( int cat, const char *msg, va_list va ) |
|
|
|
print( const char *msg, ... ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (DFlags & cat) { |
|
|
|
va_list va; |
|
|
|
vprintf( msg, va ); |
|
|
|
|
|
|
|
fflush( stdout ); |
|
|
|
va_start( va, msg ); |
|
|
|
need_nl = 0; |
|
|
|
vprint( msg, va ); |
|
|
|
} |
|
|
|
va_end( va ); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
static void ATTR_PRINTFLIKE(1, 0) |
|
|
|
vdebugn( int cat, const char *msg, va_list va ) |
|
|
|
vprintn( const char *msg, va_list va ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (DFlags & cat) { |
|
|
|
vprint( msg, va ); |
|
|
|
vprintf( msg, va ); |
|
|
|
|
|
|
|
fflush( stdout ); |
|
|
|
|
|
|
|
need_nl = 1; |
|
|
|
need_nl = 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
printn( const char *msg, ... ) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
va_list va; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
va_start( va, msg ); |
|
|
|
|
|
|
|
vprintn( msg, va ); |
|
|
|
|
|
|
|
va_end( va ); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
@ -75,6 +79,16 @@ progress( const char *msg, ... ) |
|
|
|
need_nl = 1; |
|
|
|
need_nl = 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void ATTR_PRINTFLIKE(1, 0) |
|
|
|
|
|
|
|
nvprint( const char *msg, va_list va ) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
if (*msg == '\v') |
|
|
|
|
|
|
|
msg++; |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
flushn(); |
|
|
|
|
|
|
|
vprint( msg, va ); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
|
info( const char *msg, ... ) |
|
|
|
info( const char *msg, ... ) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -82,9 +96,8 @@ info( const char *msg, ... ) |
|
|
|
|
|
|
|
|
|
|
|
if (DFlags & VERBOSE) { |
|
|
|
if (DFlags & VERBOSE) { |
|
|
|
va_start( va, msg ); |
|
|
|
va_start( va, msg ); |
|
|
|
printn( msg, va ); |
|
|
|
nvprint( msg, va ); |
|
|
|
va_end( va ); |
|
|
|
va_end( va ); |
|
|
|
need_nl = 0; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -95,7 +108,7 @@ infon( const char *msg, ... ) |
|
|
|
|
|
|
|
|
|
|
|
if (DFlags & VERBOSE) { |
|
|
|
if (DFlags & VERBOSE) { |
|
|
|
va_start( va, msg ); |
|
|
|
va_start( va, msg ); |
|
|
|
printn( msg, va ); |
|
|
|
nvprint( msg, va ); |
|
|
|
va_end( va ); |
|
|
|
va_end( va ); |
|
|
|
need_nl = 1; |
|
|
|
need_nl = 1; |
|
|
|
} |
|
|
|
} |
|
|
@ -108,9 +121,8 @@ notice( const char *msg, ... ) |
|
|
|
|
|
|
|
|
|
|
|
if (!(DFlags & QUIET)) { |
|
|
|
if (!(DFlags & QUIET)) { |
|
|
|
va_start( va, msg ); |
|
|
|
va_start( va, msg ); |
|
|
|
printn( msg, va ); |
|
|
|
nvprint( msg, va ); |
|
|
|
va_end( va ); |
|
|
|
va_end( va ); |
|
|
|
need_nl = 0; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|