]> git.saurik.com Git - apple/security.git/blob - AppleX509CL/cldebugging.h
8ac7add84bb2d13440e3c3c9ba48c305b20efb82
[apple/security.git] / AppleX509CL / cldebugging.h
1 /*
2 * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
3 *
4 * The contents of this file constitute Original Code as defined in and are
5 * subject to the Apple Public Source License Version 1.2 (the 'License').
6 * You may not use this file except in compliance with the License. Please obtain
7 * a copy of the License at http://www.apple.com/publicsource and read it before
8 * using this file.
9 *
10 * This Original Code and all software distributed under the License are
11 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
12 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
13 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
15 * specific language governing rights and limitations under the License.
16 */
17
18
19 /*
20 File: cldebugging.h
21
22 Contains: Debugging macros.
23
24 Written by: Doug Mitchell
25
26 Copyright: (c) 1998 by Apple Computer, Inc., all rights reserved.
27
28 Change History (most recent first):
29
30 06/02/98 dpm Added DEBUG_THREAD_YIELD.
31 03/10/98 dpm Created.
32
33 */
34
35 #ifndef _CLDEBUGGING_H_
36 #define _CLDEBUGGING_H_
37
38 #ifdef NDEBUG
39 #define DEBUG_ENABLE 0
40 #define ERROR_LOG_ENABLE 0
41 #else
42 #define DEBUG_ENABLE 1
43 #define ERROR_LOG_ENABLE 1
44 #endif
45
46 /* any other way? */
47 #define LOG_VIA_PRINTF 1
48
49 #if DEBUG_ENABLE || ERROR_LOG_ENABLE
50
51 #include <stdio.h>
52 #include <stdlib.h>
53
54 #if !LOG_VIA_PRINTF
55
56 #error Hey, figure out a debug mechanism
57
58 #include <string.h>
59 #include <CarbonCore/MacTypes.h>
60 #include <TextUtils.h>
61
62 /* common log macros */
63
64 /* remaining ones can take constant strings */
65
66 #ifdef __cplusplus
67 extern "C" {
68 #endif
69
70 extern void dblog0(char *str);
71 extern void dblog1(char *str, void * arg1);
72 extern void dblog2(char *str, void * arg1, void * arg2);
73 extern void dblog3(char *str, void * arg1, void * arg2, void * arg3);
74 extern void dblog4(char *str, void * arg1, void * arg2, void * arg3, void * arg4);
75
76 #ifdef __cplusplus
77 }
78 #endif
79
80
81 #else /* LOG_VIA_PRINTF */
82
83 #define dblog0(str) printf(str)
84 #define dblog1(str, arg1) printf(str, arg1)
85 #define dblog2(str, arg1, arg2) printf(str, arg1, arg2)
86 #define dblog3(str, arg1, arg2, arg3) printf(str, arg1, arg2, arg3)
87 #define dblog4(str, arg1, arg2, arg3, arg4) printf(str, arg1, arg2, arg3, arg4)
88
89 #endif /* LOG_VIA_PRINTF */
90
91 #else /* log macros disabled */
92
93 #define dblog0(str)
94 #define dblog1(str, arg1)
95 #define dblog2(str, arg1, arg2)
96 #define dblog3(str, arg1, arg2, arg3)
97 #define dblog4(str, arg1, arg2, arg3, arg4)
98
99 #endif /* DEBUG_ENABLE || ERROR_LOG_ENABLE */
100
101 #if DEBUG_ENABLE
102
103 #define dprintf0(str) dblog0(str)
104 #define dprintf1(str, arg1) dblog1(str, arg1)
105 #define dprintf2(str, arg1, arg2) dblog2(str, arg1, arg2)
106 #define dprintf3(str, arg1, arg2, arg3) dblog3(str, arg1, arg2, arg3)
107 #define dprintf4(str, arg1, arg2, arg3, arg4) dblog4(str, arg1, arg2, arg3, arg4)
108
109 #ifdef __cplusplus
110 extern "C" {
111 #endif
112
113 extern volatile void _panic(const char *str);
114
115 #ifdef __cplusplus
116 }
117 #endif
118
119 #define CASSERT(expression) \
120 ((expression) ? (void)0 : \
121 (dprintf1 ("Assertion failed: " #expression \
122 ", file " __FILE__ ", line %d.\n", __LINE__), \
123 _panic("Assertion Failure")))
124
125 #else /* DEBUG_ENABLE */
126
127 #define dprintf0(str)
128 #define dprintf1(str, arg1)
129 #define dprintf2(str, arg1, arg2)
130 #define dprintf3(str, arg1, arg2, arg3)
131 #define dprintf4(str, arg1, arg2, arg3, arg4)
132
133 #define CASSERT(expression)
134
135 #endif /* DEBUG_ENABLE */
136
137 /*
138 * Error logging. This may well be platform dependent.
139 */
140 #if ERROR_LOG_ENABLE
141 #define errorLog0(str) dblog0(str)
142 #define errorLog1(str, arg1) dblog1(str, arg1)
143 #define errorLog2(str, arg1, arg2) dblog2(str, arg1, arg2)
144 #define errorLog3(str, arg1, arg2, arg3) dblog3(str, arg1, arg2, arg3)
145 #define errorLog4(str, arg1, arg2, arg3, arg4) dblog4(str, arg1, arg2, arg3, arg4)
146
147 #else /* ERROR_LOG_ENABLE */
148
149 #define errorLog0(str)
150 #define errorLog1(str, arg1)
151 #define errorLog2(str, arg1, arg2)
152 #define errorLog3(str, arg1, arg2, arg3)
153 #define errorLog4(str, arg1, arg2, arg3, arg4)
154
155 #endif /* ERROR_LOG_ENABLE */
156
157 #endif /* _CLDEBUGGING_H_ */