| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- //
- // Urho3D Engine
- // Copyright (c) 2008-2011 Lasse Öörni
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- //
- #pragma once
- #include "Object.h"
- /// Debug message level. By default only shown in debug mode.
- static const int LOG_DEBUG = 0;
- /// Informative message level.
- static const int LOG_INFO = 1;
- /// Warning message level.
- static const int LOG_WARNING = 2;
- /// Error message level.
- static const int LOG_ERROR = 3;
- /// Disable all log messages.
- static const int LOG_NONE = 4;
- class File;
- /// Logging subsystem.
- class Log : public Object
- {
- OBJECT(Log);
-
- public:
- /// Construct.
- Log(Context* context);
- /// Destruct. Close the log file if open.
- virtual ~Log();
-
- /// Open the log file.
- void Open(const String& fileName);
- /// Write to the log. If logging level is higher than the level of the message, the message is ignored.
- void Write(int level, const String& message);
- /// Write raw output to the log.
- void WriteRaw(const String& message);
- /// %Set logging level.
- void SetLevel(int level);
-
- /// Return logging level.
- int GetLevel() const { return level_; }
- /// Return last log message.
- const String& GetLastMessage() const { return lastMessage_; }
-
- private:
- /// Log file.
- SharedPtr<File> logFile_;
- /// Last log message.
- String lastMessage_;
- /// Logging level.
- int level_;
- /// In write flag to prevent recursion.
- bool inWrite_;
- };
- /// Write to the log (static.)
- void WriteToLog(Context* context, int level, const String& message);
- /// Write raw output to the log (static.)
- void WriteToLogRaw(Context* context, const String& message);
- #define LOGDEBUG(message) WriteToLog(context_, LOG_DEBUG, message)
- #define LOGINFO(message) WriteToLog(context_, LOG_INFO, message)
- #define LOGWARNING(message) WriteToLog(context_, LOG_WARNING, message)
- #define LOGERROR(message) WriteToLog(context_, LOG_ERROR, message)
- #define LOGRAW(message) WriteToLogRaw(context_, message)
|