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