您的位置:首页 > 编程语言 > C语言/C++

C++的一个日志类,和log4cplus很像

2015-01-08 15:47 465 查看
filelogs.h

#ifndef H_FILELOGS_H
#define H_FILELOGS_H

#include "stdlib.h"
#include "stdio.h"
#include <string.h>
#include <time.h>
#include <sys/types.h>
#include <sys/stat.h>

#define MAX_FILE_LEN 5242880 //5M
#define MAX_PATH_LEN 300
#define RTN_FAIL -1
#define RTN_SUCCESS 0

#define WriteLog(Msg) WriteMsgLog(__FILE__,__LINE__,Msg)

class CFileLogs
{
public:
CFileLogs();
virtual ~CFileLogs();
bool IsOpen();
int init(int iLogLevel,const char *pcDebugLogFileName);
bool OpenFile(char *);
bool OpenNewOutputFile(char *);
bool GetLock();
int WriteMsgLog(const char *,int,const char *);
int WriteOutputMsg(const char *);

public:
char m_FileName[MAX_PATH_LEN + FILENAME_MAX + 1];
int m_LogLevel;
private:
bool m_lock;
FILE *m_file;

private:
bool CheckFile();
void GetTimeStr(char *);
};

#endif


filelogs.cpp

// filelogs.cpp: implementation of the CFileLogs class.
//
//////////////////////////////////////////////////////////////////////
#include "filelogs.h"

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CFileLogs::CFileLogs()
{
m_lock = false;
m_file = NULL;
}

CFileLogs::~CFileLogs()
{
if(m_file != NULL)
fclose(m_file);
}

//////////////////////////////////////////////////////////////////////
// public method
//////////////////////////////////////////////////////////////////////
bool CFileLogs::GetLock()
{
if(m_lock == true)
return false;
m_lock = true;
return true;
}

bool CFileLogs::IsOpen()
{
if(m_file != NULL)
return true;
else
return false;
}
int CFileLogs::init(int iLogLevel,const char *pcDebugLogFileName)
{
this->m_LogLevel = iLogLevel;
//if log level less than 1 , then don't open log file
if (this->m_LogLevel > 0) {
if (pcDebugLogFileName == NULL) {
return RTN_FAIL;
}else {
strcpy(this->m_FileName, pcDebugLogFileName);
//this->m_DebugLogFileName = strDuplicate(pcDebugLogFileName);
}
}
FILE *logFile=NULL;
if (this->m_LogLevel >= 3) {
logFile = fopen(this->m_FileName,(char *)"a+");
if (logFile == NULL) {
printf("Cannot open file %s to write!\n", this->m_FileName);
return RTN_FAIL;
}
fclose(logFile);
}

return RTN_SUCCESS;
}
bool CFileLogs::OpenFile(char *filePathAndName)
{
if(filePathAndName == NULL)
return false;
sprintf(m_FileName, filePathAndName);
if((m_file = fopen(m_FileName, "a")) == NULL)
return false;
return true;
}

bool CFileLogs::OpenNewOutputFile(char *filePathAndName)
{
if(filePathAndName == NULL)
return false;
if( IsOpen() )
fclose(m_file);
sprintf(m_FileName, filePathAndName);
if((m_file = fopen(m_FileName, "a")) == NULL)
return false;
return true;
}

int CFileLogs::WriteMsgLog(const char *pcsrcfile,int line,const char *strMsg)
{
char buf[100];

CheckFile();
if(m_file == NULL)
m_file = fopen(m_FileName, "a");
if(m_file != NULL && strMsg != NULL) {
GetTimeStr(buf);
fprintf(m_file, "[%s]line[%d][%s] %s\n",pcsrcfile,line,buf,strMsg);//pcsrcfile
fflush( m_file );
}
else {
return 0;
}
m_lock = false;
return 1;
}

int CFileLogs::WriteOutputMsg(const char *strMsg)
{
if (m_file == NULL)
m_file = fopen(m_FileName, "a");
if (m_file != NULL && strMsg != NULL) {
fprintf(m_file, "%s\n",strMsg);
fflush( m_file );
}
else {
return 0;
}
m_lock = false;
return 1;
}

bool CFileLogs::CheckFile()
{
struct stat statBuf;
int nRet;
char strNewName[500];
struct tm * pTime;

if(m_file == NULL)
return false;
nRet = fstat(
#ifdef LINUX
fileno(m_file)
#else
#ifdef HPUX
fileno(m_file)
#else
m_file->_file
#endif
#endif
, &statBuf );

if( nRet != 0 ) {
printf( "CFileLogs:Bad file handle!\n" );
return false;
} else {
if(statBuf.st_size > MAX_FILE_LEN) {
pTime = localtime(&statBuf.st_mtime);
sprintf( strNewName, "%sY%dM%dD%dH%dM%dS%d", m_FileName, pTime->tm_year + 1900, pTime->tm_mon+1, pTime->tm_mday, pTime->tm_hour, pTime->tm_min, pTime->tm_sec);
fclose(m_file);
m_file = NULL;
rename(m_FileName, strNewName);
}
}
return true;
}

void CFileLogs::GetTimeStr(char *pStr)
{
time_t ltime;
struct tm *pNow,now;

time(<ime);
#ifdef WIN32
pNow = localtime(<ime);
#else
pNow = localtime_r(<ime, &now);
#endif
sprintf(pStr, (char *)"%2d-%02d-%02d %02d:%02d:%02d",
pNow->tm_year + 1900, pNow->tm_mon+1, pNow->tm_mday,
pNow->tm_hour, pNow->tm_min, pNow->tm_sec);
return;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  C++ 日志类