]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/baconfig.h
db85a20c197e9a70a160353f9210e163f03c1ed2
[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  * Set to time limit for other end to respond to
99  *  authentication.  Normally 10 minutes is *way*
100  *  more than enough. The idea is to keep the Director
101  *  from hanging because there is a dead connection on
102  *  the other end.
103  */
104 #define AUTH_TIMEOUT 60 * 10
105
106 /*
107  * Default network buffer size
108  */
109 #define DEFAULT_NETWORK_BUFFER_SIZE (32 * 1024)
110
111 /*
112  * Stream definitions.  Once defined these must NEVER
113  *   change as they go on the storage media.
114  * Note, the following streams are passed from the SD to the DIR
115  *   so that they may be put into the catalog (actually only the
116  *   stat packet part of the attr record is put in the catalog.
117  *
118  *   STREAM_UNIX_ATTRIBUTES
119  *   STREAM_UNIX_ATTRIBUTES_EX
120  *   STREAM_MD5_SIGNATURE
121  *   STREAM_SHA1_SIGNATURE
122  */
123 #define STREAM_UNIX_ATTRIBUTES    1    /* Generic Unix attributes */
124 #define STREAM_FILE_DATA          2    /* Standard uncompressed data */
125 #define STREAM_MD5_SIGNATURE      3    /* MD5 signature for the file */
126 #define STREAM_GZIP_DATA          4    /* GZip compressed file data */
127 /* Extended Unix attributes with Win32 Extended data.  Deprecated. */
128 #define STREAM_UNIX_ATTRIBUTES_EX 5    /* Extended Unix attr for Win32 EX */
129 #define STREAM_SPARSE_DATA        6    /* Sparse data stream */
130 #define STREAM_SPARSE_GZIP_DATA   7
131 #define STREAM_PROGRAM_NAMES      8    /* program names for program data */
132 #define STREAM_PROGRAM_DATA       9    /* Data needing program */
133 #define STREAM_SHA1_SIGNATURE    10    /* SHA1 signature for the file */
134 #define STREAM_WIN32_DATA        11    /* Win32 BackupRead data */
135 #define STREAM_WIN32_GZIP_DATA   12    /* Gzipped Win32 BackupRead data */
136 #define STREAM_MACOS_FORK_DATA   13    /* Mac resource fork */
137 #define STREAM_HFSPLUS_ATTRIBUTES 14   /* Mac OS extra attributes */
138 #define STREAM_UNIX_ATTRIBUTES_ACL 15 /* ACL attributes on UNIX */
139
140 /* 
141  *  File type (Bacula defined).           
142  *  NOTE!!! These are saved in the Attributes record on the tape, so
143  *          do not change them. If need be, add to them.
144  *
145  *  This is stored as 32 bits on tape, but only FT_MASK bits are
146  *    used for the file type. The upper bits are used to indicate
147  *    additional optional fields in the attribute record.
148  */
149 #define FT_MASK       0xFFFF          /* Bits used by FT (type) */
150 #define FT_LNKSAVED   1               /* hard link to file already saved */  
151 #define FT_REGE       2               /* Regular file but empty */
152 #define FT_REG        3               /* Regular file */
153 #define FT_LNK        4               /* Soft Link */
154 #define FT_DIREND     5               /* Directory at end (saved) */
155 #define FT_SPEC       6               /* Special file -- chr, blk, fifo, sock */
156 #define FT_NOACCESS   7               /* Not able to access */
157 #define FT_NOFOLLOW   8               /* Could not follow link */
158 #define FT_NOSTAT     9               /* Could not stat file */
159 #define FT_NOCHG     10               /* Incremental option, file not changed */
160 #define FT_DIRNOCHG  11               /* Incremental option, directory not changed */
161 #define FT_ISARCH    12               /* Trying to save archive file */
162 #define FT_NORECURSE 13               /* No recursion into directory */
163 #define FT_NOFSCHG   14               /* Different file system, prohibited */
164 #define FT_NOOPEN    15               /* Could not open directory */
165 #define FT_RAW       16               /* Raw block device */
166 #define FT_FIFO      17               /* Raw fifo device */
167 /* This directory packet is sent to the FD file processing routine so
168  * that it can filter packets, but otherwise, it is not used
169  * or saved */
170 #define FT_DIRBEGIN  18               /* Directory at beginning (not saved) */
171
172 /* Definitions for upper part of type word (see above). */
173 #define AR_DATA_STREAM (1<<16)        /* Data stream id present */
174
175 /*
176  * Internal code for Signature types
177  */
178 #define NO_SIG   0
179 #define MD5_SIG  1
180 #define SHA1_SIG 2
181
182 /* Size of File Address stored in STREAM_SPARSE_DATA. Do NOT change! */
183 #define SPARSE_FADDR_SIZE (sizeof(uint64_t))
184
185
186 /* This is for dumb compilers/libraries like Solaris. Linux GCC
187  * does it correctly, so it might be worthwhile
188  * to remove the isascii(c) with ifdefs on such
189  * "smart" systems.
190  */
191 #define B_ISSPACE(c) (isascii((int)(c)) && isspace((int)(c)))
192 #define B_ISALPHA(c) (isascii((int)(c)) && isalpha((int)(c)))
193 #define B_ISUPPER(c) (isascii((int)(c)) && isupper((int)(c)))
194 #define B_ISDIGIT(c) (isascii((int)(c)) && isdigit((int)(c)))
195
196 /* For multiplying by 10 with shift and addition */
197 #define B_TIMES10(d) ((d<<3)+(d<<1))
198
199
200 typedef void (HANDLER)();
201 typedef int (INTHANDLER)();
202
203 #ifdef SETPGRP_VOID
204 # define SETPGRP_ARGS(x, y) /* No arguments */
205 #else
206 # define SETPGRP_ARGS(x, y) (x, y)
207 #endif
208
209 #ifndef S_ISLNK
210 #define S_ISLNK(m) (((m) & S_IFM) == S_IFLNK)
211 #endif
212
213 /* Added by KES to deal with Win32 systems */
214 #ifndef S_ISWIN32
215 #define S_ISWIN32 020000
216 #endif
217
218 #ifndef INADDR_NONE
219 #define INADDR_NONE ((unsigned long) -1)
220 #endif
221
222 #ifdef TIME_WITH_SYS_TIME
223 # include <sys/time.h>
224 # include <time.h>
225 #else
226 # ifdef HAVE_SYS_TIME_H
227 #  include <sys/time.h>
228 # else
229 #  include <time.h>
230 # endif
231 #endif
232
233 #ifndef O_BINARY
234 #define O_BINARY 0
235 #endif
236
237 #ifndef O_NOFOLLOW
238 #define O_NOFOLLOW 0
239 #endif
240
241 #ifndef MODE_RW
242 #define MODE_RW 0666
243 #endif
244
245 #ifdef DEBUG_MUTEX
246 extern void _p(char *file, int line, pthread_mutex_t *m);
247 extern void _v(char *file, int line, pthread_mutex_t *m);
248
249 #define P(x) _p(__FILE__, __LINE__, &(x))
250 #define V(x) _v(__FILE__, __LINE__, &(x))
251
252 #else
253
254 /* These probably should be subroutines */
255 #define P(x) \
256    do { int errstat; if ((errstat=pthread_mutex_lock(&(x)))) \
257       e_msg(__FILE__, __LINE__, M_ABORT, 0, "Mutex lock failure. ERR=%s\n",\
258            strerror(errstat)); \
259    } while(0)
260
261 #define V(x) \
262    do { int errstat; if ((errstat=pthread_mutex_unlock(&(x)))) \
263          e_msg(__FILE__, __LINE__, M_ABORT, 0, "Mutex unlock failure. ERR=%s\n",\
264            strerror(errstat)); \
265    } while(0)
266
267 #endif /* DEBUG_MUTEX */
268
269 /* These probably should be subroutines */
270 #define Pw(x) \
271    do { int errstat; if ((errstat=rwl_writelock(&(x)))) \
272       e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock lock failure. ERR=%s\n",\
273            strerror(errstat)); \
274    } while(0)
275
276 #define Vw(x) \
277    do { int errstat; if ((errstat=rwl_writeunlock(&(x)))) \
278          e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock unlock failure. ERR=%s\n",\
279            strerror(errstat)); \
280    } while(0)
281
282 #define LockRes()   b_LockRes(__FILE__, __LINE__)
283 #define UnlockRes() b_UnlockRes(__FILE__, __LINE__)
284
285 #ifdef DEBUG_MEMSET
286 #define memset(a, v, n) b_memset(__FILE__, __LINE__, a, v, n)
287 void b_memset(const char *file, int line, void *mem, int val, size_t num);
288 #endif
289
290
291 /*
292  * The digit following Dmsg and Emsg indicates the number of substitutions in
293  * the message string. We need to do this kludge because non-GNU compilers
294  * do not handle varargs #defines.
295  */
296 /* Debug Messages that are printed */
297 #ifdef DEBUG
298 #define Dmsg0(lvl, msg)             d_msg(__FILE__, __LINE__, lvl, msg)
299 #define Dmsg1(lvl, msg, a1)         d_msg(__FILE__, __LINE__, lvl, msg, a1)
300 #define Dmsg2(lvl, msg, a1, a2)     d_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
301 #define Dmsg3(lvl, msg, a1, a2, a3) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
302 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4) d_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
303 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
304 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
305 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
306 #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)
307 #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)
308 #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)
309 #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)
310 #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)
311 #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)
312 #else
313 #define Dmsg0(lvl, msg)
314 #define Dmsg1(lvl, msg, a1)
315 #define Dmsg2(lvl, msg, a1, a2)
316 #define Dmsg3(lvl, msg, a1, a2, a3)
317 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4)
318 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5)
319 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
320 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
321 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
322 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
323 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
324 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
325 #endif /* DEBUG */
326
327 #ifdef TRACE_FILE
328 #define Tmsg0(lvl, msg)             t_msg(__FILE__, __LINE__, lvl, msg)
329 #define Tmsg1(lvl, msg, a1)         t_msg(__FILE__, __LINE__, lvl, msg, a1)
330 #define Tmsg2(lvl, msg, a1, a2)     t_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
331 #define Tmsg3(lvl, msg, a1, a2, a3) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
332 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4) t_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
333 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
334 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
335 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
336 #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)
337 #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)
338 #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)
339 #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)
340 #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)
341 #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)
342 #else
343 #define Tmsg0(lvl, msg)
344 #define Tmsg1(lvl, msg, a1)
345 #define Tmsg2(lvl, msg, a1, a2)
346 #define Tmsg3(lvl, msg, a1, a2, a3)
347 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4)
348 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5)
349 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
350 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
351 #define Tmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
352 #define Tmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
353 #define Tmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
354 #define Tmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
355 #endif /* TRACE_FILE */
356
357
358
359 /* Messages that are printed (uses d_msg) */
360 #define Pmsg0(lvl, msg)             p_msg(__FILE__, __LINE__, lvl, msg)
361 #define Pmsg1(lvl, msg, a1)         p_msg(__FILE__, __LINE__, lvl, msg, a1)
362 #define Pmsg2(lvl, msg, a1, a2)     p_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
363 #define Pmsg3(lvl, msg, a1, a2, a3) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
364 #define Pmsg4(lvl, msg, arg1, arg2, arg3, arg4) p_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
365 #define Pmsg5(lvl, msg, a1, a2, a3, a4, a5) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
366 #define Pmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
367 #define Pmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
368 #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)
369 #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)
370 #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)
371 #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)
372 #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)
373 #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)
374 #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)
375
376        
377 /* Daemon Error Messages that are delivered according to the message resource */
378 #define Emsg0(typ, lvl, msg)             e_msg(__FILE__, __LINE__, typ, lvl, msg)
379 #define Emsg1(typ, lvl, msg, a1)         e_msg(__FILE__, __LINE__, typ, lvl, msg, a1)
380 #define Emsg2(typ, lvl, msg, a1, a2)     e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2)
381 #define Emsg3(typ, lvl, msg, a1, a2, a3) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3)
382 #define Emsg4(typ, lvl, msg, a1, a2, a3, a4) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4)
383 #define Emsg5(typ, lvl, msg, a1, a2, a3, a4, a5) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5)
384 #define Emsg6(typ, lvl, msg, a1, a2, a3, a4, a5, a6) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
385
386 /* Job Error Messages that are delivered according to the message resource */
387 #define Jmsg0(jcr, typ, lvl, msg)             j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
388 #define Jmsg1(jcr, typ, lvl, msg, a1)         j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
389 #define Jmsg2(jcr, typ, lvl, msg, a1, a2)     j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
390 #define Jmsg3(jcr, typ, lvl, msg, a1, a2, a3) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
391 #define Jmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
392 #define Jmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
393 #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)
394
395 /* Queued Job Error Messages that are delivered according to the message resource */
396 #define Qmsg0(jcr, typ, lvl, msg)             q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
397 #define Qmsg1(jcr, typ, lvl, msg, a1)         q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
398 #define Qmsg2(jcr, typ, lvl, msg, a1, a2)     q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
399 #define Qmsg3(jcr, typ, lvl, msg, a1, a2, a3) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
400 #define Qmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
401 #define Qmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
402 #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)
403
404
405 /* Memory Messages that are edited into a Pool Memory buffer */
406 #define Mmsg0(buf, msg)             m_msg(__FILE__, __LINE__, buf, msg)
407 #define Mmsg1(buf, msg, a1)         m_msg(__FILE__, __LINE__, buf, msg, a1)
408 #define Mmsg2(buf, msg, a1, a2)     m_msg(__FILE__, __LINE__, buf, msg, a1, a2)
409 #define Mmsg3(buf, msg, a1, a2, a3) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3)
410 #define Mmsg4(buf, msg, a1, a2, a3, a4) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4)
411 #define Mmsg5(buf, msg, a1, a2, a3, a4, a5) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5)
412 #define Mmsg6(buf, msg, a1, a2, a3, a4, a5, a6) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
413 #define Mmsg7(buf, msg, a1, a2, a3, a4, a5, a6, a7) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
414 #define Mmsg8(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6)
415 #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)
416 #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)
417
418 class POOL_MEM;
419 /* Edit message into Pool Memory buffer -- no __FILE__ and __LINE__ */
420 int  Mmsg(POOLMEM **msgbuf, const char *fmt,...);
421 int  Mmsg(POOLMEM *&msgbuf, const char *fmt,...);
422 int  Mmsg(POOL_MEM &msgbuf, const char *fmt,...);
423
424
425 struct JCR;
426 void d_msg(const char *file, int line, int level, const char *fmt,...);
427 void p_msg(const char *file, int line, int level, const char *fmt,...);
428 void e_msg(const char *file, int line, int type, int level, const char *fmt,...);
429 void j_msg(const char *file, int line, JCR *jcr, int type, time_t mtime, const char *fmt,...);
430 void q_msg(const char *file, int line, JCR *jcr, int type, time_t mtime, const char *fmt,...);
431 int  m_msg(const char *file, int line, POOLMEM **msgbuf, const char *fmt,...);
432 int  m_msg(const char *file, int line, POOLMEM *&pool_buf, const char *fmt, ...);
433
434
435 /* Use our strdup with smartalloc */
436 #undef strdup
437 #define strdup(buf) bad_call_on_strdup_use_bstrdup(buf)
438
439 /* Use our fgets which handles interrupts */
440 #undef fgets
441 #define fgets(x,y,z) bfgets((x), (y), (z))
442
443 /* Use our sscanf, which is safer and works with known sizes */
444 #define sscanf bsscanf
445
446 #ifdef DEBUG
447 #define bstrdup(str) strcpy((char *)b_malloc(__FILE__,__LINE__,strlen((str))+1),(str))
448 #else
449 #define bstrdup(str) strcpy((char *)bmalloc(strlen((str))+1),(str))
450 #endif
451
452 #ifdef DEBUG
453 #define bmalloc(size) b_malloc(__FILE__, __LINE__, (size))
454 #endif
455
456 #ifdef __alpha__
457 #define OSF 1
458 #endif
459
460 #ifdef HAVE_SUN_OS
461    /* 
462     * On Solaris 2.5, threads are not timesliced by default, so we need to
463     * explictly increase the conncurrency level.
464     */
465 #include <thread.h>
466 #define set_thread_concurrency(x)  thr_setconcurrency(x)
467 extern int thr_setconcurrency(int);
468 #define SunOS 1
469
470 #else
471
472
473 /* Not needed on most systems */
474 #define set_thread_concurrency(x)
475
476 #endif
477
478 #ifdef HAVE_DARWIN_OS
479 /* Apparently someone forgot to wrap getdomainname as a C function */
480 extern "C" int getdomainname(char *name, int len);
481
482 /* Darwin lib fnmatch() doesn't work, so use our own */
483 #undef HAVE_FNMATCH
484 #endif
485
486 #ifdef HAVE_CYGWIN
487 /* They don't really have it */
488 #undef HAVE_GETDOMAINNAME
489 #endif
490
491 /* Define Winsock functions if we aren't on Windows */
492 #if (!defined HAVE_WIN32) || (defined HAVE_CYGWIN)
493 #define WSA_Init() 0 /* 0 = success */
494 #define WSACleanup() 0 /* 0 = success */
495 #endif
496
497 #ifdef HAVE_AIX_OS
498 #endif
499
500 #ifdef HAVE_OSF1_OS
501 #undef HAVE_CHFLAGS  /* chflags is incorrectly detected */
502 extern "C" int fchdir(int filedes);
503 extern "C" long gethostid(void);
504 #endif
505  
506 /* This probably should be done on a machine by machine basic, but it works */
507 #define ALIGN_SIZE (sizeof(double))
508 #define BALIGN(x) (((x) + ALIGN_SIZE - 1) & ~(ALIGN_SIZE -1))
509
510
511 /* Added by KES to deal with Win32 systems */
512 #ifndef S_ISWIN32
513 #define S_ISWIN32 020000
514 #endif
515
516 /*
517  * Replace codes needed in both file routines and non-file routines
518  * Job replace codes -- in "replace"   
519  */
520 #define REPLACE_ALWAYS   'a'
521 #define REPLACE_IFNEWER  'w'
522 #define REPLACE_NEVER    'n'
523 #define REPLACE_IFOLDER  'o'
524
525 #undef HAVE_SETLOCALE
526 #ifdef HAVE_SETLOCALE
527 #include <locale.h>
528 #else
529 #define setlocale(x, y) ("ANSI_X3.4-1968")
530 #endif
531 #ifdef HAVE_NL_LANGINFO
532 #include <langinfo.h>
533 #else 
534 #define nl_langinfo(x) ("ANSI_X3.4-1968")
535 #endif
536
537 /* Fake entry points if regex does not exist */
538 #ifndef HAVE_REGEX_H
539 #define regcomp(x, y, z) 1
540 #define regfree(x)
541 #define regerror(rc, preg, prbuf, len) bstrncpy(prbuf, "REGEX not available on this system.", len)
542 #define regex_t int
543 #define regmatch_t char
544 #endif
545
546 #endif /* _BACONFIG_H */