spla
Loading...
Searching...
No Matches
logger.hpp
Go to the documentation of this file.
1/**********************************************************************************/
2/* This file is part of spla project */
3/* https://github.com/SparseLinearAlgebra/spla */
4/**********************************************************************************/
5/* MIT License */
6/* */
7/* Copyright (c) 2023 SparseLinearAlgebra */
8/* */
9/* Permission is hereby granted, free of charge, to any person obtaining a copy */
10/* of this software and associated documentation files (the "Software"), to deal */
11/* in the Software without restriction, including without limitation the rights */
12/* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell */
13/* copies of the Software, and to permit persons to whom the Software is */
14/* furnished to do so, subject to the following conditions: */
15/* */
16/* The above copyright notice and this permission notice shall be included in all */
17/* copies or substantial portions of the Software. */
18/* */
19/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
20/* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
21/* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
22/* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
23/* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
24/* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
25/* SOFTWARE. */
26/**********************************************************************************/
27
28#ifndef SPLA_LOGGER_HPP
29#define SPLA_LOGGER_HPP
30
31#include <spla/config.hpp>
32
33#include <functional>
34#include <mutex>
35#include <sstream>
36
37namespace spla {
38
48 class Logger {
49 public:
50 void log_msg(Status status, const std::string& msg, const std::string& file, const std::string& function, int line);
51 void set_msg_callback(MessageCallback callback);
52
53 private:
54 MessageCallback m_callback;
55
56 mutable std::mutex m_mutex;
57 };
58
63}// namespace spla
64
65#ifndef SPLA_RELEASE
66 #define LOG_MSG(status, msg) \
67 do { \
68 std::stringstream __ss; \
69 __ss << msg; \
70 Library::get()->get_logger()->log_msg(status, __ss.str(), __FILE__, __FUNCTION__, static_cast<int>(__LINE__)); \
71 } while (false);
72#else
73 #define LOG_MSG(status, msg) \
74 do { \
75 if ((status) != Status::Ok) { \
76 std::stringstream __ss; \
77 __ss << msg; \
78 Library::get()->get_logger()->log_msg(status, __ss.str(), __FILE__, __FUNCTION__, static_cast<int>(__LINE__)); \
79 } \
80 } while (false);
81#endif
82
83#endif//SPLA_LOGGER_HPP
Callback function called on library message event.
Status of library operation execution.
Library logger.
Definition logger.hpp:48
void log_msg(Status status, const std::string &msg, const std::string &file, const std::string &function, int line)
Definition logger.cpp:34
void set_msg_callback(MessageCallback callback)
Definition logger.cpp:40
Definition algorithm.hpp:37