mirror of
https://github.com/rdkit/rdkit.git
synced 2026-06-07 22:44:25 +08:00
* run clang-tidy with readability-braces-around-statements clang-format the results clean up all the parts that clang-tidy-8 broke * fix problem on windows
160 lines
5.0 KiB
C++
160 lines
5.0 KiB
C++
// $Id$
|
|
//
|
|
// Copyright (C) 2005-2010 Greg Landrum and Rational Discovery LLC
|
|
//
|
|
// @@ All Rights Reserved @@
|
|
// This file is part of the RDKit.
|
|
// The contents are covered by the terms of the BSD license
|
|
// which is included in the file license.txt, found at the root
|
|
// of the RDKit source tree.
|
|
//
|
|
#include "RDLog.h"
|
|
|
|
#if 1
|
|
#include <iomanip>
|
|
#include <string>
|
|
#include <time.h>
|
|
|
|
std::shared_ptr<boost::logging::rdLogger> rdAppLog = nullptr;
|
|
std::shared_ptr<boost::logging::rdLogger> rdDebugLog = nullptr;
|
|
std::shared_ptr<boost::logging::rdLogger> rdInfoLog = nullptr;
|
|
std::shared_ptr<boost::logging::rdLogger> rdErrorLog = nullptr;
|
|
std::shared_ptr<boost::logging::rdLogger> rdWarningLog = nullptr;
|
|
std::shared_ptr<boost::logging::rdLogger> rdStatusLog = nullptr;
|
|
|
|
namespace boost {
|
|
namespace logging {
|
|
|
|
void enable_logs(const char *arg) { enable_logs(std::string(arg)); };
|
|
void enable_logs(const std::string &arg) {
|
|
// Yes... this is extremely crude
|
|
if (arg == "rdApp.debug" || arg == "rdApp.*") {
|
|
if (rdDebugLog) {
|
|
rdDebugLog->df_enabled = true;
|
|
}
|
|
}
|
|
if (arg == "rdApp.info" || arg == "rdApp.*") {
|
|
if (rdInfoLog) {
|
|
rdInfoLog->df_enabled = true;
|
|
}
|
|
}
|
|
if (arg == "rdApp.warning" || arg == "rdApp.*") {
|
|
if (rdWarningLog) {
|
|
rdWarningLog->df_enabled = true;
|
|
}
|
|
}
|
|
if (arg == "rdApp.error" || arg == "rdApp.*") {
|
|
if (rdErrorLog) {
|
|
rdErrorLog->df_enabled = true;
|
|
}
|
|
}
|
|
};
|
|
void disable_logs(const char *arg) { disable_logs(std::string(arg)); };
|
|
void disable_logs(const std::string &arg) {
|
|
// Yes... this is extremely crude
|
|
if (arg == "rdApp.debug" || arg == "rdApp.*") {
|
|
if (rdDebugLog) {
|
|
rdDebugLog->df_enabled = false;
|
|
}
|
|
}
|
|
if (arg == "rdApp.info" || arg == "rdApp.*") {
|
|
if (rdInfoLog) {
|
|
rdInfoLog->df_enabled = false;
|
|
}
|
|
}
|
|
if (arg == "rdApp.warning" || arg == "rdApp.*") {
|
|
if (rdWarningLog) {
|
|
rdWarningLog->df_enabled = false;
|
|
}
|
|
}
|
|
if (arg == "rdApp.error" || arg == "rdApp.*") {
|
|
if (rdErrorLog) {
|
|
rdErrorLog->df_enabled = false;
|
|
}
|
|
}
|
|
};
|
|
} // namespace logging
|
|
} // namespace boost
|
|
|
|
namespace RDLog {
|
|
void InitLogs() {
|
|
rdDebugLog = std::make_shared<boost::logging::rdLogger>(&std::cerr);
|
|
rdInfoLog = std::make_shared<boost::logging::rdLogger>(&std::cout);
|
|
rdWarningLog = std::make_shared<boost::logging::rdLogger>(&std::cerr);
|
|
rdErrorLog = std::make_shared<boost::logging::rdLogger>(&std::cerr);
|
|
}
|
|
std::ostream &toStream(std::ostream &logstrm) {
|
|
time_t t = time(nullptr);
|
|
tm details = *localtime(&t);
|
|
logstrm << "[" << std::setw(2) << std::setfill('0') << details.tm_hour << ":"
|
|
<< std::setw(2) << std::setfill('0') << details.tm_min << ":"
|
|
<< std::setw(2) << std::setfill('0') << int(details.tm_sec) << "] ";
|
|
return logstrm;
|
|
}
|
|
} // namespace RDLog
|
|
|
|
#else
|
|
#include <boost/log/functions.hpp>
|
|
#if defined(BOOST_HAS_THREADS2)
|
|
#include <boost/log/extra/functions_ts.hpp>
|
|
#endif
|
|
#include <iostream>
|
|
namespace logging = boost::logging;
|
|
|
|
BOOST_DEFINE_LOG(rdAppLog, "rdApp")
|
|
BOOST_DEFINE_LOG(rdDebugLog, "rdApp.debug")
|
|
BOOST_DEFINE_LOG(rdInfoLog, "rdApp.info")
|
|
BOOST_DEFINE_LOG(rdErrorLog, "rdApp.error")
|
|
BOOST_DEFINE_LOG(rdWarningLog, "rdApp.warning")
|
|
BOOST_DEFINE_LOG(rdStatusLog, "rdApp.status")
|
|
|
|
namespace RDLog {
|
|
void write_to_cout(const std::string &, const std::string &msg) {
|
|
std::cout << msg;
|
|
std::cout.flush();
|
|
}
|
|
void write_to_cerr(const std::string &, const std::string &msg) {
|
|
std::cerr << msg;
|
|
std::cerr.flush();
|
|
}
|
|
|
|
void InitLogs() {
|
|
static bool callOnce = true;
|
|
if (!callOnce) return;
|
|
callOnce = false;
|
|
|
|
// turn off caching:
|
|
logging::set_log_caching(false);
|
|
logging::manipulate_logs("rdApp.*").add_modifier(
|
|
logging::prepend_time("[$hh:$mm:$ss] "), logging::DEFAULT_INDEX - 10);
|
|
logging::manipulate_logs("rdApp.info")
|
|
.add_appender(write_to_cout, logging::DEFAULT_INDEX + 1);
|
|
#if defined(BOOST_HAS_THREADS2)
|
|
logging::manipulate_logs("rdApp.error")
|
|
.add_appender(logging::ts_appender(write_to_cerr, 100),
|
|
logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.warning")
|
|
.add_appender(logging::ts_appender(write_to_cerr, 100),
|
|
logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.status")
|
|
.add_appender(logging::ts_appender(write_to_cerr, 100),
|
|
logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.debug")
|
|
.add_appender(logging::ts_appender(write_to_cerr, 100),
|
|
logging::DEFAULT_INDEX + 1);
|
|
#else
|
|
logging::manipulate_logs("rdApp.error")
|
|
.add_appender(write_to_cerr, logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.warning")
|
|
.add_appender(write_to_cerr, logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.status")
|
|
.add_appender(write_to_cerr, logging::DEFAULT_INDEX + 1);
|
|
logging::manipulate_logs("rdApp.debug")
|
|
.add_appender(write_to_cerr, logging::DEFAULT_INDEX + 1);
|
|
#endif
|
|
// start with the debug log disabled:
|
|
logging::disable_logs("rdApp.debug");
|
|
};
|
|
} // namespace RDLog
|
|
#endif
|