annotate define.h @ 10:a818f3c2e589

fix tree walk, we now use the item counts in the node blocks
author carl
date Fri, 17 Feb 2006 15:48:38 -0800
parents 3e3d8b576630
children 3f627519a92d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
6b1b602514db Initial revision
carl
parents:
diff changeset
1 /***
6b1b602514db Initial revision
carl
parents:
diff changeset
2 * define.h
6b1b602514db Initial revision
carl
parents:
diff changeset
3 * Part of the LibPST project
6b1b602514db Initial revision
carl
parents:
diff changeset
4 * Written by David Smith
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
5 * dave.s@earthcorp.com
0
6b1b602514db Initial revision
carl
parents:
diff changeset
6 */
6b1b602514db Initial revision
carl
parents:
diff changeset
7
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
8 #define DEBUG_ALL
0
6b1b602514db Initial revision
carl
parents:
diff changeset
9 #ifndef DEFINEH_H
6b1b602514db Initial revision
carl
parents:
diff changeset
10 #define DEFINEH_H
6b1b602514db Initial revision
carl
parents:
diff changeset
11
6b1b602514db Initial revision
carl
parents:
diff changeset
12 #ifdef DEBUG_ALL
6b1b602514db Initial revision
carl
parents:
diff changeset
13 #define DEBUG_MODE_GEN
6b1b602514db Initial revision
carl
parents:
diff changeset
14 #define DEBUGPRINT
6b1b602514db Initial revision
carl
parents:
diff changeset
15 #define DEBUG_MODE_WARN
6b1b602514db Initial revision
carl
parents:
diff changeset
16 #define DEBUG_MODE_READ
6b1b602514db Initial revision
carl
parents:
diff changeset
17 #define DEBUG_MODE_EMAIL
6b1b602514db Initial revision
carl
parents:
diff changeset
18 #define DEBUG_MODE_MAIN
6b1b602514db Initial revision
carl
parents:
diff changeset
19 #define DEBUG_MODE_INDEX
6b1b602514db Initial revision
carl
parents:
diff changeset
20 #define DEBUG_MODE_CODE
6b1b602514db Initial revision
carl
parents:
diff changeset
21 #define DEBUG_MODE_INFO
6b1b602514db Initial revision
carl
parents:
diff changeset
22 #define DEBUG_MODE_HEXDUMP
6b1b602514db Initial revision
carl
parents:
diff changeset
23 #define DEBUG_MODE_FUNC
6b1b602514db Initial revision
carl
parents:
diff changeset
24 //#define DEBUG_MODE_DECRYPT
6b1b602514db Initial revision
carl
parents:
diff changeset
25 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
26
6b1b602514db Initial revision
carl
parents:
diff changeset
27 //number of items to save in memory between writes
6b1b602514db Initial revision
carl
parents:
diff changeset
28 #define DEBUG_MAX_ITEMS 0
6b1b602514db Initial revision
carl
parents:
diff changeset
29
6b1b602514db Initial revision
carl
parents:
diff changeset
30 #define DEBUG_FILE_NO 1
6b1b602514db Initial revision
carl
parents:
diff changeset
31 #define DEBUG_INDEX_NO 2
6b1b602514db Initial revision
carl
parents:
diff changeset
32 #define DEBUG_EMAIL_NO 3
6b1b602514db Initial revision
carl
parents:
diff changeset
33 #define DEBUG_WARN_NO 4
6b1b602514db Initial revision
carl
parents:
diff changeset
34 #define DEBUG_READ_NO 5
6b1b602514db Initial revision
carl
parents:
diff changeset
35 #define DEBUG_INFO_NO 6
6b1b602514db Initial revision
carl
parents:
diff changeset
36 #define DEBUG_MAIN_NO 7
6b1b602514db Initial revision
carl
parents:
diff changeset
37 #define DEBUG_DECRYPT_NO 8
6b1b602514db Initial revision
carl
parents:
diff changeset
38 #define DEBUG_FUNC_NO 10
6b1b602514db Initial revision
carl
parents:
diff changeset
39 #define DEBUG_HEXDUMP_NO 11
6b1b602514db Initial revision
carl
parents:
diff changeset
40
7
3e3d8b576630 changes to look for duplicates
carl
parents: 0
diff changeset
41 //variable number of arguments to this macro. will expand them into
0
6b1b602514db Initial revision
carl
parents:
diff changeset
42 // ## args, then exit with status of 1
6b1b602514db Initial revision
carl
parents:
diff changeset
43 #include <stdio.h>
6b1b602514db Initial revision
carl
parents:
diff changeset
44 #include <stdlib.h>
6b1b602514db Initial revision
carl
parents:
diff changeset
45 #include <stdarg.h>
6b1b602514db Initial revision
carl
parents:
diff changeset
46
6b1b602514db Initial revision
carl
parents:
diff changeset
47 #ifdef __LINUX__
6b1b602514db Initial revision
carl
parents:
diff changeset
48 #include <netinet/in.h>
6b1b602514db Initial revision
carl
parents:
diff changeset
49 #include <unistd.h>
6b1b602514db Initial revision
carl
parents:
diff changeset
50 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
51
6b1b602514db Initial revision
carl
parents:
diff changeset
52
6b1b602514db Initial revision
carl
parents:
diff changeset
53 void _pst_debug(char *fmt, ...);
6b1b602514db Initial revision
carl
parents:
diff changeset
54 void _pst_debug_hexdump(FILE* out, unsigned char* buf, size_t size, int col);
6b1b602514db Initial revision
carl
parents:
diff changeset
55 void _pst_debug_hexprint(char *data, int size);
6b1b602514db Initial revision
carl
parents:
diff changeset
56
6b1b602514db Initial revision
carl
parents:
diff changeset
57 void _debug_init(char *fname);
6b1b602514db Initial revision
carl
parents:
diff changeset
58 void _debug_msg_info (int line, char *file, int type);
6b1b602514db Initial revision
carl
parents:
diff changeset
59 void _debug_msg_text(char* fmt, ...);
6b1b602514db Initial revision
carl
parents:
diff changeset
60 void _debug_hexdump(char *x, int y, int cols);
6b1b602514db Initial revision
carl
parents:
diff changeset
61 void _debug_func(char *function);
6b1b602514db Initial revision
carl
parents:
diff changeset
62 void _debug_func_ret();
6b1b602514db Initial revision
carl
parents:
diff changeset
63 void _debug_close(void);
6b1b602514db Initial revision
carl
parents:
diff changeset
64 void _debug_write();
6b1b602514db Initial revision
carl
parents:
diff changeset
65
6b1b602514db Initial revision
carl
parents:
diff changeset
66 void * xmalloc(size_t size);
6b1b602514db Initial revision
carl
parents:
diff changeset
67
6b1b602514db Initial revision
carl
parents:
diff changeset
68 #define MESSAGEPRINT(x,y) {_debug_msg_info(__LINE__,__FILE__,y);\
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
69 _debug_msg_text x;}
0
6b1b602514db Initial revision
carl
parents:
diff changeset
70
6b1b602514db Initial revision
carl
parents:
diff changeset
71 #define LOGSTOP() {MESSAGESTOP();DEBUGSTOP();}
6b1b602514db Initial revision
carl
parents:
diff changeset
72
6b1b602514db Initial revision
carl
parents:
diff changeset
73 #define DIE(x) {\
6b1b602514db Initial revision
carl
parents:
diff changeset
74 MESSAGEPRINT(x, 0);\
6b1b602514db Initial revision
carl
parents:
diff changeset
75 printf x;\
6b1b602514db Initial revision
carl
parents:
diff changeset
76 exit(EXIT_FAILURE);\
6b1b602514db Initial revision
carl
parents:
diff changeset
77 }
6b1b602514db Initial revision
carl
parents:
diff changeset
78 #define WARN(x) {\
6b1b602514db Initial revision
carl
parents:
diff changeset
79 MESSAGEPRINT(x, 0);\
6b1b602514db Initial revision
carl
parents:
diff changeset
80 printf x;\
6b1b602514db Initial revision
carl
parents:
diff changeset
81 }
6b1b602514db Initial revision
carl
parents:
diff changeset
82
6b1b602514db Initial revision
carl
parents:
diff changeset
83 #ifdef DEBUGPRINT
6b1b602514db Initial revision
carl
parents:
diff changeset
84 #define DEBUG_PRINT(x) _pst_debug x;
6b1b602514db Initial revision
carl
parents:
diff changeset
85 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
86 #define DEBUG_PRINT(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
87 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
88
6b1b602514db Initial revision
carl
parents:
diff changeset
89 #ifdef DEBUG_MODE_GEN
6b1b602514db Initial revision
carl
parents:
diff changeset
90 #define DEBUG(x) {DEBUG_PRINT(x);}
6b1b602514db Initial revision
carl
parents:
diff changeset
91 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
92 #define DEBUG(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
93 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
94
6b1b602514db Initial revision
carl
parents:
diff changeset
95 #ifdef DEBUG_MODE_INDEX
6b1b602514db Initial revision
carl
parents:
diff changeset
96 #define DEBUG_INDEX(x) MESSAGEPRINT(x, DEBUG_INDEX_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
97 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
98 #define DEBUG_INDEX(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
99 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
100
6b1b602514db Initial revision
carl
parents:
diff changeset
101 #ifdef DEBUG_MODE_EMAIL
6b1b602514db Initial revision
carl
parents:
diff changeset
102 #define DEBUG_EMAIL(x) MESSAGEPRINT(x, DEBUG_EMAIL_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
103 #define DEBUG_EMAIL_HEXPRINT(x,y) {_debug_msg_info(__LINE__, __FILE__, 11);\
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
104 _debug_hexdump(x, y, 0x10);}
0
6b1b602514db Initial revision
carl
parents:
diff changeset
105 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
106 #define DEBUG_EMAIL(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
107 #define DEBUG_EMAIL_HEXPRINT(x,y) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
108 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
109
6b1b602514db Initial revision
carl
parents:
diff changeset
110 #ifdef DEBUG_MODE_WARN
6b1b602514db Initial revision
carl
parents:
diff changeset
111 #define DEBUG_WARN(x) MESSAGEPRINT(x, DEBUG_WARN_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
112 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
113 #define DEBUG_WARN(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
114 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
115
6b1b602514db Initial revision
carl
parents:
diff changeset
116 #ifdef DEBUG_MODE_READ
6b1b602514db Initial revision
carl
parents:
diff changeset
117 #define DEBUG_READ(x) MESSAGEPRINT(x, DEBUG_READ_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
118 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
119 #define DEBUG_READ(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
120 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
121
6b1b602514db Initial revision
carl
parents:
diff changeset
122 #ifdef DEBUG_MODE_INFO
6b1b602514db Initial revision
carl
parents:
diff changeset
123 #define DEBUG_INFO(x) MESSAGEPRINT(x, DEBUG_INFO_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
124 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
125 #define DEBUG_INFO(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
126 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
127
6b1b602514db Initial revision
carl
parents:
diff changeset
128 #ifdef DEBUG_MODE_MAIN
6b1b602514db Initial revision
carl
parents:
diff changeset
129 #define DEBUG_MAIN(x) MESSAGEPRINT(x, DEBUG_MAIN_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
130 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
131 #define DEBUG_MAIN(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
132 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
133
6b1b602514db Initial revision
carl
parents:
diff changeset
134 #ifdef DEBUG_MODE_CODE
6b1b602514db Initial revision
carl
parents:
diff changeset
135 #define DEBUG_CODE(x) {x}
6b1b602514db Initial revision
carl
parents:
diff changeset
136 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
137 #define DEBUG_CODE(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
138 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
139
6b1b602514db Initial revision
carl
parents:
diff changeset
140 #ifdef DEBUG_MODE_DECRYPT
6b1b602514db Initial revision
carl
parents:
diff changeset
141 #define DEBUG_DECRYPT(x) MESSAGEPRINT(x, DEBUG_DECRYPT_NO);
6b1b602514db Initial revision
carl
parents:
diff changeset
142 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
143 #define DEBUG_DECRYPT(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
144 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
145
6b1b602514db Initial revision
carl
parents:
diff changeset
146 #ifdef DEBUG_MODE_HEXDUMP
6b1b602514db Initial revision
carl
parents:
diff changeset
147 #define DEBUG_HEXDUMP(x, s)\
6b1b602514db Initial revision
carl
parents:
diff changeset
148 {_debug_msg_info(__LINE__, __FILE__, DEBUG_HEXDUMP_NO);\
6b1b602514db Initial revision
carl
parents:
diff changeset
149 _debug_hexdump(x, s, 0x10);}
6b1b602514db Initial revision
carl
parents:
diff changeset
150 #define DEBUG_HEXDUMPC(x, s, c)\
6b1b602514db Initial revision
carl
parents:
diff changeset
151 {_debug_msg_info(__LINE__, __FILE__, DEBUG_HEXDUMP_NO);\
6b1b602514db Initial revision
carl
parents:
diff changeset
152 _debug_hexdump(x, s, c);}
6b1b602514db Initial revision
carl
parents:
diff changeset
153 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
154 #define DEBUG_HEXDUMP(x, s) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
155 #define DEBUG_HEXDUMPC(x, s, c) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
156 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
157
6b1b602514db Initial revision
carl
parents:
diff changeset
158 #define DEBUG_FILE(x) {_debug_msg_info(__LINE__, __FILE__, DEBUG_FILE_NO);\
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
159 _debug_msg_text x;}
0
6b1b602514db Initial revision
carl
parents:
diff changeset
160
6b1b602514db Initial revision
carl
parents:
diff changeset
161 #ifdef DEBUG_MODE_FUNC
6b1b602514db Initial revision
carl
parents:
diff changeset
162 # define DEBUG_ENT(x) \
6b1b602514db Initial revision
carl
parents:
diff changeset
163 {MESSAGEPRINT(("Entering function %s\n",x),DEBUG_FUNC_NO);\
6b1b602514db Initial revision
carl
parents:
diff changeset
164 _debug_func(x);}
6b1b602514db Initial revision
carl
parents:
diff changeset
165 # define DEBUG_RET() {MESSAGEPRINT(("Leaving function\n"),DEBUG_FUNC_NO);\
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
166 _debug_func_ret();}
0
6b1b602514db Initial revision
carl
parents:
diff changeset
167 #else
6b1b602514db Initial revision
carl
parents:
diff changeset
168 # define DEBUG_ENT(x) {}
6b1b602514db Initial revision
carl
parents:
diff changeset
169 # define DEBUG_RET() {}
6b1b602514db Initial revision
carl
parents:
diff changeset
170 #endif
6b1b602514db Initial revision
carl
parents:
diff changeset
171
6b1b602514db Initial revision
carl
parents:
diff changeset
172 #define DEBUG_INIT(fname) {_debug_init(fname);}
6b1b602514db Initial revision
carl
parents:
diff changeset
173 #define DEBUG_CLOSE() {_debug_close();}
6b1b602514db Initial revision
carl
parents:
diff changeset
174 #define DEBUG_REGISTER_CLOSE() {if(atexit(_debug_close)!=0) fprintf(stderr, "Error registering atexit function\n");}
6b1b602514db Initial revision
carl
parents:
diff changeset
175
6b1b602514db Initial revision
carl
parents:
diff changeset
176 #define RET_DERROR(res, ret_val, x)\
6b1b602514db Initial revision
carl
parents:
diff changeset
177 if (res) { DIE(x);}
6b1b602514db Initial revision
carl
parents:
diff changeset
178
6b1b602514db Initial revision
carl
parents:
diff changeset
179 #define RET_ERROR(res, ret_val)\
10
a818f3c2e589 fix tree walk, we now use the item counts in the node blocks
carl
parents: 7
diff changeset
180 if (res) {return ret_val;}
0
6b1b602514db Initial revision
carl
parents:
diff changeset
181
6b1b602514db Initial revision
carl
parents:
diff changeset
182 #define DEBUG_VERSION 1
6b1b602514db Initial revision
carl
parents:
diff changeset
183 struct _debug_file_rec_m {
6b1b602514db Initial revision
carl
parents:
diff changeset
184 unsigned short int funcname;
6b1b602514db Initial revision
carl
parents:
diff changeset
185 unsigned short int filename;
6b1b602514db Initial revision
carl
parents:
diff changeset
186 unsigned short int text;
6b1b602514db Initial revision
carl
parents:
diff changeset
187 unsigned short int end;
6b1b602514db Initial revision
carl
parents:
diff changeset
188 unsigned int line;
6b1b602514db Initial revision
carl
parents:
diff changeset
189 unsigned int type;
6b1b602514db Initial revision
carl
parents:
diff changeset
190 };
6b1b602514db Initial revision
carl
parents:
diff changeset
191
6b1b602514db Initial revision
carl
parents:
diff changeset
192 struct _debug_file_rec_l {
6b1b602514db Initial revision
carl
parents:
diff changeset
193 unsigned int funcname;
6b1b602514db Initial revision
carl
parents:
diff changeset
194 unsigned int filename;
6b1b602514db Initial revision
carl
parents:
diff changeset
195 unsigned int text;
6b1b602514db Initial revision
carl
parents:
diff changeset
196 unsigned int end;
6b1b602514db Initial revision
carl
parents:
diff changeset
197 unsigned int line;
6b1b602514db Initial revision
carl
parents:
diff changeset
198 unsigned int type;
6b1b602514db Initial revision
carl
parents:
diff changeset
199 };
6b1b602514db Initial revision
carl
parents:
diff changeset
200
6b1b602514db Initial revision
carl
parents:
diff changeset
201 #endif //DEFINEH_H