Roll src/third_party/WebKit eac3800:0237a66 (svn 202606:202607)
[chromium-blink-merge.git] / base / mac / mach_logging.h
blobb12e274ea80145ff7f8d6917467cae9562235faf
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_MAC_MACH_LOGGING_H_
6 #define BASE_MAC_MACH_LOGGING_H_
8 #include <mach/mach.h>
10 #include "base/base_export.h"
11 #include "base/basictypes.h"
12 #include "base/logging.h"
13 #include "build/build_config.h"
15 // Use the MACH_LOG family of macros along with a mach_error_t (kern_return_t)
16 // containing a Mach error. The error value will be decoded so that logged
17 // messages explain the error.
19 // Use the BOOTSTRAP_LOG family of macros specifically for errors that occur
20 // while interoperating with the bootstrap subsystem. These errors will first
21 // be looked up as bootstrap error messages. If no match is found, they will
22 // be treated as generic Mach errors, as in MACH_LOG.
24 // Examples:
26 // kern_return_t kr = mach_timebase_info(&info);
27 // if (kr != KERN_SUCCESS) {
28 // MACH_LOG(ERROR, kr) << "mach_timebase_info";
29 // }
31 // kr = vm_deallocate(task, address, size);
32 // MACH_DCHECK(kr == KERN_SUCCESS, kr) << "vm_deallocate";
34 namespace logging {
36 class BASE_EXPORT MachLogMessage : public logging::LogMessage {
37 public:
38 MachLogMessage(const char* file_path,
39 int line,
40 LogSeverity severity,
41 mach_error_t mach_err);
42 ~MachLogMessage();
44 private:
45 mach_error_t mach_err_;
47 DISALLOW_COPY_AND_ASSIGN(MachLogMessage);
50 } // namespace logging
52 #if defined(NDEBUG)
53 #define MACH_DVLOG_IS_ON(verbose_level) 0
54 #else
55 #define MACH_DVLOG_IS_ON(verbose_level) VLOG_IS_ON(verbose_level)
56 #endif
58 #define MACH_LOG_STREAM(severity, mach_err) \
59 COMPACT_GOOGLE_LOG_EX_ ## severity(MachLogMessage, mach_err).stream()
60 #define MACH_VLOG_STREAM(verbose_level, mach_err) \
61 logging::MachLogMessage(__FILE__, __LINE__, \
62 -verbose_level, mach_err).stream()
64 #define MACH_LOG(severity, mach_err) \
65 LAZY_STREAM(MACH_LOG_STREAM(severity, mach_err), LOG_IS_ON(severity))
66 #define MACH_LOG_IF(severity, condition, mach_err) \
67 LAZY_STREAM(MACH_LOG_STREAM(severity, mach_err), \
68 LOG_IS_ON(severity) && (condition))
70 #define MACH_VLOG(verbose_level, mach_err) \
71 LAZY_STREAM(MACH_VLOG_STREAM(verbose_level, mach_err), \
72 VLOG_IS_ON(verbose_level))
73 #define MACH_VLOG_IF(verbose_level, condition, mach_err) \
74 LAZY_STREAM(MACH_VLOG_STREAM(verbose_level, mach_err), \
75 VLOG_IS_ON(verbose_level) && (condition))
77 #define MACH_CHECK(condition, mach_err) \
78 LAZY_STREAM(MACH_LOG_STREAM(FATAL, mach_err), !(condition)) \
79 << "Check failed: " # condition << ". "
81 #define MACH_DLOG(severity, mach_err) \
82 LAZY_STREAM(MACH_LOG_STREAM(severity, mach_err), DLOG_IS_ON(severity))
83 #define MACH_DLOG_IF(severity, condition, mach_err) \
84 LAZY_STREAM(MACH_LOG_STREAM(severity, mach_err), \
85 DLOG_IS_ON(severity) && (condition))
87 #define MACH_DVLOG(verbose_level, mach_err) \
88 LAZY_STREAM(MACH_VLOG_STREAM(verbose_level, mach_err), \
89 MACH_DVLOG_IS_ON(verbose_level))
90 #define MACH_DVLOG_IF(verbose_level, condition, mach_err) \
91 LAZY_STREAM(MACH_VLOG_STREAM(verbose_level, mach_err), \
92 MACH_DVLOG_IS_ON(verbose_level) && (condition))
94 #define MACH_DCHECK(condition, mach_err) \
95 LAZY_STREAM(MACH_LOG_STREAM(FATAL, mach_err), \
96 DCHECK_IS_ON() && !(condition)) \
97 << "Check failed: " #condition << ". "
99 #if !defined(OS_IOS)
101 namespace logging {
103 class BASE_EXPORT BootstrapLogMessage : public logging::LogMessage {
104 public:
105 BootstrapLogMessage(const char* file_path,
106 int line,
107 LogSeverity severity,
108 kern_return_t bootstrap_err);
109 ~BootstrapLogMessage();
111 private:
112 kern_return_t bootstrap_err_;
114 DISALLOW_COPY_AND_ASSIGN(BootstrapLogMessage);
117 } // namespace logging
119 #define BOOTSTRAP_DVLOG_IS_ON MACH_DVLOG_IS_ON
121 #define BOOTSTRAP_LOG_STREAM(severity, bootstrap_err) \
122 COMPACT_GOOGLE_LOG_EX_ ## severity(BootstrapLogMessage, \
123 bootstrap_err).stream()
124 #define BOOTSTRAP_VLOG_STREAM(verbose_level, bootstrap_err) \
125 logging::BootstrapLogMessage(__FILE__, __LINE__, \
126 -verbose_level, bootstrap_err).stream()
128 #define BOOTSTRAP_LOG(severity, bootstrap_err) \
129 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(severity, \
130 bootstrap_err), LOG_IS_ON(severity))
131 #define BOOTSTRAP_LOG_IF(severity, condition, bootstrap_err) \
132 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(severity, bootstrap_err), \
133 LOG_IS_ON(severity) && (condition))
135 #define BOOTSTRAP_VLOG(verbose_level, bootstrap_err) \
136 LAZY_STREAM(BOOTSTRAP_VLOG_STREAM(verbose_level, bootstrap_err), \
137 VLOG_IS_ON(verbose_level))
138 #define BOOTSTRAP_VLOG_IF(verbose_level, condition, bootstrap_err) \
139 LAZY_STREAM(BOOTSTRAP_VLOG_STREAM(verbose_level, bootstrap_err), \
140 VLOG_IS_ON(verbose_level) && (condition))
142 #define BOOTSTRAP_CHECK(condition, bootstrap_err) \
143 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(FATAL, bootstrap_err), !(condition)) \
144 << "Check failed: " # condition << ". "
146 #define BOOTSTRAP_DLOG(severity, bootstrap_err) \
147 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(severity, bootstrap_err), \
148 DLOG_IS_ON(severity))
149 #define BOOTSTRAP_DLOG_IF(severity, condition, bootstrap_err) \
150 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(severity, bootstrap_err), \
151 DLOG_IS_ON(severity) && (condition))
153 #define BOOTSTRAP_DVLOG(verbose_level, bootstrap_err) \
154 LAZY_STREAM(BOOTSTRAP_VLOG_STREAM(verbose_level, bootstrap_err), \
155 BOOTSTRAP_DVLOG_IS_ON(verbose_level))
156 #define BOOTSTRAP_DVLOG_IF(verbose_level, condition, bootstrap_err) \
157 LAZY_STREAM(BOOTSTRAP_VLOG_STREAM(verbose_level, bootstrap_err), \
158 BOOTSTRAP_DVLOG_IS_ON(verbose_level) && (condition))
160 #define BOOTSTRAP_DCHECK(condition, bootstrap_err) \
161 LAZY_STREAM(BOOTSTRAP_LOG_STREAM(FATAL, bootstrap_err), \
162 DCHECK_IS_ON() && !(condition)) \
163 << "Check failed: " #condition << ". "
165 #endif // !OS_IOS
167 #endif // BASE_MAC_MACH_LOGGING_H_