Main Page   Class Hierarchy   Alphabetical List   Data Structures   File List   Data Fields  

log.Log.h

00001 /*----------------------------------------------------------------------------
00002   SWORD 2000 - Software With Objects for Rapid Development
00003   Copyright (C) 2003 Eric NICOLAS
00004   ----------------------------------------------------------------------------
00005   SWORD is free software; you can redistribute it and/or modify
00006   it under the terms of the GNU Lesser General Public License as published by
00007   the Free Software Foundation; either version 2 of the License, or
00008   (at your option) any later version.
00009 
00010   SWORD is distributed in the hope that it will be useful,
00011   but WITHOUT ANY WARRANTY; without even the implied warranty of
00012   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013   GNU Lesser General Public License for more details.
00014 
00015   You should have received a copy of the GNU Lesser General Public License
00016   along with SWORD; if not, write to the Free Software
00017   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00018   --------------------------------------------------------------------------*/
00019 #ifndef _SWORD_LOG_LOG_
00020 #define _SWORD_LOG_LOG_
00021 
00022 #include "sword/log.LogStream.h"
00023 
00024 namespace sword {
00025 
00027 
00045         class SWORDDECL Log {
00046         public:
00047                 Log();
00048                 ~Log();
00049 
00051                 enum Level { Debug=0, Info, Warning, Error, Fatal, NOTUSED };
00052 
00053                 struct Entry
00054                 {
00055                         int64       timestamp_;
00056                         Level       level_;
00057                         std::string message_;
00058 
00059                         // note: do not use 'sword::Time' here because Log is very
00060                         // low level and we do not want to link this header to higher
00061                         // level classes.
00062                 };
00063 
00065                 static const char *levelStr(Level level);
00066 
00068 
00072                 static std::string format(const Entry &entry, const std::string& timestampFormat);
00073 
00075                 static std::string printf(const char* format, ...);
00076 
00077                 // End of line for message flushing
00078                 static class Endl {} endl;
00079                 static void flush();
00080 
00082                 static LogStream &log(Level level);
00083 
00084         private:
00085                 void flush_();
00086                 LogStream &log_(Level level);
00087 
00088                 LogStream stream_;
00089                 Level     level_;
00090                 bool      active_;
00091                 static ACE_TSS<Log> instance_;
00092         };
00093 
00094 } // namespace sword
00095 
00096 #include "sword.private/log.Log.inl"
00097 
00098 #endif // _SWORD_LOG_LOG_

Generated on Tue Dec 23 20:08:56 2003 for SWORD by doxygen1.3-rc2