annotate src/define.h @ 36:6fe121a971c9 stable-0-5-7

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