youmetme 56e1ac52ff fix 拦截器level参数无效 (#15)
* #feat 增强Fatal级别的底色,修改logging类的方法

* 更新版本号

* 加入test脚本

* fix:conanfile

* test action

* 修复错别字

* add test on windows action

* fix test on windows action

* fix action on windows

* fix

* fix 内存分配错误

* fix msvc 不支持中文注释,删除中文注释

* test on windows and test  chinese char

* ersion 0.2.4

* feature:根据文件大小分割日志

* fix:内存泄露

* fix:使用char偏移单位

* add english brief

* 修改api函数名,加入Default关键字,减除歧义

* Multiple substring interceptors

* 更新版本号

* #fix 拦截器对level参数无效

* fix
2024-11-21 16:02:40 +08:00
2024-11-03 11:51:08 +08:00
2024-09-21 15:21:53 +08:00
2024-11-02 20:26:04 +08:00
2024-11-21 16:02:40 +08:00
2024-11-03 11:51:08 +08:00
2024-11-21 15:17:16 +08:00
2024-08-12 18:13:42 +08:00

C language logging library logging

brief

Logging is a lightweight and easy-to-use C language log library that supports log level, log format, log output, log files, and other functions.

function

  • Support log levels: DEBUG, INFO, Warning, ERROR, FATAL
  • Support log formats: timestamp, log level, log content
  • Support log output: console, file
  • Support log files: automatic creation, automatic scrolling, log segmentation

install

  • Conan
conan create .
  • cmake

usage

console log

#include "logging.h"

int main() {
    Logger *logger = newDefaultLogger("testLogger", LOG_DEBUG);

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    destroyDefaultLogger();
    return 0;
}

file log

#include "logging.h"
#include "logging/logging-handler.h"

int main() {
    Logger *logger = newDefaultLogger("testLogger", LOG_DEBUG);
    logger->addHandler(loggingFileHandler("test1", 1024*1024));

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    destroyDefaultLogger();
    return 0;
}

Logging Interceptor

Support adding custom interceptors, currently with built-in substring interceptors The function of an interceptor is to redirect intercepted logs to the interceptor's dedicated processor

example

Redirects intercepted logs to a dedicated file processor

#include "logging.h"
#include <stdio.h>

int main() {
    Logger  *logger = newDefaultLogger("testLogger", LOG_DEBUG);

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    char *test1[]         = {"123", "tt", NULL};

    log_Interceptor *tint = loggingSubStringInterceptor(
        test1,
        LOG_DEBUG,
        loggingFileHandler("test_interceptor", 1024 * 1024),
        true);

    logger->addInterceptor(tint);

    printf("\n");
    printf("Interceptor added\n");
    printf("\n");

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    destroyDefaultLogger();
    return 0;
}

Multiple substring interceptors

#include "logging.h"
#include <stdbool.h>
#include <stdio.h>
#include <time.h>

int main() {
    Logger *logger = newDefaultLogger("testLogger", LOG_DEBUG);

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    char *test1[]         = {"This",NULL};

    log_Interceptor *tint = loggingSubStringInterceptor(
        test1,
        LOG_DEBUG,
        loggingFileHandler("test_interceptor", 1024 * 1024),
        false);

    logger->addInterceptor(tint);

    char *test2[]         = {"123",NULL};

    log_Interceptor *tint1 = loggingSubStringInterceptor(
        test2,
        LOG_DEBUG,
        loggingFileHandler("test_interceptor1", 1024 * 1024),
        true);

    logger->addInterceptor(tint1);

    printf("\n");
    printf("Interceptor added\n");
    printf("\n");

    log_info("This is an info message");
    log_error("This is an error message%s", "123");
    log_fatal("This is an fatal message");
    log_debug("This is a debug message");
    log_warning("This is a warning message%s", "123");

    destroyDefaultLogger();
    return 0;
}
Description
No description provided
Readme MIT 465 KiB
v1.0.0 Latest
2025-10-18 09:06:21 +08:00
Languages
C 84.4%
CMake 7.2%
Python 7%
Shell 0.7%
Makefile 0.4%
Other 0.3%