最近闲来无事写了一个简单的log库,支持Unix和Windows两个版本;
里面调用了tinyxml,本人比较懒,直接把它加载到了工程里面;
废话不过说直接上代码:
第一部分:是功能函数的头文件,文件名(CLogEx.h)
#ifdef CTLOGEX_EXPORTS
#define CTLOGEX_API __declspec(dllexport)
#else
#define CTLOGEX_API __declspec(dllimport)
#endif
#ifndef __CTLOGEX_H__
#define __CTLOGEX_H__
#include "custom.h"
#ifndef __cplusplus
extern "C"{
#endif
/*<载入XML配置文件;>*/
CTLOGEX_API int LoadConfig(const char* xmlfile);
/*<初始化log环境;>*/
CTLOGEX_API int Init();
/*<释放log资源;>*/
CTLOGEX_API void Release();
/*<功能函数:warn
@param:
[in]警告等级,从0~6,错误为0级警告;
[in]输入的日志,可变参数组
@result:
返回错误类型
>*/
CTLOGEX_API int cwarn(unsigned short level, const char *format, ...);
/*<功能函数:trace
@param:
[in]输入的日志,可变参数组
@result:
[out]返回错误类型
>*/
CTLOGEX_API int ctrace(const char *format, ...);
/*<获取错误信息>*/
CTLOGEX_API extern const TCHAR* GetLogErrorInfo(int code);
#ifndef __cplusplus
};
#endif
#endif // !__CTLOGEX_H__
第二部分:功能函数的实现
// CTLogEx.cpp : 定义 DLL 应用程序的导出函数。
//
#include "CTLogEx.h"
#include <stdarg.h>
#include "tinyxml2.h"
#include <sys/stat.h>
#include <io.h>
#include <fcntl.h>
#include <string.h>
using namespace tinyxml2;
static FILE* _swarn,* _strace; /*<日志输出位置,当输出到控制台时,_swarn = stderr而_strace = stdout;>*/
static bool _default = false;/*<是否为默认配置,默认不输出日志;>*/
static int _type;/*<输出类型,0表示不输出,1表示输出到控制台,2表示输出到文件;>*/
static int _level; /*<警告等级,总计划分为0~6级别,错误为0级;>*/
static bool _traceIsActive = true; /*<是否开启TRCE>*/
static long size_log; /*<文件的大小,以M为单位>*/
static char _pwarn[256];
static char _ptrace[256];
/*<log函数;>*/
int cwarn(unsigned short level, const char *format, ...)
{
int _ret;
va_list arglist;
char buffer[2048</