извинения, если я пропустил трюк в документации Boost, но я действительно изо всех сил пытаюсь понять, как лучше использовать журнал Boost во всей моей программе.
Я не полный ноб С ++, но я не очень хорошо разбираюсь в этом языке ....!
Короче:
Что такоелучшая практика использовать тот же лог Boost в других моих классах за пределами основного класса?
Мои цели - использовать журнал форсирования, который сохраняется в файл, а также выводится на консоль.
Установочный / основной бит работает нормально:
Основная точка входа:
void init();
int main()
{
/*start logging */
init();
logging::add_common_attributes();
using namespace logging::trivial;
src::severity_logger< severity_level > lg;
BOOST_LOG_SEV(lg, info) << "KeyGeo started...";
//rest of my program objects start here, omitted for brevity......
return 0;
}
с функцией инициализации для настройки регистратора согласноBoost docs
/* configuration for the boost log */
void init()
{
logging::add_file_log
(
keywords::file_name = "KGLog_%N.log",
keywords::rotation_size = 10 * 1024 * 1024,
keywords::time_based_rotation = sinks::file::rotation_at_time_point(0, 0, 0),
keywords::format = "[%TimeStamp%]: %Message%",
keywords::open_mode = std::ios_base::app,
keywords::auto_flush = true
);
logging::core::get()->set_filter
(
logging::trivial::severity >= logging::trivial::info
);
}
Но что / как я могу использовать этот же журнал в других моих классах. Я мог бы передать 'lg' в качестве аргумента конструктору или тому подобному, но это похоже на хакерский путь. Я пробовал различные примеры, такие как src::logger lg
, но они не работали.
Что я здесь вставил?
#include "KGSQLManager.h"
#include "KGResult.h"
#include "stdafx.h"
using namespace logging::trivial;
namespace KeyGeo
{
class KGDataFactory
{
/* SOME BOOST LOG OBJECT IM GUESSING ???! */
private:
SQLWCHAR *connStr;
std::vector< KGResult > results;
public:
KGDataFactory();
KGSQLManager SQLManager;
void parseSourceGeo();
void initLogs();
};
}