2020-04-29 15:27:14 +02:00
|
|
|
//
|
|
|
|
// logger.hpp
|
|
|
|
// libsclogging
|
|
|
|
//
|
|
|
|
// Created by Bob Polis at 2020-04-29
|
|
|
|
// Copyright (c) 2020 SwiftCoder. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef _logger_H_
|
|
|
|
#define _logger_H_
|
|
|
|
|
|
|
|
#include <iostream>
|
2020-04-29 16:54:58 +02:00
|
|
|
#include <string>
|
2020-04-29 15:27:14 +02:00
|
|
|
|
|
|
|
namespace sc {
|
|
|
|
|
|
|
|
enum class loglevel {
|
|
|
|
undefined,
|
|
|
|
debug,
|
|
|
|
info,
|
|
|
|
warning,
|
|
|
|
error,
|
|
|
|
critical
|
|
|
|
};
|
|
|
|
|
|
|
|
constexpr bool operator>=(loglevel lhs, loglevel rhs) {
|
|
|
|
return static_cast<int>(lhs) >= static_cast<int>(rhs);
|
|
|
|
}
|
|
|
|
|
|
|
|
constexpr const char* loglevel_desc(loglevel lvl) {
|
|
|
|
switch (lvl) {
|
|
|
|
case loglevel::undefined: return "UNDEFINED"; break;
|
|
|
|
case loglevel::debug: return "DEBUG"; break;
|
|
|
|
case loglevel::info: return "INFO"; break;
|
|
|
|
case loglevel::warning: return "WARNING"; break;
|
|
|
|
case loglevel::error: return "ERROR"; break;
|
|
|
|
case loglevel::critical: return "CRITICAL"; break;
|
|
|
|
}
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
|
|
|
|
class logger {
|
|
|
|
public:
|
2020-04-29 16:54:58 +02:00
|
|
|
logger(const std::string& name, loglevel level);
|
2020-04-29 15:27:14 +02:00
|
|
|
|
2020-04-29 16:40:04 +02:00
|
|
|
void msg(loglevel level, const char* file, int line, const char* func);
|
2020-04-29 15:27:14 +02:00
|
|
|
|
|
|
|
template<typename T, typename... Args>
|
2020-04-29 16:40:04 +02:00
|
|
|
void msg(loglevel level, const char* file, int line, const char* func,
|
|
|
|
T value, Args... args) {
|
2020-04-29 15:27:14 +02:00
|
|
|
if (level >= _level) {
|
|
|
|
if (_topcall) {
|
|
|
|
_topcall = false;
|
2020-04-29 16:40:04 +02:00
|
|
|
write_prefix(level, file, line, func);
|
2020-04-29 15:27:14 +02:00
|
|
|
}
|
|
|
|
std::cerr << value;
|
2020-04-29 16:40:04 +02:00
|
|
|
msg(level, file, line, func, args...);
|
2020-04-29 15:27:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loglevel level() const { return _level; }
|
|
|
|
void level(loglevel level) { _level = level; }
|
|
|
|
|
|
|
|
private:
|
2020-04-29 16:40:04 +02:00
|
|
|
void write_prefix(loglevel level,
|
|
|
|
const char* file,
|
|
|
|
int line,
|
|
|
|
const char* func);
|
2020-04-29 15:27:14 +02:00
|
|
|
|
|
|
|
loglevel _level {loglevel::info};
|
|
|
|
bool _topcall {true};
|
2020-04-29 16:54:58 +02:00
|
|
|
std::string _name;
|
2020-04-29 15:27:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-04-29 16:40:04 +02:00
|
|
|
#define _debug(logger, ...) logger.msg(sc::loglevel::debug, __FILE__, __LINE__, __FUNCTION__, __VA_ARGS__)
|
|
|
|
#define _info(logger, ...) logger.msg(sc::loglevel::info, __FILE__, __LINE__, __FUNCTION__, __VA_ARGS__)
|
|
|
|
#define _warning(logger, ...) logger.msg(sc::loglevel::warning, __FILE__, __LINE__, __FUNCTION__, __VA_ARGS__)
|
|
|
|
#define _error(logger, ...) logger.msg(sc::loglevel::error, __FILE__, __LINE__, __FUNCTION__, __VA_ARGS__)
|
|
|
|
#define _critical(logger, ...) logger.msg(sc::loglevel::critical, __FILE__, __LINE__, __FUNCTION__, __VA_ARGS__)
|
|
|
|
|
2020-04-29 15:27:14 +02:00
|
|
|
#endif // _logger_H_
|