// -*- C++ -*- // Module: Log4CPLUS // File: logger.h // Created: 6/2001 // Author: Tad E. Smith // // // Copyright 2001-2010 Tad E. Smith // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. /** @file * This header defines the Logger class and the logging macros. */ #ifndef LOG4CPLUS_LOGGERHEADER_ #define LOG4CPLUS_LOGGERHEADER_ #include #if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE) #pragma once #endif #include #include #include #include #include namespace log4cplus { // Forward declarations class Appender; class Hierarchy; class HierarchyLocker; class DefaultLoggerFactory; namespace spi { class LoggerImpl; } /** \typedef std::vector LoggerList * This is a list of {@link Logger Loggers}. */ typedef std::vector LoggerList; /** * This is the central class in the log4cplus package. One of the * distintive features of log4cplus are hierarchical loggers and their * evaluation. * * See the user manual for an * introduction on this class. */ class LOG4CPLUS_EXPORT Logger : public log4cplus::spi::AppenderAttachable { public: // Static Methods /** * Returns true if the named logger exists * (in the default hierarchy). * * @param name The name of the logger to search for. */ static bool exists(const log4cplus::tstring& name); /* * Returns all the currently defined loggers in the default * hierarchy. * * The root logger is not included in the returned * list. */ static LoggerList getCurrentLoggers(); /** * Return the default Hierarchy instance. */ static Hierarchy& getDefaultHierarchy(); /** * Retrieve a logger with name name. If the named * logger already exists, then the existing instance will be returned. * Otherwise, a new instance is created. * * By default, loggers do not have a set LogLevel but inherit * it from the hierarchy. This is one of the central features of * log4cplus. * * @param name The name of the logger to retrieve. */ static Logger getInstance(const log4cplus::tstring& name); /** * Like getInstance() except that the type of logger * instantiated depends on the type returned by the {@link * spi::LoggerFactory#makeNewLoggerInstance} method of the * factory parameter. * * This method is intended to be used by sub-classes. * * @param name The name of the logger to retrieve. * @param factory A {@link spi::LoggerFactory} implementation that will * actually create a new Instance. */ static Logger getInstance(const log4cplus::tstring& name, spi::LoggerFactory& factory); /** * Return the root of the default logger hierrachy. * * The root logger is always instantiated and available. It's * name is "root". * * Nevertheless, calling {@link #getInstance * Logger.getInstance("root")} does not retrieve the root logger * but a logger just under root named "root". */ static Logger getRoot(); /** * Calling this method will safely close and remove all * appenders in all the loggers including root contained in the * default hierachy. * * Some appenders such as SocketAppender need to be closed before the * application exits. Otherwise, pending logging events might be * lost. * * The shutdown method is careful to close nested * appenders before closing regular appenders. This is allows * configurations where a regular appender is attached to a logger * and again to a nested appender. */ static void shutdown(); // Non-Static Methods /** * If assertionVal parameter is false, then * logs msg with FATAL_LOG_LEVEL log level. * * @param assertionVal Truth value of assertion condition. * @param msg The message to print if assertion is * false. */ void assertion(bool assertionVal, const log4cplus::tstring& msg) const; /** * Close all attached appenders implementing the AppenderAttachable * interface. */ void closeNestedAppenders() const; /** * Check whether this logger is enabled for a given * LogLevel passed as parameter. * * @return boolean True if this logger is enabled for ll. */ bool isEnabledFor(LogLevel ll) const; /** * This generic form is intended to be used by wrappers. */ void log(LogLevel ll, const log4cplus::tstring& message, const char* file=NULL, int line=-1) const; void log(spi::InternalLoggingEvent const &) const; /** * This method creates a new logging event and logs the event * without further checks. */ void forcedLog(LogLevel ll, const log4cplus::tstring& message, const char* file=NULL, int line=-1) const; void forcedLog(spi::InternalLoggingEvent const &) const; /** * Call the appenders in the hierrachy starting at * this. If no appenders could be found, emit a * warning. * * This method calls all the appenders inherited from the * hierarchy circumventing any evaluation of whether to log or not * to log the particular log request. * * @param event the event to log. */ void callAppenders(const spi::InternalLoggingEvent& event) const; /** * Starting from this logger, search the logger hierarchy for a * "set" LogLevel and return it. Otherwise, return the LogLevel of the * root logger. * * The Logger class is designed so that this method executes as * quickly as possible. */ LogLevel getChainedLogLevel() const; /** * Returns the assigned LogLevel, if any, for this Logger. * * @return LogLevel - the assigned LogLevel, can be NOT_SET_LOG_LEVEL. */ LogLevel getLogLevel() const; /** * Set the LogLevel of this Logger. */ void setLogLevel(LogLevel ll); /** * Return the the {@link Hierarchy} where this Logger instance is * attached. */ Hierarchy& getHierarchy() const; /** * Return the logger name. */ log4cplus::tstring const & getName() const; /** * Get the additivity flag for this Logger instance. */ bool getAdditivity() const; /** * Set the additivity flag for this Logger instance. */ void setAdditivity(bool additive); // AppenderAttachable Methods virtual void addAppender(SharedAppenderPtr newAppender); virtual SharedAppenderPtrList getAllAppenders(); virtual SharedAppenderPtr getAppender(const log4cplus::tstring& name); virtual void removeAllAppenders(); virtual void removeAppender(SharedAppenderPtr appender); virtual void removeAppender(const log4cplus::tstring& name); Logger (); Logger(const Logger& rhs); Logger& operator=(const Logger& rhs); #if defined (LOG4CPLUS_HAVE_RVALUE_REFS) Logger (Logger && rhs); Logger & operator = (Logger && rhs); #endif virtual ~Logger(); void swap (Logger &); /** * Used to retrieve the parent of this Logger in the * Logger tree. */ Logger getParent() const; protected: // Data /** This is a pointer to the implementation class. */ spi::LoggerImpl * value; private: // Ctors /** * This constructor created a new Logger instance * with a pointer to a Logger implementation. * * You should not create loggers directly. * * @param ptr A pointer to the Logger implementation. This value * cannot be NULL. */ LOG4CPLUS_PRIVATE Logger(spi::LoggerImpl * ptr); // Friends friend class log4cplus::spi::LoggerImpl; friend class log4cplus::Hierarchy; friend class log4cplus::HierarchyLocker; friend class log4cplus::DefaultLoggerFactory; }; /** * This class is used to create the default implementation of * the Logger class */ class LOG4CPLUS_EXPORT DefaultLoggerFactory : public spi::LoggerFactory { public: Logger makeNewLoggerInstance(const log4cplus::tstring& name, Hierarchy& h); }; } // end namespace log4cplus #endif // LOG4CPLUS_LOGGERHEADER_