00001 #if !defined(__MCLOGFILE_H_)
00002 #define __MCLOGFILE_H_
00003
00004 #ident "@(#)$Id: MCLogFile.h,v 1.5 2004/12/02 07:05:20 mike Exp $"
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025 #include "mcllib/MCMsg.h"
00026 #include "mcllib/MCInMutex.h"
00027 #include "mcllib/MCLock.h"
00028 #include "mcllib/MCRefCount.h"
00029 #include "mcllib/MCFile.h"
00030 #include <stdarg.h>
00031
00032 namespace mcllib
00033 {
00054 class MCLogFile : public MCRefCount {
00055 public:
00056 static const int MAX_ROLL;
00077 MCLogFile(const MCString& fileName = MCString(0),
00078 MCMsg::msglevel_t lvl = MCMsg::MSGLVL_WARN,
00079 int maxSize = 0,
00080 int maxRoll = MAX_ROLL,
00081 bool keepOpen = false);
00087 ~MCLogFile();
00095 void operator()(const char* fmt, ...);
00103 void operator()(MCMsg::msglevel_t lvl, const char* fmt, ...);
00110 void operator()(const MCMsg& msg);
00115 bool isOutput(MCMsg::msglevel_t lvl) const;
00122 void setDefaultLevel(MCMsg::msglevel_t lvl);
00129 void setOutputLevel(MCMsg::msglevel_t lvl);
00136 void setOutputFile(const MCString& fileName);
00142 void setOutputFile(MCFile::EStdHandle hdl);
00143
00144 protected:
00152 void operator()(const char* fmt, va_list ap);
00160 void operator()(MCMsg::msglevel_t lvl, const char* fmt, va_list ap);
00165 void init(const MCString& fileName = MCString(0),
00166 MCMsg::msglevel_t lvl = MCMsg::MSGLVL_WARN,
00167 int maxSize = 0,
00168 int maxRoll = MAX_ROLL,
00169 bool keepOpen = false);
00170
00171 private:
00172 MCFile m_file;
00173 MCInMutex m_mtx;
00174 MCString m_fileName;
00175 MCMsg::msglevel_t m_outLvl;
00176 MCMsg::msglevel_t m_defLvl;
00177 mcint64 m_maxSize;
00178 mcint64 m_curSize;
00179 int m_maxRoll;
00180 bool m_keepOpen;
00181
00182 bool rollFile();
00183 void openFile(bool fresh);
00184 void closeFile();
00185 };
00186 };
00187
00188 #endif