2001-08-21 12:56:08 +00:00
/*
2001-10-03 11:06:31 +00:00
* Copyright ( C ) 2001 Sistina Software ( UK ) Limited .
2001-08-21 12:56:08 +00:00
*
2001-10-03 11:06:31 +00:00
* This file is released under the GPL .
2001-08-21 12:56:08 +00:00
*/
2001-09-25 12:49:28 +00:00
# ifndef _LVM_LOG_H
# define _LVM_LOG_H
2001-08-21 12:56:08 +00:00
2001-10-23 18:20:27 +00: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 20:55:49 +00:00
# include <stdio.h> /* FILE */
# include <string.h> /* strerror() */
2001-10-04 10:13:07 +00:00
# include <errno.h>
2001-08-21 12:56:08 +00: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
2004-03-26 11:45:01 +00:00
# define VERBOSE_BASE_LEVEL _LOG_WARN
2003-07-04 22:34:56 +00:00
void init_log_file ( const char * log_file , int append ) ;
void init_log_direct ( const char * log_file , int append ) ;
void init_log_while_suspended ( int log_while_suspended ) ;
2001-10-03 11:06:31 +00:00
void fin_log ( void ) ;
2003-07-04 22:34:56 +00:00
void release_log_memory ( void ) ;
2001-08-21 12:56:08 +00:00
void init_syslog ( int facility ) ;
void fin_syslog ( void ) ;
void init_verbose ( int level ) ;
void init_test ( int level ) ;
2002-01-29 17:23:33 +00:00
void init_partial ( int level ) ;
2003-04-30 15:22:52 +00:00
void init_pvmove ( int level ) ;
2001-08-21 12:56:08 +00:00
void init_debug ( int level ) ;
2002-01-22 15:33:40 +00:00
void init_cmd_name ( int status ) ;
void init_msg_prefix ( const char * prefix ) ;
void init_indent ( int indent ) ;
2002-07-10 20:43:32 +00:00
void init_ignorelockingfailure ( int level ) ;
2002-01-22 15:33:40 +00:00
void set_cmd_name ( const char * cmd_name ) ;
2001-08-21 12:56:08 +00:00
int test_mode ( void ) ;
2002-01-29 17:23:33 +00:00
int partial_mode ( void ) ;
2003-04-30 15:22:52 +00:00
int pvmove_mode ( void ) ;
2001-08-21 12:56:08 +00:00
int debug_level ( void ) ;
2002-07-10 20:43:32 +00:00
int ignorelockingfailure ( void ) ;
2001-08-21 12:56:08 +00:00
2002-03-15 22:54:04 +00:00
/* Suppress messages to stdout/stderr */
void log_suppress ( int suppress ) ;
2003-07-04 22:34:56 +00:00
/* Suppress messages to syslog */
void syslog_suppress ( int suppress ) ;
2004-03-26 14:47:14 +00:00
typedef void ( * lvm2_log_fn_t ) ( int level , const char * file , int line ,
const char * message ) ;
void init_log_fn ( lvm2_log_fn_t log_fn ) ;
2001-10-03 11:06:31 +00:00
void print_log ( int level , const char * file , int line , const char * format , . . . )
2002-12-12 20:55:49 +00:00
__attribute__ ( ( format ( printf , 4 , 5 ) ) ) ;
2001-08-21 12:56:08 +00: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 18:25:18 +00:00
# define stack log_debug("<backtrace>") /* Backtrace on error */
2001-08-21 12:56:08 +00:00
2003-03-24 18:08:53 +00:00
# define log_error(args...) log_err(args)
# define log_print(args...) log_warn(args)
# define log_verbose(args...) log_notice(args)
# define log_very_verbose(args...) log_info(args)
2001-08-21 12:56:08 +00:00
2001-10-23 18:20:27 +00:00
/* Two System call equivalents */
2001-10-10 16:36:32 +00: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 ) )
2003-07-04 22:34:56 +00:00
# define log_sys_debug(x, y) \
log_debug ( " %s: %s failed: %s " , y , x , strerror ( errno ) )
2001-10-10 16:36:32 +00:00
2001-08-21 12:56:08 +00:00
# endif