#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;
}
以上就是短码网小编为大家整理的《类似log4cplus的一个C++日志类》相关内容,希望大家喜欢。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将联系本站反馈,一经查实,立即处理!
《类似log4cplus的一个C++日志类》文档下载仅供参考学习,下载后请在24小时内删除。
转载注明出处:https://www.duanma.net/article/7c23e3fe123.html