/*============================================================================= Library: CTK Copyright (c) German Cancer Research Center, Division of Medical and Biological Informatics 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. =============================================================================*/ #ifndef CTKLOGSERVICE_H #define CTKLOGSERVICE_H #include #include #include "ctkLogStream.h" #include /** * \ingroup LogService * Provides methods for plugins to write messages to the log. * *

* ctkLogService methods are provided to log messages; optionally with a * ctkServiceReference object or an exception. * *

* Plugins must log messages in the Plugin Framework with a severity level * according to the following hierarchy: *

    *
  1. #LOG_ERROR *
  2. #LOG_WARNING *
  3. #LOG_INFO *
  4. #LOG_DEBUG *
* * \remarks This class is thread safe. */ struct CTK_PLUGINFW_EXPORT ctkLogService { virtual ~ctkLogService() {} /** * An error message (Value 1). * *

* This log entry indicates the plugin or service may not be functional. */ static const int LOG_ERROR; // = 1; /** * A warning message (Value 2). * *

* This log entry indicates a plugin or service is still functioning but may * experience problems in the future because of the warning condition. */ static const int LOG_WARNING; // = 2; /** * An informational message (Value 3). * *

* This log entry may be the result of any change in the plugin or service * and does not indicate a problem. */ static const int LOG_INFO; // = 3; /** * A debugging message (Value 4). * *

* This log entry is used for problem determination and may be irrelevant to * anyone but the plugin developer. */ static const int LOG_DEBUG; // = 4; /** * Logs a message. * *

* The ctkServiceReference field and the Exception field * of the ctkLogEntry object will be set to null. * * \param level The severity of the message. This should be one of the * defined log levels but may be any integer that is interpreted in a * user defined way. * \param message Human readable string describing the condition. * \param exception The exception that reflects the condition or null. * \param file The current file name. * \param function The current function name. * \param line The current line number. * * \see #LOG_ERROR * \see #LOG_WARNING * \see #LOG_INFO * \see #LOG_DEBUG */ virtual void log(int level, const QString& message, const std::exception* exception = 0, const char* file = 0, const char* function = 0, int line = -1) = 0; /** * Logs a message associated with a specific ctkServiceReference * object. * *

* The Exception field of the ctkLogEntry will be set to * null. * * \param sr The ctkServiceReference object of the service that this * message is associated with. * \param level The severity of the message. This should be one of the * defined log levels but may be any integer that is interpreted in a * user defined way. * \param message Human readable string describing the condition. * \param exception The exception that reflects the condition or * null. * \param file The current file name. * \param function The current function name. * \param line The current line number. * * \see #LOG_ERROR * \see #LOG_WARNING * \see #LOG_INFO * \see #LOG_DEBUG */ virtual void log(const ctkServiceReference& sr, int level, const QString& message, const std::exception* exception = 0, const char* file = 0, const char* function = 0, int line = -1) = 0; /** * Get the current log level. The log service discards log entries with a * level that is less severe than the current level. E.g. if the current * log level is LOG_WARNING then the log service will discard all log entries with * level LOG_INFO and LOG_DEBUG. * * \return The lowest severity level that is accepted into the log. */ virtual int getLogLevel() const = 0; }; Q_DECLARE_INTERFACE(ctkLogService, "org.commontk.service.log.LogService") /** * \ingroup LogService */ class CTK_PLUGINFW_EXPORT ctkLogStreamWithServiceRef : public ctkLogStream { public: ctkLogStreamWithServiceRef(ctkLogService* logService, const ctkServiceReference& sr, int level, const std::exception* exc = 0, const char* file = 0, const char* function = 0, int line = -1); ctkLogStreamWithServiceRef(const ctkLogStreamWithServiceRef& logStreamWithRef); ~ctkLogStreamWithServiceRef(); protected: ctkServiceReference sr; }; /** * \ingroup LogService */ class CTK_PLUGINFW_EXPORT ctkNullLogStream : public ctkLogStream { public: ctkNullLogStream(); ~ctkNullLogStream(); }; /** * \ingroup LogService * @{ */ #define CTK_DEBUG(logService) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_DEBUG) ? \ ctkLogStream(logService, ctkLogService::LOG_DEBUG, 0, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_DEBUG_EXC(logService, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_DEBUG) ? \ ctkLogStream(logService, ctkLogService::LOG_DEBUG, exc, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_DEBUG_SR(logService, serviceRef) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_DEBUG) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_DEBUG, 0, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_DEBUG_SR_EXC(logService, serviceRef, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_DEBUG) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_DEBUG, exc, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_INFO(logService) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_INFO) ? \ ctkLogStream(logService, ctkLogService::LOG_INFO, 0, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_INFO_EXC(logService, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_INFO) ? \ ctkLogStream(logService, ctkLogService::LOG_INFO, exc, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_INFO_SR(logService, serviceRef) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_INFO) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_INFO, 0, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_INFO_SR_EXC(logService, serviceRef, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_INFO) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_INFO, exc, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_WARN(logService) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_WARNING) ? \ ctkLogStream(logService, ctkLogService::LOG_WARNING, 0, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_WARN_EXC(logService, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_WARNING) ? \ ctkLogStream(logService, ctkLogService::LOG_WARNING, exc, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_WARN_SR(logService, serviceRef) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_WARNING) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_WARNING, 0, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_WARN_SR_EXC(logService, serviceRef, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_WARNING) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_WARNING, exc, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_ERROR(logService) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_ERROR) ? \ ctkLogStream(logService, ctkLogService::LOG_ERROR, 0, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_ERROR_EXC(logService, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_ERROR) ? \ ctkLogStream(logService, ctkLogService::LOG_ERROR, exc, __FILE__, __FUNCTION__, __LINE__) : \ ctkNullLogStream()) #define CTK_ERROR_SR(logService, serviceRef) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_ERRO) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_ERROR, 0, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) #define CTK_ERROR_SR_EXC(logService, serviceRef, exc) \ ((logService && logService->getLogLevel() >= ctkLogService::LOG_ERROR) ? \ static_cast(ctkLogStreamWithServiceRef(logService, serviceRef, ctkLogService::LOG_ERROR, exc, __FILE__, __FUNCTION__, __LINE__)) : \ static_cast(ctkNullLogStream())) /** @}*/ #endif // CTKLOGSERVICE_H