From a282a131cd809c3f425a44f42e30dfb902bca76e Mon Sep 17 00:00:00 2001 From: Janusz Kozerski Date: Thu, 28 May 2015 10:41:03 +0200 Subject: Add cert-checker database (+tests). Change include files path. * Add m_buffer in Logic class. * Load database into buffer in Logic::setup() * Move include to separate folder - this solves problem with app.h file from different package. [Verification] Run cert-checker-tests. All should pass. Change-Id: I809951a17fd44d5258ad91e480b6914e92d1058b --- src/include/cchecker/log.h | 86 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 src/include/cchecker/log.h (limited to 'src/include/cchecker/log.h') diff --git a/src/include/cchecker/log.h b/src/include/cchecker/log.h new file mode 100644 index 0000000..d4efcdc --- /dev/null +++ b/src/include/cchecker/log.h @@ -0,0 +1,86 @@ +/* + * Copyright (c) 2015 Samsung Electronics Co., Ltd All Rights Reserved + * + * 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 log.h + * @author Janusz Kozerski + * @brief Project log framework - logs into journal + */ + +#include +#include + +#ifndef CERT_CHECKER_LOG_H +#define CERT_CHECKER_LOG_H + +void JournalLog(int logLevel, const char *message, const char *fileName, + int line, const char *function); + +/* + * Replacement low overhead null logging class + */ +class NullStream +{ + public: + NullStream() {} + + template + NullStream& operator<<(const T&) + { + return *this; + } +}; + +/* avoid warnings about unused variables */ +#define DPL_MACRO_DUMMY_LOGGING(message, level) \ + do { \ + NullStream ns; \ + ns << message; \ + } while (0) + +#define CERT_CHECKER_LOG(message, level) \ +do \ +{ \ + std::ostringstream platformLog; \ + platformLog << message; \ + JournalLog(level, \ + platformLog.str().c_str(), \ + __FILE__, \ + __LINE__, \ + __FUNCTION__); \ +} while (0) + +/* Errors must be always logged. */ +#define LogError(message) \ + CERT_CHECKER_LOG(message, LOG_ERR) + +#ifdef BUILD_TYPE_DEBUG + #define LogDebug(message) \ + CERT_CHECKER_LOG(message, LOG_DEBUG) + #define LogInfo(message) \ + CERT_CHECKER_LOG(message, LOG_INFO) + #define LogWarning(message) \ + CERT_CHECKER_LOG(message, LOG_WARNING) +#else + #define LogDebug(message) \ + DPL_MACRO_DUMMY_LOGGING(message, LOG_DEBUG) + #define LogInfo(message) \ + DPL_MACRO_DUMMY_LOGGING(message, LOG_INFO) + #define LogWarning(message) \ + DPL_MACRO_DUMMY_LOGGING(message, LOG_WARNING) +#endif // BUILD_TYPE_DEBUG + +#endif //CERT_CHECKER_LOG_H + -- cgit v1.2.3