Files
scylladb/log.cc
Avi Kivity 0362800e8d log: add slf4j-compatible logger class
Supports variadic logging with placeholders, e.g.

  logger.error("what happened? x = {}, y = {}", x, y);

Instantiate loggers as static thread_local, e.g.

  class foo {
      static thread_local logging::logger logger;
  };

  thread_local logging::logger foo::logger{logging::logger_for<foo>};
2014-12-29 17:09:41 +02:00

66 lines
1.3 KiB
C++

/*
* Copyright (C) 2014 Cloudius Systems, Ltd.
*/
#include "log.hh"
#include <cxxabi.h>
namespace logging {
logger::logger(sstring name) : _name(std::move(name)) {
g_registry.register_logger(this);
}
logger::logger(logger&& x) : _name(std::move(x._name)), _level(x._level) {
g_registry.moved(&x, this);
}
logger::~logger() {
g_registry.unregister_logger(this);
}
void
logger::really_do_log(log_level level, const char* fmt, stringer** s, size_t n) {
const char* p = fmt;
while (*p != '\0') {
if (*p == '{' && *(p+1) == '}') {
p += 2;
if (n > 0) {
(*s++)->append(std::cout);
--n;
} else {
std::cout << "???";
}
} else {
std::cout << *p++;
}
}
std::cout << "\n";
}
void
registry::register_logger(logger* l) {
_loggers[l->name()] = l;
}
void
registry::unregister_logger(logger* l) {
_loggers.erase(l->name());
}
void
registry::moved(logger* from, logger* to) {
_loggers[from->name()] = to;
}
sstring pretty_type_name(const std::type_info& ti) {
int status;
std::unique_ptr<char[], void (*)(void*)> result(
abi::__cxa_demangle(ti.name(), 0, 0, &status), std::free);
return result.get() ? result.get() : ti.name();
}
thread_local registry g_registry;
}