#include "spdlog/spdlog.h"

#include <iostream>
#include <memory>

namespace spd = spdlog;
int main(int, char *[])
{
    bool enable_debug = true;
    try
    {
        // This other example use a single logger with multiple sinks.
        // This means that the same log_msg is forwarded to multiple sinks;
        // Each sink can have it's own log level and a message will be logged.
        std::vector<spdlog::sink_ptr> sinks;
        sinks.push_back(std::make_shared<spdlog::sinks::stdout_sink_mt>());
        sinks.push_back(std::make_shared<spdlog::sinks::simple_file_sink_mt>("./log_regular_file.txt"));
        sinks.push_back(std::make_shared<spdlog::sinks::simple_file_sink_mt>("./log_debug_file.txt"));

        spdlog::logger console_multisink("multisink", sinks.begin(), sinks.end());
        console_multisink.set_level(spdlog::level::warn);

        sinks[0]->set_level(spdlog::level::trace); // console. Allow everything.  Default value
        sinks[1]->set_level(spdlog::level::trace); //  regular file. Allow everything.  Default value
        sinks[2]->set_level(spdlog::level::off);   //  regular file. Ignore everything.

        console_multisink.warn("warn: will print only on console and regular file");

        if (enable_debug)
        {
            console_multisink.set_level(spdlog::level::debug); // level of the logger
            sinks[1]->set_level(spdlog::level::debug);         // regular file
            sinks[2]->set_level(spdlog::level::debug);         // debug file
        }
        console_multisink.debug("Debug: you should see this on console and both files");

        // Release and close all loggers
        spdlog::drop_all();
    }
    // Exceptions will only be thrown upon failed logger or sink construction (not during logging)
    catch (const spd::spdlog_ex &ex)
    {
        std::cout << "Log init failed: " << ex.what() << std::endl;
        return 1;
    }
}