mirror of
https://codeberg.org/dnkl/foot.git
synced 2026-03-11 05:33:55 -04:00
log: caller can control syslog level
This commit is contained in:
parent
7a3fb9284e
commit
a0fcec3a3d
4 changed files with 19 additions and 7 deletions
2
client.c
2
client.c
|
|
@ -40,7 +40,7 @@ print_usage(const char *prog_name)
|
||||||
int
|
int
|
||||||
main(int argc, char *const *argv)
|
main(int argc, char *const *argv)
|
||||||
{
|
{
|
||||||
log_init(LOG_FACILITY_USER);
|
log_init(LOG_FACILITY_USER, LOG_CLASS_WARNING);
|
||||||
int ret = EXIT_FAILURE;
|
int ret = EXIT_FAILURE;
|
||||||
|
|
||||||
const char *const prog_name = argv[0];
|
const char *const prog_name = argv[0];
|
||||||
|
|
|
||||||
18
log.c
18
log.c
|
|
@ -13,17 +13,29 @@
|
||||||
|
|
||||||
static bool colorize = false;
|
static bool colorize = false;
|
||||||
|
|
||||||
|
static void __attribute__((constructor))
|
||||||
|
init(void)
|
||||||
|
{
|
||||||
|
colorize = isatty(STDOUT_FILENO);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
log_init(enum log_facility syslog_facility)
|
log_init(enum log_facility syslog_facility, enum log_class syslog_level)
|
||||||
{
|
{
|
||||||
static const int facility_map[] = {
|
static const int facility_map[] = {
|
||||||
[LOG_FACILITY_USER] = LOG_USER,
|
[LOG_FACILITY_USER] = LOG_USER,
|
||||||
[LOG_FACILITY_DAEMON] = LOG_DAEMON,
|
[LOG_FACILITY_DAEMON] = LOG_DAEMON,
|
||||||
};
|
};
|
||||||
|
|
||||||
colorize = isatty(STDOUT_FILENO);
|
static const int level_map[] = {
|
||||||
|
[LOG_CLASS_ERROR] = LOG_ERR,
|
||||||
|
[LOG_CLASS_WARNING] = LOG_WARNING,
|
||||||
|
[LOG_CLASS_INFO] = LOG_INFO,
|
||||||
|
[LOG_CLASS_DEBUG] = LOG_DEBUG,
|
||||||
|
};
|
||||||
|
|
||||||
openlog(NULL, /*LOG_PID*/0, facility_map[syslog_facility]);
|
openlog(NULL, /*LOG_PID*/0, facility_map[syslog_facility]);
|
||||||
setlogmask(LOG_UPTO(LOG_WARNING));
|
setlogmask(LOG_UPTO(level_map[syslog_level]));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
||||||
2
log.h
2
log.h
|
|
@ -3,7 +3,7 @@
|
||||||
enum log_facility { LOG_FACILITY_USER, LOG_FACILITY_DAEMON };
|
enum log_facility { LOG_FACILITY_USER, LOG_FACILITY_DAEMON };
|
||||||
enum log_class { LOG_CLASS_ERROR, LOG_CLASS_WARNING, LOG_CLASS_INFO, LOG_CLASS_DEBUG };
|
enum log_class { LOG_CLASS_ERROR, LOG_CLASS_WARNING, LOG_CLASS_INFO, LOG_CLASS_DEBUG };
|
||||||
|
|
||||||
void log_init(enum log_facility syslog_facility);
|
void log_init(enum log_facility syslog_facility, enum log_class syslog_level);
|
||||||
void log_deinit(void);
|
void log_deinit(void);
|
||||||
|
|
||||||
void log_msg(enum log_class log_class, const char *module,
|
void log_msg(enum log_class log_class, const char *module,
|
||||||
|
|
|
||||||
4
main.c
4
main.c
|
|
@ -165,6 +165,8 @@ main(int argc, char *const *argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
log_init(as_server ? LOG_FACILITY_DAEMON : LOG_FACILITY_USER, LOG_CLASS_WARNING);
|
||||||
|
|
||||||
argc -= optind;
|
argc -= optind;
|
||||||
argv += optind;
|
argv += optind;
|
||||||
|
|
||||||
|
|
@ -176,8 +178,6 @@ main(int argc, char *const *argv)
|
||||||
struct server *server = NULL;
|
struct server *server = NULL;
|
||||||
struct shutdown_context shutdown_ctx = {.term = &term, .exit_code = EXIT_FAILURE};
|
struct shutdown_context shutdown_ctx = {.term = &term, .exit_code = EXIT_FAILURE};
|
||||||
|
|
||||||
log_init(as_server ? LOG_FACILITY_DAEMON : LOG_FACILITY_USER);
|
|
||||||
|
|
||||||
if ((fdm = fdm_init()) == NULL)
|
if ((fdm = fdm_init()) == NULL)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue