formatter-bench.cpp 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. //
  2. // Copyright(c) 2018 Gabi Melman.
  3. // Distributed under the MIT License (http://opensource.org/licenses/MIT)
  4. //
  5. #include "benchmark/benchmark.h"
  6. #include "spdlog/spdlog.h"
  7. #include "spdlog/pattern_formatter.h"
  8. void bench_formatter(benchmark::State &state, std::string pattern)
  9. {
  10. auto formatter = spdlog::details::make_unique<spdlog::pattern_formatter>(pattern);
  11. spdlog::memory_buf_t dest;
  12. std::string logger_name = "logger-name";
  13. const char *text = "Hello. This is some message with length of 80 ";
  14. spdlog::source_loc source_loc{"a/b/c/d/myfile.cpp", 123, "some_func()"};
  15. spdlog::details::log_msg msg(source_loc, logger_name, spdlog::level::info, text);
  16. for (auto _ : state)
  17. {
  18. dest.clear();
  19. formatter->format(msg, dest);
  20. benchmark::DoNotOptimize(dest);
  21. }
  22. }
  23. void bench_formatters()
  24. {
  25. // basic patterns(single flag)
  26. std::string all_flags = "+vtPnlLaAbBcCYDmdHIMSefFprRTXzEisg@luioO%";
  27. std::vector<std::string> basic_patterns;
  28. for (auto &flag : all_flags)
  29. {
  30. auto pattern = std::string("%") + flag;
  31. benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
  32. // pattern = std::string("%16") + flag;
  33. // benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
  34. //
  35. // // bench center padding
  36. // pattern = std::string("%=16") + flag;
  37. // benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
  38. }
  39. // complex patterns
  40. std::vector<std::string> patterns = {
  41. "[%D %X] [%l] [%n] %v",
  42. "[%Y-%m-%d %H:%M:%S.%e] [%l] [%n] %v",
  43. "[%Y-%m-%d %H:%M:%S.%e] [%l] [%n] [%t] %v",
  44. };
  45. for (auto &pattern : patterns)
  46. {
  47. benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern)->Iterations(2500000);
  48. }
  49. }
  50. int main(int argc, char *argv[])
  51. {
  52. spdlog::set_pattern("[%^%l%$] %v");
  53. if (argc != 2)
  54. {
  55. spdlog::error("Usage: {} <pattern> (or \"all\" to bench all)", argv[0]);
  56. exit(1);
  57. }
  58. std::string pattern = argv[1];
  59. if (pattern == "all")
  60. {
  61. bench_formatters();
  62. }
  63. else
  64. {
  65. benchmark::RegisterBenchmark(pattern.c_str(), bench_formatter, pattern);
  66. }
  67. benchmark::Initialize(&argc, argv);
  68. benchmark::RunSpecifiedBenchmarks();
  69. }