123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- // Copyright (C) 2002-2012 Nikolaus Gebhardt
- // This file is part of the "Irrlicht Engine".
- // For conditions of distribution and use, see copyright notice in irrlicht.h
- #ifndef __I_LOGGER_H_INCLUDED__
- #define __I_LOGGER_H_INCLUDED__
- #include "IReferenceCounted.h"
- namespace irr
- {
- //! Possible log levels.
- //! When used has filter ELL_DEBUG means => log everything and ELL_NONE means => log (nearly) nothing.
- //! When used to print logging information ELL_DEBUG will have lowest priority while ELL_NONE
- //! messages are never filtered and always printed.
- enum ELOG_LEVEL
- {
- //! Used for printing information helpful in debugging
- ELL_DEBUG,
- //! Useful information to print. For example hardware infos or something started/stopped.
- ELL_INFORMATION,
- //! Warnings that something isn't as expected and can cause oddities
- ELL_WARNING,
- //! Something did go wrong.
- ELL_ERROR,
- //! Logs with ELL_NONE will never be filtered.
- //! And used as filter it will remove all logging except ELL_NONE messages.
- ELL_NONE
- };
- //! Interface for logging messages, warnings and errors
- class ILogger : public virtual IReferenceCounted
- {
- public:
- //! Destructor
- virtual ~ILogger() {}
- //! Returns the current set log level.
- virtual ELOG_LEVEL getLogLevel() const = 0;
- //! Sets a new log level.
- /** With this value, texts which are sent to the logger are filtered
- out. For example setting this value to ELL_WARNING, only warnings and
- errors are printed out. Setting it to ELL_INFORMATION, which is the
- default setting, warnings, errors and informational texts are printed
- out.
- \param ll: new log level filter value. */
- virtual void setLogLevel(ELOG_LEVEL ll) = 0;
- //! Prints out a text into the log
- /** \param text: Text to print out.
- \param ll: Log level of the text. If the text is an error, set
- it to ELL_ERROR, if it is warning set it to ELL_WARNING, and if it
- is just an informational text, set it to ELL_INFORMATION. Texts are
- filtered with these levels. If you want to be a text displayed,
- independent on what level filter is set, use ELL_NONE. */
- virtual void log(const c8* text, ELOG_LEVEL ll=ELL_INFORMATION) = 0;
- //! Prints out a text into the log
- /** \param text: Text to print out.
- \param hint: Additional info. This string is added after a " :" to the
- string.
- \param ll: Log level of the text. If the text is an error, set
- it to ELL_ERROR, if it is warning set it to ELL_WARNING, and if it
- is just an informational text, set it to ELL_INFORMATION. Texts are
- filtered with these levels. If you want to be a text displayed,
- independent on what level filter is set, use ELL_NONE. */
- virtual void log(const c8* text, const c8* hint, ELOG_LEVEL ll=ELL_INFORMATION) = 0;
- virtual void log(const c8* text, const wchar_t* hint, ELOG_LEVEL ll=ELL_INFORMATION) = 0;
- //! Prints out a text into the log
- /** \param text: Text to print out.
- \param hint: Additional info. This string is added after a " :" to the
- string.
- \param ll: Log level of the text. If the text is an error, set
- it to ELL_ERROR, if it is warning set it to ELL_WARNING, and if it
- is just an informational text, set it to ELL_INFORMATION. Texts are
- filtered with these levels. If you want to be a text displayed,
- independent on what level filter is set, use ELL_NONE. */
- virtual void log(const wchar_t* text, const wchar_t* hint, ELOG_LEVEL ll=ELL_INFORMATION) = 0;
- //! Prints out a text into the log
- /** \param text: Text to print out.
- \param ll: Log level of the text. If the text is an error, set
- it to ELL_ERROR, if it is warning set it to ELL_WARNING, and if it
- is just an informational text, set it to ELL_INFORMATION. Texts are
- filtered with these levels. If you want to be a text displayed,
- independent on what level filter is set, use ELL_NONE. */
- virtual void log(const wchar_t* text, ELOG_LEVEL ll=ELL_INFORMATION) = 0;
- };
- } // end namespace
- #endif
|