annotate libcxx/utils/google-benchmark/src/log.h @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 #ifndef BENCHMARK_LOG_H_
anatofuz
parents:
diff changeset
2 #define BENCHMARK_LOG_H_
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 #include <iostream>
anatofuz
parents:
diff changeset
5 #include <ostream>
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 #include "benchmark/benchmark.h"
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 namespace benchmark {
anatofuz
parents:
diff changeset
10 namespace internal {
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 typedef std::basic_ostream<char>&(EndLType)(std::basic_ostream<char>&);
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 class LogType {
anatofuz
parents:
diff changeset
15 friend LogType& GetNullLogInstance();
anatofuz
parents:
diff changeset
16 friend LogType& GetErrorLogInstance();
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 // FIXME: Add locking to output.
anatofuz
parents:
diff changeset
19 template <class Tp>
anatofuz
parents:
diff changeset
20 friend LogType& operator<<(LogType&, Tp const&);
anatofuz
parents:
diff changeset
21 friend LogType& operator<<(LogType&, EndLType*);
anatofuz
parents:
diff changeset
22
anatofuz
parents:
diff changeset
23 private:
anatofuz
parents:
diff changeset
24 LogType(std::ostream* out) : out_(out) {}
anatofuz
parents:
diff changeset
25 std::ostream* out_;
anatofuz
parents:
diff changeset
26 BENCHMARK_DISALLOW_COPY_AND_ASSIGN(LogType);
anatofuz
parents:
diff changeset
27 };
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 template <class Tp>
anatofuz
parents:
diff changeset
30 LogType& operator<<(LogType& log, Tp const& value) {
anatofuz
parents:
diff changeset
31 if (log.out_) {
anatofuz
parents:
diff changeset
32 *log.out_ << value;
anatofuz
parents:
diff changeset
33 }
anatofuz
parents:
diff changeset
34 return log;
anatofuz
parents:
diff changeset
35 }
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 inline LogType& operator<<(LogType& log, EndLType* m) {
anatofuz
parents:
diff changeset
38 if (log.out_) {
anatofuz
parents:
diff changeset
39 *log.out_ << m;
anatofuz
parents:
diff changeset
40 }
anatofuz
parents:
diff changeset
41 return log;
anatofuz
parents:
diff changeset
42 }
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 inline int& LogLevel() {
anatofuz
parents:
diff changeset
45 static int log_level = 0;
anatofuz
parents:
diff changeset
46 return log_level;
anatofuz
parents:
diff changeset
47 }
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 inline LogType& GetNullLogInstance() {
anatofuz
parents:
diff changeset
50 static LogType log(nullptr);
anatofuz
parents:
diff changeset
51 return log;
anatofuz
parents:
diff changeset
52 }
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 inline LogType& GetErrorLogInstance() {
anatofuz
parents:
diff changeset
55 static LogType log(&std::clog);
anatofuz
parents:
diff changeset
56 return log;
anatofuz
parents:
diff changeset
57 }
anatofuz
parents:
diff changeset
58
anatofuz
parents:
diff changeset
59 inline LogType& GetLogInstanceForLevel(int level) {
anatofuz
parents:
diff changeset
60 if (level <= LogLevel()) {
anatofuz
parents:
diff changeset
61 return GetErrorLogInstance();
anatofuz
parents:
diff changeset
62 }
anatofuz
parents:
diff changeset
63 return GetNullLogInstance();
anatofuz
parents:
diff changeset
64 }
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 } // end namespace internal
anatofuz
parents:
diff changeset
67 } // end namespace benchmark
anatofuz
parents:
diff changeset
68
anatofuz
parents:
diff changeset
69 // clang-format off
anatofuz
parents:
diff changeset
70 #define VLOG(x) \
anatofuz
parents:
diff changeset
71 (::benchmark::internal::GetLogInstanceForLevel(x) << "-- LOG(" << x << "):" \
anatofuz
parents:
diff changeset
72 " ")
anatofuz
parents:
diff changeset
73 // clang-format on
anatofuz
parents:
diff changeset
74 #endif