Revision 5f6623a9e0dfc5c7ed37718bb6e1c1f66e0f2e82 authored by Dmitri Naumov on 08 June 2021, 18:57:27 UTC, committed by Dmitri Naumov on 09 June 2021, 11:55:47 UTC
1 parent 19e3e0b
Logging.cpp
/**
* \file
*
* \copyright
* Copyright (c) 2012-2021, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#include "Logging.h"
#include <spdlog/sinks/stdout_color_sinks.h>
#include <spdlog/spdlog.h>
#include <map>
#ifdef USE_PETSC
#include <mpi.h>
#include <petscsys.h>
#endif
#include "Error.h"
namespace BaseLib
{
#ifdef USE_PETSC
std::shared_ptr<spdlog::logger> console = spdlog::stdout_color_mt("ogs");
#else // USE_PETSC
std::shared_ptr<spdlog::logger> console = spdlog::stdout_color_st("ogs");
#endif // USE_PETSC
void setConsoleLogLevel(std::string const& level_string)
{
using namespace spdlog::level;
std::map<std::string, level_enum> string_to_log_level = {
{"none", off}, {"critical", critical}, {"error", err}, {"warn", warn},
{"info", info}, {"debug", debug}, {"all", trace}};
auto const level = string_to_log_level.find(level_string);
if (level == string_to_log_level.end())
{
ERR("'{:s}' is not a valid log level!", level_string);
OGS_FATAL("Wrong log level string.");
}
console->set_level(level->second);
spdlog::set_default_logger(console);
}
} // namespace BaseLib
Computing file changes ...