]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/baconfig.h
Misc
[bacula/bacula] / bacula / src / baconfig.h
1 /*
2  * General header file configurations that apply to
3  * all daemons.  System dependent stuff goes here.
4  *
5  *   Version $Id$
6  */
7 /*
8    Copyright (C) 2000-2004 Kern Sibbald and John Walker
9
10    This program is free software; you can redistribute it and/or
11    modify it under the terms of the GNU General Public License as
12    published by the Free Software Foundation; either version 2 of
13    the License, or (at your option) any later version.
14
15    This program is distributed in the hope that it will be useful,
16    but WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18    General Public License for more details.
19
20    You should have received a copy of the GNU General Public
21    License along with this program; if not, write to the Free
22    Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
23    MA 02111-1307, USA.
24
25  */
26
27
28 #ifndef _BACONFIG_H
29 #define _BACONFIG_H 1
30
31 /* Bacula common configuration defines */
32
33 #undef  TRUE
34 #undef  FALSE
35 #define TRUE  1
36 #define FALSE 0
37
38 #ifndef ETIME
39 #define ETIME ETIMEDOUT
40 #endif
41
42 #ifdef PROTOTYPES
43 # define __PROTO(p)     p
44 #else
45 # define __PROTO(p)     ()
46 #endif
47
48 #ifdef DEBUG
49 #define ASSERT(x) if (!(x)) { \
50    char *jcr = NULL; \
51    Emsg1(M_ERROR, 0, "Failed ASSERT: %s\n", #x); \
52    jcr[0] = 0; }
53 #else
54 #define ASSERT(x)
55 #endif
56
57 /* Allow printing of NULL pointers */
58 #define NPRT(x) (x)?(x):"*None*" 
59
60 #ifdef ENABLE_NLS
61 #include <libintl.h>
62 #define _(s) gettext((s))
63 #define N_(s) (s)
64 #else
65 #undef _
66 #define _(s) (s)
67 #undef N_
68 #define N_(s) (s)
69 #undef textdomain
70 #define textdomain(d)
71 /* #define bindtextdomain(p, d) */
72 #endif
73
74
75 /* This should go away! ****FIXME***** */
76 #define MAXSTRING 500
77
78 /* Maximum length to edit time/date */
79 #define MAX_TIME_LENGTH 50  
80
81 /* Maximum Name length including EOS */
82 #define MAX_NAME_LENGTH 128
83
84 /* Maximume number of user entered command args */
85 #define MAX_CMD_ARGS 30
86
87 /* All tape operations MUST be a multiple of this */
88 #define TAPE_BSIZE 1024
89 #if !defined(DEV_BSIZE) && defined(BSIZE)
90 #define DEV_BSIZE BSIZE
91 #endif
92
93 #ifndef DEV_BSIZE
94 #define DEV_BSIZE 512
95 #endif
96
97 /*
98  * Default network buffer size
99  */
100 #define DEFAULT_NETWORK_BUFFER_SIZE (32 * 1024)
101
102 /*
103  * Stream definitions.  Once defined these must NEVER
104  *   change as they go on the storage media.
105  * Note, the following streams are passed from the SD to the DIR
106  *   so that they may be put into the catalog (actually only the
107  *   stat packet part of the attr record is put in the catalog.
108  *
109  *   STREAM_UNIX_ATTRIBUTES
110  *   STREAM_UNIX_ATTRIBUTES_EX
111  *   STREAM_MD5_SIGNATURE
112  *   STREAM_SHA1_SIGNATURE
113  */
114 #define STREAM_UNIX_ATTRIBUTES    1    /* Generic Unix attributes */
115 #define STREAM_FILE_DATA          2    /* Standard uncompressed data */
116 #define STREAM_MD5_SIGNATURE      3    /* MD5 signature for the file */
117 #define STREAM_GZIP_DATA          4    /* GZip compressed file data */
118 /* Extended Unix attributes with Win32 Extended data.  Deprecated. */
119 #define STREAM_UNIX_ATTRIBUTES_EX 5    /* Extended Unix attr for Win32 EX */
120 #define STREAM_SPARSE_DATA        6    /* Sparse data stream */
121 #define STREAM_SPARSE_GZIP_DATA   7
122 #define STREAM_PROGRAM_NAMES      8    /* program names for program data */
123 #define STREAM_PROGRAM_DATA       9    /* Data needing program */
124 #define STREAM_SHA1_SIGNATURE    10    /* SHA1 signature for the file */
125 #define STREAM_WIN32_DATA        11    /* Win32 BackupRead data */
126 #define STREAM_WIN32_GZIP_DATA   12    /* Gzipped Win32 BackupRead data */
127 #define STREAM_MACOS_FORK_DATA   13    /* Mac resource fork */
128 #define STREAM_HFSPLUS_ATTRIBUTES 14   /* Mac OS extra attributes */
129
130 /* 
131  *  File type (Bacula defined).           
132  *  NOTE!!! These are saved in the Attributes record on the tape, so
133  *          do not change them. If need be, add to them.
134  *
135  *  This is stored as 32 bits on tape, but only FT_MASK bits are
136  *    used for the file type. The upper bits are used to indicate
137  *    additional optional fields in the attribute record.
138  */
139 #define FT_MASK       0xFFFF          /* Bits used by FT (type) */
140 #define FT_LNKSAVED   1               /* hard link to file already saved */  
141 #define FT_REGE       2               /* Regular file but empty */
142 #define FT_REG        3               /* Regular file */
143 #define FT_LNK        4               /* Soft Link */
144 #define FT_DIR        5               /* Directory */
145 #define FT_SPEC       6               /* Special file -- chr, blk, fifo, sock */
146 #define FT_NOACCESS   7               /* Not able to access */
147 #define FT_NOFOLLOW   8               /* Could not follow link */
148 #define FT_NOSTAT     9               /* Could not stat file */
149 #define FT_NOCHG     10               /* Incremental option, file not changed */
150 #define FT_DIRNOCHG  11               /* Incremental option, directory not changed */
151 #define FT_ISARCH    12               /* Trying to save archive file */
152 #define FT_NORECURSE 13               /* No recursion into directory */
153 #define FT_NOFSCHG   14               /* Different file system, prohibited */
154 #define FT_NOOPEN    15               /* Could not open directory */
155 #define FT_RAW       16               /* Raw block device */
156 #define FT_FIFO      17               /* Raw fifo device */
157
158 /* Definitions for upper part of type word (see above). */
159 #define AR_DATA_STREAM (1<<16)        /* Data stream id present */
160
161 /*
162  * Internal code for Signature types
163  */
164 #define NO_SIG   0
165 #define MD5_SIG  1
166 #define SHA1_SIG 2
167
168 /* Size of File Address stored in STREAM_SPARSE_DATA. Do NOT change! */
169 #define SPARSE_FADDR_SIZE (sizeof(uint64_t))
170
171
172 /* This is for dumb compilers/libraries like Solaris. Linux GCC
173  * does it correctly, so it might be worthwhile
174  * to remove the isascii(c) with ifdefs on such
175  * "smart" systems.
176  */
177 #define B_ISSPACE(c) (isascii((int)(c)) && isspace((int)(c)))
178 #define B_ISALPHA(c) (isascii((int)(c)) && isalpha((int)(c)))
179 #define B_ISUPPER(c) (isascii((int)(c)) && isupper((int)(c)))
180 #define B_ISDIGIT(c) (isascii((int)(c)) && isdigit((int)(c)))
181
182
183 typedef void (HANDLER)();
184 typedef int (INTHANDLER)();
185
186 #ifdef SETPGRP_VOID
187 # define SETPGRP_ARGS(x, y) /* No arguments */
188 #else
189 # define SETPGRP_ARGS(x, y) (x, y)
190 #endif
191
192 #ifndef S_ISLNK
193 #define S_ISLNK(m) (((m) & S_IFM) == S_IFLNK)
194 #endif
195
196 /* Added by KES to deal with Win32 systems */
197 #ifndef S_ISWIN32
198 #define S_ISWIN32 020000
199 #endif
200
201 #ifndef INADDR_NONE
202 #define INADDR_NONE ((unsigned long) -1)
203 #endif
204
205 #ifdef TIME_WITH_SYS_TIME
206 # include <sys/time.h>
207 # include <time.h>
208 #else
209 # ifdef HAVE_SYS_TIME_H
210 #  include <sys/time.h>
211 # else
212 #  include <time.h>
213 # endif
214 #endif
215
216 #ifndef O_BINARY
217 #define O_BINARY 0
218 #endif
219
220 #ifndef O_NOFOLLOW
221 #define O_NOFOLLOW 0
222 #endif
223
224 #ifndef MODE_RW
225 #define MODE_RW 0666
226 #endif
227
228 #ifdef DEBUG_MUTEX
229 extern void _p(char *file, int line, pthread_mutex_t *m);
230 extern void _v(char *file, int line, pthread_mutex_t *m);
231
232 #define P(x) _p(__FILE__, __LINE__, &(x))
233 #define V(x) _v(__FILE__, __LINE__, &(x))
234
235 #else
236
237 /* These probably should be subroutines */
238 #define P(x) \
239    do { int errstat; if ((errstat=pthread_mutex_lock(&(x)))) \
240       e_msg(__FILE__, __LINE__, M_ABORT, 0, "Mutex lock failure. ERR=%s\n",\
241            strerror(errstat)); \
242    } while(0)
243
244 #define V(x) \
245    do { int errstat; if ((errstat=pthread_mutex_unlock(&(x)))) \
246          e_msg(__FILE__, __LINE__, M_ABORT, 0, "Mutex unlock failure. ERR=%s\n",\
247            strerror(errstat)); \
248    } while(0)
249
250 #endif /* DEBUG_MUTEX */
251
252 /* These probably should be subroutines */
253 #define Pw(x) \
254    do { int errstat; if ((errstat=rwl_writelock(&(x)))) \
255       e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock lock failure. ERR=%s\n",\
256            strerror(errstat)); \
257    } while(0)
258
259 #define Vw(x) \
260    do { int errstat; if ((errstat=rwl_writeunlock(&(x)))) \
261          e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock unlock failure. ERR=%s\n",\
262            strerror(errstat)); \
263    } while(0)
264
265 #define LockRes()   b_LockRes(__FILE__, __LINE__)
266 #define UnlockRes() b_UnlockRes(__FILE__, __LINE__)
267
268
269 /*
270  * The digit following Dmsg and Emsg indicates the number of substitutions in
271  * the message string. We need to do this kludge because non-GNU compilers
272  * do not handle varargs #defines.
273  */
274 /* Debug Messages that are printed */
275 #ifdef DEBUG
276 #define Dmsg0(lvl, msg)             d_msg(__FILE__, __LINE__, lvl, msg)
277 #define Dmsg1(lvl, msg, a1)         d_msg(__FILE__, __LINE__, lvl, msg, a1)
278 #define Dmsg2(lvl, msg, a1, a2)     d_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
279 #define Dmsg3(lvl, msg, a1, a2, a3) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
280 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4) d_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
281 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
282 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
283 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
284 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
285 #define Dmsg9(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9)
286 #define Dmsg10(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10)
287 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
288 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
289 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
290 #else
291 #define Dmsg0(lvl, msg)
292 #define Dmsg1(lvl, msg, a1)
293 #define Dmsg2(lvl, msg, a1, a2)
294 #define Dmsg3(lvl, msg, a1, a2, a3)
295 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4)
296 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5)
297 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
298 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
299 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
300 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
301 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
302 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
303 #endif /* DEBUG */
304
305 #ifdef TRACE_FILE
306 #define Tmsg0(lvl, msg)             t_msg(__FILE__, __LINE__, lvl, msg)
307 #define Tmsg1(lvl, msg, a1)         t_msg(__FILE__, __LINE__, lvl, msg, a1)
308 #define Tmsg2(lvl, msg, a1, a2)     t_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
309 #define Tmsg3(lvl, msg, a1, a2, a3) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
310 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4) t_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
311 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
312 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
313 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
314 #define Tmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
315 #define Tmsg9(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9) t_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9)
316 #define Tmsg10(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10) t_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10)
317 #define Tmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11) t_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
318 #define Tmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12) t_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
319 #define Tmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13) t_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
320 #else
321 #define Tmsg0(lvl, msg)
322 #define Tmsg1(lvl, msg, a1)
323 #define Tmsg2(lvl, msg, a1, a2)
324 #define Tmsg3(lvl, msg, a1, a2, a3)
325 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4)
326 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5)
327 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
328 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
329 #define Tmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
330 #define Tmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
331 #define Tmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
332 #define Tmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
333 #endif /* TRACE_FILE */
334
335
336
337 /* Messages that are printed (uses d_msg) */
338 #define Pmsg0(lvl, msg)             p_msg(__FILE__, __LINE__, lvl, msg)
339 #define Pmsg1(lvl, msg, a1)         p_msg(__FILE__, __LINE__, lvl, msg, a1)
340 #define Pmsg2(lvl, msg, a1, a2)     p_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
341 #define Pmsg3(lvl, msg, a1, a2, a3) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
342 #define Pmsg4(lvl, msg, arg1, arg2, arg3, arg4) p_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
343 #define Pmsg5(lvl, msg, a1, a2, a3, a4, a5) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
344 #define Pmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
345 #define Pmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
346 #define Pmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
347 #define Pmsg9(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9)
348 #define Pmsg10(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10)
349 #define Pmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
350 #define Pmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
351 #define Pmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
352 #define Pmsg14(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14) p_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14)
353
354        
355 /* Daemon Error Messages that are delivered according to the message resource */
356 #define Emsg0(typ, lvl, msg)             e_msg(__FILE__, __LINE__, typ, lvl, msg)
357 #define Emsg1(typ, lvl, msg, a1)         e_msg(__FILE__, __LINE__, typ, lvl, msg, a1)
358 #define Emsg2(typ, lvl, msg, a1, a2)     e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2)
359 #define Emsg3(typ, lvl, msg, a1, a2, a3) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3)
360 #define Emsg4(typ, lvl, msg, a1, a2, a3, a4) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4)
361 #define Emsg5(typ, lvl, msg, a1, a2, a3, a4, a5) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5)
362 #define Emsg6(typ, lvl, msg, a1, a2, a3, a4, a5, a6) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
363
364 /* Job Error Messages that are delivered according to the message resource */
365 #define Jmsg0(jcr, typ, lvl, msg)             j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
366 #define Jmsg1(jcr, typ, lvl, msg, a1)         j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
367 #define Jmsg2(jcr, typ, lvl, msg, a1, a2)     j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
368 #define Jmsg3(jcr, typ, lvl, msg, a1, a2, a3) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
369 #define Jmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
370 #define Jmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
371 #define Jmsg6(jcr, typ, lvl, msg, a1, a2, a3, a4, a5, a6) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
372
373 /* Queued Job Error Messages that are delivered according to the message resource */
374 #define Qmsg0(jcr, typ, lvl, msg)             q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
375 #define Qmsg1(jcr, typ, lvl, msg, a1)         q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
376 #define Qmsg2(jcr, typ, lvl, msg, a1, a2)     q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
377 #define Qmsg3(jcr, typ, lvl, msg, a1, a2, a3) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
378 #define Qmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
379 #define Qmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
380 #define Qmsg6(jcr, typ, lvl, msg, a1, a2, a3, a4, a5, a6) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
381
382
383 /* Memory Messages that are edited into a Pool Memory buffer */
384 #define Mmsg0(buf, msg)             m_msg(__FILE__, __LINE__, buf, msg)
385 #define Mmsg1(buf, msg, a1)         m_msg(__FILE__, __LINE__, buf, msg, a1)
386 #define Mmsg2(buf, msg, a1, a2)     m_msg(__FILE__, __LINE__, buf, msg, a1, a2)
387 #define Mmsg3(buf, msg, a1, a2, a3) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3)
388 #define Mmsg4(buf, msg, a1, a2, a3, a4) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4)
389 #define Mmsg5(buf, msg, a1, a2, a3, a4, a5) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5)
390 #define Mmsg6(buf, msg, a1, a2, a3, a4, a5, a6) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
391 #define Mmsg7(buf, msg, a1, a2, a3, a4, a5, a6, a7) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
392 #define Mmsg8(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6)
393 #define Mmsg11(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
394 #define Mmsg15(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14,a15) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14,a15)
395
396 /* Edit message into Pool Memory buffer -- no __FILE__ and __LINE__ */
397 int  Mmsg(POOLMEM **msgbuf, const char *fmt,...);
398
399
400 struct JCR;
401 void d_msg(const char *file, int line, int level, const char *fmt,...);
402 void p_msg(const char *file, int line, int level, const char *fmt,...);
403 void e_msg(const char *file, int line, int type, int level, const char *fmt,...);
404 void j_msg(const char *file, int line, JCR *jcr, int type, int level, const char *fmt,...);
405 void q_msg(const char *file, int line, JCR *jcr, int type, int level, const char *fmt,...);
406 int  m_msg(const char *file, int line, POOLMEM **msgbuf, const char *fmt,...);
407
408
409 /* Use our strdup with smartalloc */
410 #undef strdup
411 #define strdup(buf) bad_call_on_strdup_use_bstrdup(buf)
412
413 /* Use our fgets which handles interrupts */
414 #undef fgets
415 #define fgets(x,y,z) bfgets((x), (y), (z))
416
417 #ifdef DEBUG
418 #define bstrdup(str) strcpy((char *)b_malloc(__FILE__,__LINE__,strlen((str))+1),(str))
419 #else
420 #define bstrdup(str) strcpy((char *)bmalloc(strlen((str))+1),(str))
421 #endif
422
423 #ifdef DEBUG
424 #define bmalloc(size) b_malloc(__FILE__, __LINE__, (size))
425 #endif
426
427 #ifdef __alpha__
428 #define OSF 1
429 #endif
430
431 #ifdef HAVE_SUN_OS
432    /* 
433     * On Solaris 2.5, threads are not timesliced by default, so we need to
434     * explictly increase the conncurrency level.
435     */
436 #include <thread.h>
437 #define set_thread_concurrency(x)  thr_setconcurrency(x)
438 extern int thr_setconcurrency(int);
439 #define SunOS 1
440
441 #else
442
443
444 /* Not needed on most systems */
445 #define set_thread_concurrency(x)
446
447 #endif
448
449 #ifdef HAVE_DARWIN_OS
450 /* Apparently someone forgot to wrap getdomainname as a C function */
451 extern "C" int getdomainname(char *name, int len);
452
453 /* Darwin lib fnmatch() doesn't work, so use our own */
454 #undef HAVE_FNMATCH
455 #endif
456
457 #ifdef HAVE_CYGWIN
458 /* They don't really have it */
459 #undef HAVE_GETDOMAINNAME
460 #endif
461
462 /* Define Winsock functions if we aren't on Windows */
463 #if (!defined HAVE_WIN32) || (defined HAVE_CYGWIN)
464 #define WSA_Init() 0 /* 0 = success */
465 #define WSACleanup() 0 /* 0 = success */
466 #endif
467
468 #ifdef HAVE_AIX_OS
469 #endif
470  
471 /* This probably should be done on a machine by machine basic, but it works */
472 #define ALIGN_SIZE (sizeof(double))
473 #define BALIGN(x) (((x) + ALIGN_SIZE - 1) & ~(ALIGN_SIZE -1))
474
475
476 /* Added by KES to deal with Win32 systems */
477 #ifndef S_ISWIN32
478 #define S_ISWIN32 020000
479 #endif
480
481 /*
482  * Replace codes needed in both file routines and non-file routines
483  * Job replace codes -- in "replace"   
484  */
485 #define REPLACE_ALWAYS   'a'
486 #define REPLACE_IFNEWER  'w'
487 #define REPLACE_NEVER    'n'
488 #define REPLACE_IFOLDER  'o'
489
490 #ifdef HAVE_SETLOCALE
491 #include <locale.h>
492 #else
493 #define setlocale(x, y) ("ANSI_X3.4-1968")
494 #endif
495 #ifdef HAVE_NL_LANGINFO
496 #include <langinfo.h>
497 #else 
498 #define nl_langinfo(x) ("ANSI_X3.4-1968")
499 #endif
500
501 #endif /* _BACONFIG_H */