// -*- C++ -*- // Module: Log4CPLUS // File: loglog.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 */ #ifndef DCMTK_LOG4CPLUS_HELPERS_LOGLOG #define DCMTK_LOG4CPLUS_HELPERS_LOGLOG #include "dcmtk/oflog/config.h" #if defined (DCMTK_LOG4CPLUS_HAVE_PRAGMA_ONCE) #pragma once #endif #include "dcmtk/oflog/tstring.h" #include "dcmtk/oflog/streams.h" #include "dcmtk/oflog/thread/syncprim.h" namespace dcmtk { namespace log4cplus { namespace helpers { /** * This class used to output log statements from within the log4cplus package. * * Log4cplus components cannot make log4cplus logging calls. However, it is * sometimes useful for the user to learn about what log4cplus is * doing. You can enable log4cplus internal logging by defining the * log4cplus.configDebug variable. * * All log4cplus internal debug calls go to cout * where as internal error messages are sent to * cerr. All internal messages are prepended with * the string "log4clus: ". */ class DCMTK_LOG4CPLUS_EXPORT LogLog { public: //! Return type of getLogLog(). typedef LogLog * Ptr; /** * Returns a reference to the LogLog singleton. */ static Ptr getLogLog(); /** * Allows to enable/disable log4cplus internal logging. */ void setInternalDebugging(bool enabled); /** * In quite mode no LogLog generates strictly no output, not even * for errors. * * @param quietMode A true for not */ void setQuietMode(bool quietMode); /** * This method is used to output log4cplus internal debug * statements. Output goes to STD_NAMESPACE cout. */ void debug(const log4cplus::tstring& msg) const; void debug(tchar const * msg) const; /** * This method is used to output log4cplus internal error * statements. There is no way to disable error * statements. Output goes to * STD_NAMESPACE cerr. Optionally, this method can * throw STD_NAMESPACE runtime_error exception too. */ void error(const log4cplus::tstring& msg, bool throw_flag = false) const; void error(tchar const * msg, bool throw_flag = false) const; /** * This method is used to output log4cplus internal warning * statements. There is no way to disable warning statements. * Output goes to STD_NAMESPACE cerr. */ void warn(const log4cplus::tstring& msg) const; void warn(tchar const * msg) const; // Public ctor and dtor to be used only by internal::DefaultContext. LogLog(); virtual ~LogLog(); private: enum TriState { TriUndef = -1, TriFalse, TriTrue }; DCMTK_LOG4CPLUS_PRIVATE void logging_worker (tostream & os, bool (LogLog:: * cond) () const, tchar const *, tchar const *, bool throw_flag = false) const; DCMTK_LOG4CPLUS_PRIVATE static void set_tristate_from_env (TriState *, tchar const * envvar); DCMTK_LOG4CPLUS_PRIVATE bool get_quiet_mode () const; DCMTK_LOG4CPLUS_PRIVATE bool get_not_quiet_mode () const; DCMTK_LOG4CPLUS_PRIVATE bool get_debug_mode () const; // Data mutable TriState debugEnabled; mutable TriState quietMode; thread::Mutex mutex; DCMTK_LOG4CPLUS_PRIVATE LogLog(const LogLog&); DCMTK_LOG4CPLUS_PRIVATE LogLog & operator = (LogLog const &); }; DCMTK_LOG4CPLUS_EXPORT LogLog & getLogLog (); } // end namespace helpers } // end namespace log4cplus } // end namespace dcmtk #endif // DCMTK_LOG4CPLUS_HELPERS_LOGLOG