2022-07-28 15:15:04 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2022 Jordan Bancino <@jordan:bancino.net>
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person
|
|
|
|
* obtaining a copy of this software and associated documentation files
|
|
|
|
* (the "Software"), to deal in the Software without restriction,
|
|
|
|
* including without limitation the rights to use, copy, modify, merge,
|
|
|
|
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
|
|
* and to permit persons to whom the Software is furnished to do so,
|
|
|
|
* subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be
|
2022-07-28 16:00:52 +00:00
|
|
|
* included in all copies or portions of the Software.
|
2022-07-28 15:15:04 +00:00
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
*/
|
2022-07-29 16:32:52 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Log.h: A heavily-modified version of Shlog, a simple C logging
|
|
|
|
* facility that allows for colorful output, timestamps, and custom
|
|
|
|
* log levels. This library differs from Shlog in that the naming
|
|
|
|
* conventions have been updated to be consistent with Telodendria.
|
|
|
|
*
|
|
|
|
* Shlog was originally a learning project. It worked well, however,
|
|
|
|
* and produced elegant logging output, so it was chosen to be the
|
|
|
|
* main logging mechanism of Telodendria. The original Shlog project
|
|
|
|
* is now dead; Shlog lives on now only as Telodendria's logging
|
|
|
|
* mechanism.
|
|
|
|
*
|
|
|
|
* In the name of simplicity and portability, I opted to use an
|
|
|
|
* in-house logging system instead of syslog(), or other system logging
|
|
|
|
* mechanisms. However, this API could easily be patched to allow
|
|
|
|
* logging via other mechanisms that support the same features.
|
|
|
|
*/
|
2022-07-23 00:19:12 +00:00
|
|
|
#ifndef TELODENDRIA_LOG_H
|
|
|
|
#define TELODENDRIA_LOG_H
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
2022-07-29 16:32:52 +00:00
|
|
|
/*
|
|
|
|
* There are five log "levels," each one showing more information than
|
|
|
|
* the previous one. A level of LOG_ERROR shows only errors, while a
|
|
|
|
* level of LOG_DEBUG shows all output possible.
|
|
|
|
*/
|
2022-07-25 19:25:06 +00:00
|
|
|
typedef enum LogLevel
|
|
|
|
{
|
2022-07-23 00:19:12 +00:00
|
|
|
LOG_ERROR,
|
|
|
|
LOG_WARNING,
|
|
|
|
LOG_TASK,
|
|
|
|
LOG_MESSAGE,
|
|
|
|
LOG_DEBUG
|
|
|
|
} LogLevel;
|
|
|
|
|
2022-07-29 16:32:52 +00:00
|
|
|
/*
|
|
|
|
* The possible flags that can be applied to alter the behavior of
|
|
|
|
* the logger
|
|
|
|
*/
|
2022-07-25 19:25:06 +00:00
|
|
|
typedef enum LogFlag
|
|
|
|
{
|
2022-07-29 16:32:52 +00:00
|
|
|
LOG_FLAG_COLOR = (1 << 0) /* Enable color output on TTYs */
|
2022-07-23 00:19:12 +00:00
|
|
|
} LogFlag;
|
|
|
|
|
2022-07-29 16:32:52 +00:00
|
|
|
/*
|
|
|
|
* The log configurations structure in which all settings exist.
|
|
|
|
* It's not super elegant to pass around a pointer to the logging
|
|
|
|
* configuration
|
|
|
|
*/
|
2022-07-23 00:19:12 +00:00
|
|
|
typedef struct LogConfig LogConfig;
|
|
|
|
|
|
|
|
extern LogConfig *
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigCreate(void);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigFree(LogConfig * config);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigLevelSet(LogConfig * config, LogLevel level);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern LogLevel
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigLevelGet(LogConfig * config);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigIndentSet(LogConfig * config, size_t indent);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern size_t
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigIndentGet(LogConfig * config);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigIndent(LogConfig * config);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigUnindent(LogConfig * config);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigOutputSet(LogConfig * config, FILE * out);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigFlagSet(LogConfig * config, int flags);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigFlagClear(LogConfig * config, int flags);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern int
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigFlagGet(LogConfig * config, int flags);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
LogConfigTimeStampFormatSet(LogConfig * config, char *tsFmt);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
extern void
|
2022-07-25 19:25:06 +00:00
|
|
|
Log(LogConfig * config, LogLevel level, const char *msg,...);
|
2022-07-23 00:19:12 +00:00
|
|
|
|
|
|
|
#endif
|