2009-12-20 00:37:15 +03:00
|
|
|
/*
|
2011-07-10 16:33:19 +04:00
|
|
|
* vim:ts=4:sw=4:expandtab
|
2009-12-20 00:37:15 +03:00
|
|
|
*
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
2015-04-04 03:17:56 +03:00
|
|
|
* © 2009 Michael Stapelberg and contributors (see also: LICENSE)
|
2009-12-20 00:37:15 +03:00
|
|
|
*
|
2012-07-22 02:16:52 +04:00
|
|
|
* log.c: Logging functions.
|
2009-12-20 00:37:15 +03:00
|
|
|
*
|
|
|
|
*/
|
2013-12-29 06:11:50 +04:00
|
|
|
#pragma once
|
2009-12-20 00:37:15 +03:00
|
|
|
|
2016-10-11 10:13:35 +03:00
|
|
|
#include <config.h>
|
|
|
|
|
2009-12-20 00:37:15 +03:00
|
|
|
#include <stdarg.h>
|
2010-03-19 20:48:36 +03:00
|
|
|
#include <stdbool.h>
|
2009-12-20 00:37:15 +03:00
|
|
|
|
2012-08-12 14:20:15 +04:00
|
|
|
/* We will include libi3.h which define its own version of LOG, ELOG.
|
2012-08-10 17:39:50 +04:00
|
|
|
* We want *our* version, so we undef the libi3 one. */
|
2012-08-12 14:20:15 +04:00
|
|
|
#if defined(LOG)
|
|
|
|
#undef LOG
|
|
|
|
#endif
|
2012-08-10 17:39:50 +04:00
|
|
|
#if defined(ELOG)
|
|
|
|
#undef ELOG
|
|
|
|
#endif
|
2013-12-24 13:35:56 +04:00
|
|
|
#if defined(DLOG)
|
|
|
|
#undef DLOG
|
|
|
|
#endif
|
2012-08-12 14:20:15 +04:00
|
|
|
/** ##__VA_ARGS__ means: leave out __VA_ARGS__ completely if it is empty, that
|
|
|
|
is, delete the preceding comma */
|
|
|
|
#define LOG(fmt, ...) verboselog(fmt, ##__VA_ARGS__)
|
2009-12-20 00:37:15 +03:00
|
|
|
#define ELOG(fmt, ...) errorlog("ERROR: " fmt, ##__VA_ARGS__)
|
2016-10-10 22:16:09 +03:00
|
|
|
#define DLOG(fmt, ...) debuglog("%s:%s:%d - " fmt, STRIPPED__FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__)
|
2009-12-20 00:37:15 +03:00
|
|
|
|
2011-07-10 16:33:19 +04:00
|
|
|
extern char *errorfilename;
|
2011-12-10 02:27:35 +04:00
|
|
|
extern char *shmlogname;
|
|
|
|
extern int shmlog_size;
|
2011-07-10 16:33:19 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes logging by creating an error logfile in /tmp (or
|
|
|
|
* XDG_RUNTIME_DIR, see get_process_filename()).
|
|
|
|
*
|
|
|
|
*/
|
2012-03-31 12:53:04 +04:00
|
|
|
void init_logging(void);
|
2009-12-20 00:37:15 +03:00
|
|
|
|
2013-06-05 17:04:57 +04:00
|
|
|
/**
|
|
|
|
* Opens the logbuffer.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void open_logbuffer(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Closes the logbuffer.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void close_logbuffer(void);
|
|
|
|
|
2013-06-05 17:06:53 +04:00
|
|
|
/**
|
|
|
|
* Checks if debug logging is active.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool get_debug_logging(void);
|
|
|
|
|
2009-12-20 00:37:15 +03:00
|
|
|
/**
|
2012-07-22 02:16:52 +04:00
|
|
|
* Set debug logging.
|
2009-12-20 00:37:15 +03:00
|
|
|
*
|
|
|
|
*/
|
2012-07-22 02:16:52 +04:00
|
|
|
void set_debug_logging(const bool _debug_logging);
|
2009-12-20 00:37:15 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set verbosity of i3. If verbose is set to true, informative messages will
|
|
|
|
* be printed to stdout. If verbose is set to false, only errors will be
|
|
|
|
* printed.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void set_verbosity(bool _verbose);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the given message to stdout while prefixing the current time to it,
|
2012-07-22 02:16:52 +04:00
|
|
|
* but only if debug logging was activated.
|
2009-12-20 00:37:15 +03:00
|
|
|
*
|
|
|
|
*/
|
2012-08-05 17:59:08 +04:00
|
|
|
void debuglog(char *fmt, ...)
|
2014-06-19 13:20:32 +04:00
|
|
|
__attribute__((format(printf, 1, 2)));
|
2009-12-20 00:37:15 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the given message to stdout while prefixing the current time to it.
|
|
|
|
*
|
|
|
|
*/
|
2012-08-05 17:59:08 +04:00
|
|
|
void errorlog(char *fmt, ...)
|
2014-06-19 13:20:32 +04:00
|
|
|
__attribute__((format(printf, 1, 2)));
|
2009-12-20 00:37:15 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the given message to stdout while prefixing the current time to it,
|
|
|
|
* but only if verbose mode is activated.
|
|
|
|
*
|
|
|
|
*/
|
2012-08-05 17:59:08 +04:00
|
|
|
void verboselog(char *fmt, ...)
|
2014-06-19 13:20:32 +04:00
|
|
|
__attribute__((format(printf, 1, 2)));
|
2009-12-20 00:37:15 +03:00
|
|
|
|
2012-08-11 03:50:37 +04:00
|
|
|
/**
|
|
|
|
* Deletes the unused log files. Useful if i3 exits immediately, eg.
|
|
|
|
* because --get-socketpath was called. We don't care for syscall
|
|
|
|
* failures. This function is invoked automatically when exiting.
|
|
|
|
*/
|
|
|
|
void purge_zerobyte_logfile(void);
|