2001-08-21 16:56:08 +04:00
/*
2001-10-03 15:06:31 +04:00
* Copyright ( C ) 2001 Sistina Software ( UK ) Limited .
2001-08-21 16:56:08 +04:00
*
2001-10-03 15:06:31 +04:00
* This file is released under the GPL .
2001-08-21 16:56:08 +04:00
*/
2001-09-25 16:49:28 +04:00
# ifndef _LVM_LOG_H
# define _LVM_LOG_H
2001-08-21 16:56:08 +04:00
2001-10-23 22:20:27 +04:00
/*
* printf ( ) - style macros to use for messages :
*
* log_error - always print to stderr .
* log_print - always print to stdout . Use this instead of printf .
* log_verbose - print to stdout if verbose is set ( - v )
* log_very_verbose - print to stdout if verbose is set twice ( - vv )
* log_debug - print to stdout if verbose is set three times ( - vvv )
*
* In addition , messages will be logged to file or syslog if they
* are more serious than the log level specified with the log / debug_level
* parameter in the configuration file . These messages get the file
* and line number prepended . ' stack ' ( without arguments ) can be used
* to log this information at debug level .
*
* log_sys_error and log_sys_very_verbose are for errors from system calls
* e . g . log_sys_error ( " stat " , filename ) ;
* / dev / fd / 7 : stat failed : No such file or directory
*
*/
2002-12-12 23:55:49 +03:00
# include <stdio.h> /* FILE */
# include <string.h> /* strerror() */
2001-10-04 14:13:07 +04:00
# include <errno.h>
2001-08-21 16:56:08 +04:00
# define _LOG_DEBUG 7
# define _LOG_INFO 6
# define _LOG_NOTICE 5
# define _LOG_WARN 4
# define _LOG_ERR 3
# define _LOG_FATAL 2
void init_log ( FILE * fp ) ;
2001-10-03 15:06:31 +04:00
void fin_log ( void ) ;
2001-08-21 16:56:08 +04:00
void init_syslog ( int facility ) ;
void fin_syslog ( void ) ;
void init_verbose ( int level ) ;
void init_test ( int level ) ;
2002-01-29 20:23:33 +03:00
void init_partial ( int level ) ;
2001-08-21 16:56:08 +04:00
void init_debug ( int level ) ;
2002-01-22 18:33:40 +03:00
void init_cmd_name ( int status ) ;
void init_msg_prefix ( const char * prefix ) ;
void init_indent ( int indent ) ;
2002-07-11 00:43:32 +04:00
void init_ignorelockingfailure ( int level ) ;
2002-01-22 18:33:40 +03:00
void set_cmd_name ( const char * cmd_name ) ;
2001-08-21 16:56:08 +04:00
int test_mode ( void ) ;
2002-01-29 20:23:33 +03:00
int partial_mode ( void ) ;
2001-08-21 16:56:08 +04:00
int debug_level ( void ) ;
2002-07-11 00:43:32 +04:00
int ignorelockingfailure ( void ) ;
2001-08-21 16:56:08 +04:00
2002-03-16 01:54:04 +03:00
/* Suppress messages to stdout/stderr */
void log_suppress ( int suppress ) ;
2001-10-03 15:06:31 +04:00
void print_log ( int level , const char * file , int line , const char * format , . . . )
2002-12-12 23:55:49 +03:00
__attribute__ ( ( format ( printf , 4 , 5 ) ) ) ;
2001-08-21 16:56:08 +04:00
# define plog(l, x...) print_log(l, __FILE__, __LINE__ , ## x)
# define log_debug(x...) plog(_LOG_DEBUG, x)
# define log_info(x...) plog(_LOG_INFO, x)
# define log_notice(x...) plog(_LOG_NOTICE, x)
# define log_warn(x...) plog(_LOG_WARN, x)
# define log_err(x...) plog(_LOG_ERR, x)
# define log_fatal(x...) plog(_LOG_FATAL, x)
2002-02-11 21:25:18 +03:00
# define stack log_debug("<backtrace>") /* Backtrace on error */
2001-08-21 16:56:08 +04:00
# define log_error(fmt, args...) log_err(fmt , ## args)
# define log_print(fmt, args...) log_warn(fmt , ## args)
# define log_verbose(fmt, args...) log_notice(fmt , ## args)
# define log_very_verbose(fmt, args...) log_info(fmt , ## args)
2001-10-23 22:20:27 +04:00
/* Two System call equivalents */
2001-10-10 20:36:32 +04:00
# define log_sys_error(x, y) \
log_err ( " %s: %s failed: %s " , y , x , strerror ( errno ) )
# define log_sys_very_verbose(x, y) \
log_info ( " %s: %s failed: %s " , y , x , strerror ( errno ) )
2001-08-21 16:56:08 +04:00
# endif