00001 /* 00002 ----------------------------------------------------------------------------- 00003 This source file is part of OGRE 00004 (Object-oriented Graphics Rendering Engine) 00005 For the latest info, see http://www.ogre3d.org/ 00006 00007 Copyright © 2000-2002 The OGRE Team 00008 Also see acknowledgements in Readme.html 00009 00010 This program is free software; you can redistribute it and/or modify it under 00011 the terms of the GNU Lesser General Public License as published by the Free Software 00012 Foundation; either version 2 of the License, or (at your option) any later 00013 version. 00014 00015 This program is distributed in the hope that it will be useful, but WITHOUT 00016 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS 00017 FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. 00018 00019 You should have received a copy of the GNU Lesser General Public License along with 00020 this program; if not, write to the Free Software Foundation, Inc., 59 Temple 00021 Place - Suite 330, Boston, MA 02111-1307, USA, or go to 00022 http://www.gnu.org/copyleft/lesser.txt. 00023 ----------------------------------------------------------------------------- 00024 */ 00025 #include "OgreStableHeaders.h" 00026 00027 #include "OgreLog.h" 00028 #include "OgreString.h" 00029 00030 namespace Ogre { 00031 00032 //----------------------------------------------------------------------- 00033 Log::Log( const String& name, bool debuggerOuput ) 00034 { 00035 mfpLog.open(name); 00036 mDebugOut = debuggerOuput; 00037 mLogLevel = LL_NORMAL; 00038 } 00039 //----------------------------------------------------------------------- 00040 Log::~Log() 00041 { 00042 mfpLog.close(); 00043 } 00044 //----------------------------------------------------------------------- 00045 void Log::logMessage( const String& message, LogMessageLevel lml ) 00046 { 00047 if ((mLogLevel + lml) >= LOG_THRESHOLD) 00048 { 00049 if (mDebugOut) 00050 fprintf( stderr, "%s\n", message.c_str()); 00051 00052 // Write time into log 00053 struct tm *pTime; 00054 time_t ctTime; time(&ctTime); 00055 pTime = localtime( &ctTime ); 00056 mfpLog << std::setw(2) << std::setfill('0') << pTime->tm_hour 00057 << ":" << std::setw(2) << std::setfill('0') << pTime->tm_min 00058 << ":" << std::setw(2) << std::setfill('0') << pTime->tm_sec << ": " << message << std::endl; 00059 00060 // Flush stcmdream to ensure it is written (incase of a crash, we need log to be up to date) 00061 mfpLog.flush(); 00062 } 00063 00064 } 00065 //----------------------------------------------------------------------- 00066 void Log::setLogDetail(LoggingLevel ll) 00067 { 00068 mLogLevel = ll; 00069 } 00070 }
Copyright © 2002-2003 by The OGRE Team
Last modified Wed Jan 21 00:10:15 2004