Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

OgreLog.cpp

Go to the documentation of this file.
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