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_
1.3-rc2