telodendria/src/include/Log.h

121 lines
3.5 KiB
C
Raw Normal View History

/*
* 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.
*
* 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.
*/
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
*/
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 *
LogConfigCreate(void);
2022-07-23 00:19:12 +00:00
extern void
LogConfigFree(LogConfig * config);
2022-07-23 00:19:12 +00:00
extern void
LogConfigLevelSet(LogConfig * config, LogLevel level);
2022-07-23 00:19:12 +00:00
extern LogLevel
LogConfigLevelGet(LogConfig * config);
2022-07-23 00:19:12 +00:00
extern void
LogConfigIndentSet(LogConfig * config, size_t indent);
2022-07-23 00:19:12 +00:00
extern size_t
LogConfigIndentGet(LogConfig * config);
2022-07-23 00:19:12 +00:00
extern void
LogConfigIndent(LogConfig * config);
2022-07-23 00:19:12 +00:00
extern void
LogConfigUnindent(LogConfig * config);
2022-07-23 00:19:12 +00:00
extern void
LogConfigOutputSet(LogConfig * config, FILE * out);
2022-07-23 00:19:12 +00:00
extern void
LogConfigFlagSet(LogConfig * config, int flags);
2022-07-23 00:19:12 +00:00
extern void
LogConfigFlagClear(LogConfig * config, int flags);
2022-07-23 00:19:12 +00:00
extern int
LogConfigFlagGet(LogConfig * config, int flags);
2022-07-23 00:19:12 +00:00
extern void
LogConfigTimeStampFormatSet(LogConfig * config, char *tsFmt);
2022-07-23 00:19:12 +00:00
extern void
Log(LogConfig * config, LogLevel level, const char *msg,...);
2022-07-23 00:19:12 +00:00
#endif