1
0
mirror of https://github.com/pevans/erc-c.git synced 2025-01-18 10:30:37 +00:00
erc-c/include/log.h

44 lines
1.3 KiB
C
Raw Normal View History

2017-11-21 23:24:51 -06:00
#ifndef _LOG_H_
#define _LOG_H_
2017-12-06 16:52:33 -06:00
#include <stdio.h>
2017-12-15 16:52:26 -06:00
#include <string.h>
#include <errno.h>
#include <sys/syslog.h>
2017-12-06 16:52:33 -06:00
2017-12-02 13:05:53 -06:00
#define LOG_FILENAME "/tmp/emp.log"
2017-12-09 15:16:56 -06:00
enum log_errcode {
OK = 1,
ERR_OOM, // out of memory
ERR_OOB, // out of bounds
2017-12-15 16:52:26 -06:00
ERR_BADFILE,
ERR_BADOPT, // bad option (e.g. from getopt)
2018-02-04 00:06:04 -06:00
ERR_INVALID, // invalid operation
ERR_GFXINIT, // couldn't initialize graphics
2017-12-19 21:50:50 -06:00
ERR_GFXOP, // we couldn't execute a specific graphic operation
2017-12-09 15:16:56 -06:00
};
extern FILE *log_stream();
extern int log_close();
2017-12-06 16:43:30 -06:00
extern void log_open(FILE *);
2017-12-26 16:44:28 -06:00
extern void log_write(int, const char *, ...);
2017-11-21 23:24:51 -06:00
2017-12-06 21:25:47 -06:00
/*
* Here we have a couple of convenience macros that abstracts the log
* level number.
*/
2017-11-21 23:24:51 -06:00
#define log_critical(...) log_write(0, __VA_ARGS__)
#define log_error(...) log_write(0, __VA_ARGS__)
#define log_alert(...) log_write(LOG_ALERT, __VA_ARGS__)
#define log_crit(...) log_write(LOG_CRIT, __VA_ARGS__)
#define log_debug(...) log_write(LOG_DEBUG, __VA_ARGS__)
#define log_emerg(...) log_write(LOG_EMERG, __VA_ARGS__)
#define log_err(...) log_write(LOG_ERR, __VA_ARGS__)
#define log_info(...) log_write(LOG_INFO, __VA_ARGS__)
#define log_notice(...) log_write(LOG_NOTICE, __VA_ARGS__)
#define log_warning(...) log_write(LOG_WARNING, __VA_ARGS__)
2017-11-21 23:24:51 -06:00
#endif