fs_log

Posted mrsandstorm

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了fs_log相关的知识,希望对你有一定的参考价值。

 

 

 

技术分享图片
#include "fs_log.h"

void write_log (const char *format, ...)
{
    va_list arg;
    int done;
    time_t time_log;
    struct tm* tm_log;
    FILE* pFile = NULL;
#if LOG_HAVE_WINDOW_OUT
    char buff[300];
    int off = 0;
#endif
    va_start (arg, format);

    time_log = time(NULL);
    tm_log = localtime(&time_log);

    pFile = fopen(LOG_FILE, "a");

    fprintf(pFile,"%04d-%02d-%02d %02d:%02d:%02d :",
        tm_log->tm_year + 1900, tm_log->tm_mon + 1, tm_log->tm_mday,
        tm_log->tm_hour, tm_log->tm_min, tm_log->tm_sec);
    done = vfprintf (pFile, format, arg);
    va_end (arg);
    fflush(pFile);

    fclose(pFile);

#if LOG_HAVE_WINDOW_OUT
    memset(buff, 0, sizeof(buff));
    off = sprintf(buff, "%04d-%02d-%02d %02d:%02d:%02d [%s][%d]:",
        tm_log->tm_year + 1900, tm_log->tm_mon + 1, tm_log->tm_mday,
        tm_log->tm_hour, tm_log->tm_min, tm_log->tm_sec);
    sprintf(buff+off, format, arg);
    printf("%s",buff);
#endif

    return;
}

void write_log_cond(char valve, char *file_nameconst, int len, char *format, ...)
{
    va_list arg;
    int done;
    time_t time_log;
    struct tm* tm_log;
    FILE* pFile = NULL;
#if LOG_HAVE_WINDOW_OUT
    char buff[300];
    int off = 0;
#endif

    if (valve == 0)
    {
        return;
    }
    va_start (arg, format);

    time_log = time(NULL);
    tm_log = localtime(&time_log);

    pFile = fopen(LOG_FILE, "a");

    fprintf(pFile,"%04d-%02d-%02d %02d:%02d:%02d [%s][%d]:",
        tm_log->tm_year + 1900, tm_log->tm_mon + 1, tm_log->tm_mday,
        tm_log->tm_hour, tm_log->tm_min, tm_log->tm_sec,
        file_nameconst,len);
    done = vfprintf (pFile, format, arg);
    va_end (arg);
    fflush(pFile);

    fclose(pFile);

#if LOG_HAVE_WINDOW_OUT
    memset(buff, 0, sizeof(buff));
    off = sprintf(buff, "%04d-%02d-%02d %02d:%02d:%02d [%s][%d]:",
        tm_log->tm_year + 1900, tm_log->tm_mon + 1, tm_log->tm_mday,
        tm_log->tm_hour, tm_log->tm_min, tm_log->tm_sec,
        file_nameconst,len);
    sprintf(buff+off, format, arg);
    printf("%s",buff);
#endif

    return;
}
fs_log.h

 

技术分享图片
#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include <time.h>

#define LOG_FILE "./runlog.txt"
#define LOG_HAVE_WINDOW_OUT     (1)

#define SHORT_FILE strrchr(__FILE__, ‘\‘) ? strrchr(__FILE__, ‘\‘) + 1 : __FILE__
#define LOG_DEBUG_SET_LEVLE(a)  (a),(SHORT_FILE),(__LINE__)

#define print_deb    write_log
#define print_info    write_log
#define print_war    write_log
#define print_err    write_log
#define print_cond    write_log_cond

extern void write_log (const char *format, ...);
extern void write_log_cond (char valve, char *file_nameconst, int len, char *format, ...);

#endif
fs_log.h

 

以上是关于fs_log的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段6——CSS选择器

VSCode自定义代码片段——声明函数