spdlog/bench/formatter-bench.cpp

93 lines
2.5 KiB
C++
Raw Normal View History

2018-11-11 06:52:21 +08:00
//
// Copyright(c) 2018 Gabi Melman.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
//
#include "benchmark/benchmark.h"
#include "spdlog/spdlog.h"
#include "spdlog/details/pattern_formatter.h"
void bench_scoped_pad(benchmark::State &state, size_t wrapped_size, spdlog::details::padding_info padinfo)
{
fmt::memory_buffer dest;
for (auto _ : state)
{
{
spdlog::details::scoped_pad p(wrapped_size, padinfo, dest);
benchmark::DoNotOptimize(p);
2018-11-12 22:13:52 +08:00
dest.clear();
2018-11-11 06:52:21 +08:00
}
2018-11-12 22:13:52 +08:00
}
}
void bench_formatter(benchmark::State &state, std::string pattern)
{
auto formatter = spdlog::details::make_unique<spdlog::pattern_formatter>(pattern);
fmt::memory_buffer dest;
std::string logger_name = "logger-name";
const char* text = "Hello. This is some message with length of 80 ";
spdlog::details::log_msg msg(&logger_name, spdlog::level::info, text);
// formatter->format(msg, dest);
// printf("%s\n", fmt::to_string(dest).c_str());
for (auto _ : state)
{
2018-11-11 06:52:21 +08:00
dest.clear();
2018-11-12 22:13:52 +08:00
formatter->format(msg, dest);
benchmark::DoNotOptimize(dest);
2018-11-11 06:52:21 +08:00
}
}
2018-11-12 22:13:52 +08:00
void bench_formatters()
{
// basic patterns(single flag)
std::string all_flags = "+vtPnlLaAbBcCYDmdHIMSefFprRTXzEi%";
std::vector<std::string> basic_patterns;
for(auto &flag:all_flags)
{
auto pattern = std::string("%") + flag;
2018-11-16 20:13:29 +08:00
benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
//bench left padding
pattern = std::string("%16") + flag;
benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
//bench center padding
pattern = std::string("%=16") + flag;
benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
2018-11-12 22:13:52 +08:00
}
2018-11-16 20:13:29 +08:00
2018-11-12 22:13:52 +08:00
// complex patterns
std::vector<std::string> patterns = {
"[%D %X] [%l] [%n] %v",
"[%Y-%m-%d %H:%M:%S.%e] [%l] [%n] %v",
"[%Y-%m-%d %H:%M:%S.%e] [%l] [%n] [%t] %v",
};
for(auto &pattern:patterns)
{
2018-11-12 22:44:34 +08:00
benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern)->Iterations(2500000);
2018-11-12 22:13:52 +08:00
}
}
2018-11-16 20:13:29 +08:00
int main(int argc, char *argv[])
2018-11-11 07:26:57 +08:00
{
2018-11-11 06:52:21 +08:00
2018-11-16 20:13:29 +08:00
if(argc > 1) //bench given pattern
2018-11-11 06:52:21 +08:00
{
2018-11-16 20:13:29 +08:00
std::string pattern = argv[1];
benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
}
else //bench all flags
{
bench_formatters();
2018-11-11 06:52:21 +08:00
}
benchmark::Initialize(&argc, argv);
benchmark::RunSpecifiedBenchmarks();
}
2018-11-12 22:13:52 +08:00