Как лучше использовать один и тот же лог Boost в моей программе на C ++? - PullRequest
0 голосов
/ 09 ноября 2019

извинения, если я пропустил трюк в документации 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();

    };
}

1 Ответ

0 голосов
/ 09 ноября 2019

Я решил это сам ...

Мне просто нужно было определить регистратор как тот же тип во втором классе, как это:

namespace KeyGeo
{
    class KGDataFactory
    {

        private:
            SQLWCHAR *connStr;
            std::vector< KGResult > results;

            /* added this.....*/
            src::severity_logger< severity_level > lg;

        public:
            KGDataFactory();
            KGSQLManager SQLManager;
            void parseSourceGeo();
            void initLogs();

    };
}

используется так:

namespace KeyGeo
{

    /* consturctor for main factory wrapper */
    KGDataFactory::KGDataFactory()
    {
        BOOST_LOG_SEV(lg, info) << "This worked in the class";
    };
...