mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-20 18:09:23 +03:00
98 lines
2.7 KiB
C
98 lines
2.7 KiB
C
|
/*
|
||
|
* tools/lib/lvm_log.h
|
||
|
*
|
||
|
* Copyright (C) 2001 Sistina Software
|
||
|
*
|
||
|
*
|
||
|
* This LVM library is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU Library General Public
|
||
|
* License as published by the Free Software Foundation; either
|
||
|
* version 2 of the License, or (at your option) any later version.
|
||
|
*
|
||
|
* This LVM library is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
* Library General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Library General Public
|
||
|
* License along with this LVM library; if not, write to the Free
|
||
|
* Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
|
||
|
* MA 02111-1307, USA
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* Changelog
|
||
|
*
|
||
|
* 22/01/2001 - First version (Joe Thornber)
|
||
|
* 25/04/2001 - Remove some spurious ##s that annoyed newer gcc versions.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef LVM_LOG_H
|
||
|
#define LVM_LOG_H
|
||
|
|
||
|
#include <stdio.h>
|
||
|
|
||
|
#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);
|
||
|
void fin_log();
|
||
|
|
||
|
void init_syslog(int facility);
|
||
|
void fin_syslog(void);
|
||
|
|
||
|
void init_verbose(int level);
|
||
|
void init_test(int level);
|
||
|
void init_debug(int level);
|
||
|
|
||
|
int test_mode(void);
|
||
|
int debug_level(void);
|
||
|
|
||
|
void print_log(int level, const char *file, int line, const char *format, ...);
|
||
|
|
||
|
#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)
|
||
|
#define log_sys_err(x) log_debug("system call '%s' failed (%s)", \
|
||
|
x, strerror(errno))
|
||
|
|
||
|
#define stack log_debug( "stack trace" )
|
||
|
|
||
|
/*
|
||
|
* Macros to use for messages:
|
||
|
*
|
||
|
* log_error - always print to stderr
|
||
|
* log_print - always print to stdout
|
||
|
* 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 -d.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#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)
|
||
|
|
||
|
#endif
|
||
|
|
||
|
/*
|
||
|
* Local variables:
|
||
|
* c-file-style: "linux"
|
||
|
* End:
|
||
|
*/
|