]>
git.saurik.com Git - apple/dyld.git/blob - dyld3/Diagnostics.h
2 * Copyright (c) 2017 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
30 #if BUILDING_CACHE_BUILDER
34 #include <dispatch/dispatch.h>
40 class VIS_HIDDEN Diagnostics
43 Diagnostics(bool verbose
=false);
46 void error(const char* format
, ...) __attribute__((format(printf
, 2, 3)));
47 void error(const char* format
, va_list list
);
48 #if BUILDING_CACHE_BUILDER
49 Diagnostics(const std::string
& prefix
, bool verbose
=false);
51 void warning(const char* format
, ...) __attribute__((format(printf
, 2, 3)));
52 void verbose(const char* format
, ...) __attribute__((format(printf
, 2, 3)));
53 void copy(const Diagnostics
&);
56 bool hasError() const;
59 void assertNoError() const;
60 bool errorMessageContains(const char* subString
) const;
62 #if !BUILDING_CACHE_BUILDER
63 const char* errorMessage() const;
65 const std::string
prefix() const;
66 std::string
errorMessage() const;
67 const std::set
<std::string
> warnings() const;
73 void* _buffer
= nullptr;
74 #if BUILDING_CACHE_BUILDER
76 std::set
<std::string
> _warnings
;
77 bool _verbose
= false;
81 #if BUILDING_CACHE_BUILDER
83 class VIS_HIDDEN TimeRecorder
86 // Call pushTimedSection(), then mark events with recordTime. Call popTimedSection() to stop the current timing session.
87 // This is stack-based, so you can start a sub-timer with pushTimedSection() / recordTime / recordTime... / popTimedSection()
88 // inside a first timed section.
89 // Call logTimings() to print everything.
91 // Start a new timed section.
92 void pushTimedSection();
94 // Records the time taken since the last pushTimedSection() / recordTime() at the current level
95 void recordTime(const char* format
, ...);
97 // Stop the current timed section and pop back one level.
98 void popTimedSection();
104 std::string logMessage
;
108 std::vector
<uint64_t> openTimings
;
109 std::vector
<TimingEntry
> timings
;
112 #endif /* BUILDING_CACHE_BUILDER */
114 #endif // Diagnostics_h