/usr/include/pion/PionLogger.hpp is in libpion-common-dev 4.0.7+dfsg-3.1ubuntu4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 | // -----------------------------------------------------------------------
// pion-common: a collection of common libraries used by the Pion Platform
// -----------------------------------------------------------------------
// Copyright (C) 2007-2008 Atomic Labs, Inc. (http://www.atomiclabs.com)
//
// Distributed under the Boost Software License, Version 1.0.
// See http://www.boost.org/LICENSE_1_0.txt
//
#ifndef __PION_PIONLOGGER_HEADER__
#define __PION_PIONLOGGER_HEADER__
#include <pion/PionConfig.hpp>
#if defined(PION_USE_LOG4CXX)
// unfortunately, the current version of log4cxx has many problems that
// produce very annoying warnings
// log4cxx headers
#include <log4cxx/logger.h>
#ifdef _MSC_VER
#pragma warning(push)
#pragma warning(disable: 4231) // nonstandard extension used : 'extern' before template explicit instantiation
#endif
#include <log4cxx/basicconfigurator.h>
#include <log4cxx/propertyconfigurator.h>
#ifdef _MSC_VER
#pragma warning(pop)
#endif
#if defined _MSC_VER
#if defined _DEBUG
#pragma comment(lib, "log4cxxd")
#else
#pragma comment(lib, "log4cxx")
#endif
#pragma comment(lib, "odbc32")
#endif
namespace pion {
typedef log4cxx::LoggerPtr PionLogger;
typedef log4cxx::AppenderSkeleton PionLogAppender;
typedef PionLogAppender * PionLogAppenderPtr;
}
#define PION_LOG_CONFIG_BASIC log4cxx::BasicConfigurator::configure();
#define PION_LOG_CONFIG(FILE) log4cxx::PropertyConfigurator::configure(FILE);
#define PION_GET_LOGGER(NAME) log4cxx::Logger::getLogger(NAME)
#define PION_LOG_SETLEVEL_DEBUG(LOG) LOG->setLevel(log4cxx::Level::toLevel(log4cxx::Level::DEBUG_INT));
#define PION_LOG_SETLEVEL_INFO(LOG) LOG->setLevel(log4cxx::Level::toLevel(log4cxx::Level::INFO_INT));
#define PION_LOG_SETLEVEL_WARN(LOG) LOG->setLevel(log4cxx::Level::toLevel(log4cxx::Level::WARN_INT));
#define PION_LOG_SETLEVEL_ERROR(LOG) LOG->setLevel(log4cxx::Level::toLevel(log4cxx::Level::ERROR_INT));
#define PION_LOG_SETLEVEL_FATAL(LOG) LOG->setLevel(log4cxx::Level::toLevel(log4cxx::Level::FATAL_INT));
#define PION_LOG_SETLEVEL_UP(LOG) LOG->setLevel(LOG->getLevel()->toInt()+1);
#define PION_LOG_SETLEVEL_DOWN(LOG) LOG->setLevel(LOG->getLevel()->toInt()-1);
#define PION_LOG_DEBUG LOG4CXX_DEBUG
#define PION_LOG_INFO LOG4CXX_INFO
#define PION_LOG_WARN LOG4CXX_WARN
#define PION_LOG_ERROR LOG4CXX_ERROR
#define PION_LOG_FATAL LOG4CXX_FATAL
#elif defined(PION_USE_LOG4CPLUS)
// log4cplus headers
#include <log4cplus/logger.h>
#include <log4cplus/configurator.h>
#include <log4cplus/appender.h>
#include <log4cplus/spi/loggingevent.h>
#include <log4cplus/loglevel.h>
#include <boost/circular_buffer.hpp>
#include <boost/thread/mutex.hpp>
#if defined _MSC_VER
#if defined _DEBUG
#pragma comment(lib, "log4cplusD")
#else
#pragma comment(lib, "log4cplus")
#endif
#endif
namespace pion {
typedef log4cplus::Logger PionLogger;
typedef log4cplus::Appender PionLogAppender;
typedef log4cplus::SharedAppenderPtr PionLogAppenderPtr;
///
/// CircularBufferAppender: caches log events in a circular buffer
///
class CircularBufferAppender : public log4cplus::Appender
{
public:
typedef boost::circular_buffer<log4cplus::spi::InternalLoggingEvent> LogEventBuffer;
// default constructor and destructor
CircularBufferAppender(void) : m_log_events(1000) {};
virtual ~CircularBufferAppender() {}
/// returns an iterator to the log events in the buffer
const LogEventBuffer& getLogIterator() const {
return m_log_events;
}
public:
// member functions inherited from the Appender interface class
virtual void close() {}
protected:
virtual void append(const log4cplus::spi::InternalLoggingEvent& event) {
boost::mutex::scoped_lock log_lock(m_log_mutex);
m_log_events.push_back(*event.clone());
}
private:
/// circular buffer for log events
LogEventBuffer m_log_events;
/// mutex to make class thread-safe
boost::mutex m_log_mutex;
};
}
#define PION_LOG_CONFIG_BASIC log4cplus::BasicConfigurator::doConfigure();
#define PION_LOG_CONFIG(FILE) log4cplus::PropertyConfigurator::doConfigure(FILE);
#define PION_GET_LOGGER(NAME) log4cplus::Logger::getInstance(NAME)
#define PION_LOG_SETLEVEL_DEBUG(LOG) LOG.setLogLevel(log4cplus::DEBUG_LOG_LEVEL);
#define PION_LOG_SETLEVEL_INFO(LOG) LOG.setLogLevel(log4cplus::INFO_LOG_LEVEL);
#define PION_LOG_SETLEVEL_WARN(LOG) LOG.setLogLevel(log4cplus::WARN_LOG_LEVEL);
#define PION_LOG_SETLEVEL_ERROR(LOG) LOG.setLogLevel(log4cplus::ERROR_LOG_LEVEL);
#define PION_LOG_SETLEVEL_FATAL(LOG) LOG.setLogLevel(log4cplus::FATAL_LOG_LEVEL);
#define PION_LOG_SETLEVEL_UP(LOG) LOG.setLogLevel(LOG.getLogLevel()+1);
#define PION_LOG_SETLEVEL_DOWN(LOG) LOG.setLogLevel(LOG.getLogLevel()-1);
#define PION_LOG_DEBUG LOG4CPLUS_DEBUG
#define PION_LOG_INFO LOG4CPLUS_INFO
#define PION_LOG_WARN LOG4CPLUS_WARN
#define PION_LOG_ERROR LOG4CPLUS_ERROR
#define PION_LOG_FATAL LOG4CPLUS_FATAL
#elif defined(PION_USE_LOG4CPP)
// log4cpp headers
#include <log4cpp/Category.hh>
#include <log4cpp/BasicLayout.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/AppenderSkeleton.hh>
namespace pion {
typedef log4cpp::Category* PionLogger;
typedef log4cpp::AppenderSkeleton PionLogAppender;
typedef PionLogAppender * PionLogAppenderPtr;
}
#define PION_LOG_CONFIG_BASIC { log4cpp::OstreamAppender *app = new log4cpp::OstreamAppender("cout", &std::cout); app->setLayout(new log4cpp::BasicLayout()); log4cpp::Category::getRoot().setAppender(app); }
#define PION_LOG_CONFIG(FILE) { log4cpp::PropertyConfigurator::configure(FILE); }
#define PION_GET_LOGGER(NAME) (&log4cpp::Category::getInstance(NAME))
#define PION_LOG_SETLEVEL_DEBUG(LOG) { LOG->setPriority(log4cpp::Priority::DEBUG); }
#define PION_LOG_SETLEVEL_INFO(LOG) { LOG->setPriority(log4cpp::Priority::INFO); }
#define PION_LOG_SETLEVEL_WARN(LOG) { LOG->setPriority(log4cpp::Priority::WARN); }
#define PION_LOG_SETLEVEL_ERROR(LOG) { LOG->setPriority(log4cpp::Priority::ERROR); }
#define PION_LOG_SETLEVEL_FATAL(LOG) { LOG->setPriority(log4cpp::Priority::FATAL); }
#define PION_LOG_SETLEVEL_UP(LOG) { LOG->setPriority(LOG.getPriority()+1); }
#define PION_LOG_SETLEVEL_DOWN(LOG) { LOG->setPriority(LOG.getPriority()-1); }
#define PION_LOG_DEBUG(LOG, MSG) if (LOG->getPriority()>=log4cpp::Priority::DEBUG) { LOG->debugStream() << MSG; }
#define PION_LOG_INFO(LOG, MSG) if (LOG->getPriority()>=log4cpp::Priority::INFO) { LOG->infoStream() << MSG; }
#define PION_LOG_WARN(LOG, MSG) if (LOG->getPriority()>=log4cpp::Priority::WARN) { LOG->warnStream() << MSG; }
#define PION_LOG_ERROR(LOG, MSG) if (LOG->getPriority()>=log4cpp::Priority::ERROR) { LOG->errorStream() << MSG; }
#define PION_LOG_FATAL(LOG, MSG) if (LOG->getPriority()>=log4cpp::Priority::FATAL) { LOG->fatalStream() << MSG; }
#elif defined(PION_DISABLE_LOGGING)
// Logging is disabled -> add do-nothing stubs for logging
namespace pion {
typedef int PionLogger;
}
#define PION_LOG_CONFIG_BASIC {}
#define PION_LOG_CONFIG(FILE) {}
#define PION_GET_LOGGER(NAME) 0
// use "++LOG" to avoid warnings about LOG not being used
#define PION_LOG_SETLEVEL_DEBUG(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_INFO(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_WARN(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_ERROR(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_FATAL(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_UP(LOG) { if (false) ++LOG; }
#define PION_LOG_SETLEVEL_DOWN(LOG) { if (false) ++LOG; }
// use "++LOG" to avoid warnings about LOG not being used
#define PION_LOG_DEBUG(LOG, MSG) { if (false) ++LOG; }
#define PION_LOG_INFO(LOG, MSG) { if (false) ++LOG; }
#define PION_LOG_WARN(LOG, MSG) { if (false) ++LOG; }
#define PION_LOG_ERROR(LOG, MSG) { if (false) ++LOG; }
#define PION_LOG_FATAL(LOG, MSG) { if (false) ++LOG; }
#else
#define PION_USE_OSTREAM_LOGGING
// Logging uses std::cout and std::cerr
#include <iostream>
#include <string>
#include <ctime>
namespace pion {
struct PION_COMMON_API PionLogger {
enum PionPriorityType {
LOG_LEVEL_DEBUG, LOG_LEVEL_INFO, LOG_LEVEL_WARN,
LOG_LEVEL_ERROR, LOG_LEVEL_FATAL
};
~PionLogger() {}
PionLogger(void) : m_name("pion") {}
PionLogger(const std::string& name) : m_name(name) {}
PionLogger(const PionLogger& p) : m_name(p.m_name) {}
std::string m_name;
static PionPriorityType m_priority;
};
}
#define PION_LOG_CONFIG_BASIC {}
#define PION_LOG_CONFIG(FILE) {}
#define PION_GET_LOGGER(NAME) pion::PionLogger(NAME)
#define PION_LOG_SETLEVEL_DEBUG(LOG) { LOG.m_priority = pion::PionLogger::LOG_LEVEL_DEBUG; }
#define PION_LOG_SETLEVEL_INFO(LOG) { LOG.m_priority = pion::PionLogger::LOG_LEVEL_INFO; }
#define PION_LOG_SETLEVEL_WARN(LOG) { LOG.m_priority = pion::PionLogger::LOG_LEVEL_WARN; }
#define PION_LOG_SETLEVEL_ERROR(LOG) { LOG.m_priority = pion::PionLogger::LOG_LEVEL_ERROR; }
#define PION_LOG_SETLEVEL_FATAL(LOG) { LOG.m_priority = pion::PionLogger::LOG_LEVEL_FATAL; }
#define PION_LOG_SETLEVEL_UP(LOG) { ++LOG.m_priority; }
#define PION_LOG_SETLEVEL_DOWN(LOG) { --LOG.m_priority; }
#define PION_LOG_DEBUG(LOG, MSG) if (LOG.m_priority <= pion::PionLogger::LOG_LEVEL_DEBUG) { std::cout << time(NULL) << " DEBUG " << LOG.m_name << ' ' << MSG << std::endl; }
#define PION_LOG_INFO(LOG, MSG) if (LOG.m_priority <= pion::PionLogger::LOG_LEVEL_INFO) { std::cout << time(NULL) << " INFO " << LOG.m_name << ' ' << MSG << std::endl; }
#define PION_LOG_WARN(LOG, MSG) if (LOG.m_priority <= pion::PionLogger::LOG_LEVEL_WARN) { std::cerr << time(NULL) << " WARN " << LOG.m_name << ' ' << MSG << std::endl; }
#define PION_LOG_ERROR(LOG, MSG) if (LOG.m_priority <= pion::PionLogger::LOG_LEVEL_ERROR) { std::cerr << time(NULL) << " ERROR " << LOG.m_name << ' ' << MSG << std::endl; }
#define PION_LOG_FATAL(LOG, MSG) if (LOG.m_priority <= pion::PionLogger::LOG_LEVEL_FATAL) { std::cerr << time(NULL) << " FATAL " << LOG.m_name << ' ' << MSG << std::endl; }
#endif
#endif
|