]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/baconfig.h
df14b3ce978f47dcc94abf60d3d9af3ab57dc3dd
[bacula/bacula] / bacula / src / baconfig.h
1 /*
2    Bacula® - The Network Backup Solution
3
4    Copyright (C) 2000-2007 Free Software Foundation Europe e.V.
5
6    The main author of Bacula is Kern Sibbald, with contributions from
7    many others, a complete list can be found in the file AUTHORS.
8    This program is Free Software; you can redistribute it and/or
9    modify it under the terms of version two of the GNU General Public
10    License as published by the Free Software Foundation and included
11    in the file LICENSE.
12
13    This program is distributed in the hope that it will be useful, but
14    WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16    General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21    02110-1301, USA.
22
23    Bacula® is a registered trademark of John Walker.
24    The licensor of Bacula is the Free Software Foundation Europe
25    (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
26    Switzerland, email:ftf@fsfeurope.org.
27 */
28 /*
29  * General header file configurations that apply to
30  * all daemons.  System dependent stuff goes here.
31  *
32  *   Version $Id$
33  */
34
35
36 #ifndef _BACONFIG_H
37 #define _BACONFIG_H 1
38
39 /* Bacula common configuration defines */
40
41 #define HAVE_VA_COPY
42
43 #undef  TRUE
44 #undef  FALSE
45 #define TRUE  1
46 #define FALSE 0
47
48 #ifndef MAX
49 #define MAX(a, b) ((a) > (b) ? (a) : (b))
50 #endif
51 #ifndef MIN
52 #define MIN(a, b) ((a) < (b) ? (a) : (b))
53 #endif
54
55 #ifdef HAVE_TLS
56 #define have_tls 1
57 #else
58 #define have_tls 0
59 #endif
60
61 #ifndef ETIME
62 #define ETIME ETIMEDOUT
63 #endif
64
65 #ifdef PROTOTYPES
66 # define __PROTO(p)     p
67 #else
68 # define __PROTO(p)     ()
69 #endif
70
71 #ifdef DEBUG
72 #define ASSERT(x) if (!(x)) { \
73    char *jcr = NULL; \
74    Emsg1(M_ERROR, 0, _("Failed ASSERT: %s\n"), #x); \
75    jcr[0] = 0; }
76 #else
77 #define ASSERT(x)
78 #endif
79
80 /* Allow printing of NULL pointers */
81 #define NPRT(x) (x)?(x):_("*None*")
82  
83 #if defined(HAVE_WIN32)
84 void InitWinAPIWrapper();
85
86 #define  OSDependentInit()    InitWinAPIWrapper()
87
88 #define sbrk(x)  0
89
90
91 #if defined(BUILDING_DLL)
92 #  define DLL_IMP_EXP   _declspec(dllexport)
93 #elif defined(USING_DLL)
94 #  define DLL_IMP_EXP   _declspec(dllimport)
95 #else
96 #  define DLL_IMP_EXP
97 #endif
98
99 #if defined(USING_CATS)
100 #  define CATS_IMP_EXP   _declspec(dllimport)
101 #else
102 #  define CATS_IMP_EXP
103 #endif
104
105 #else
106
107 #define DLL_IMP_EXP
108 #define CATS_IMP_EXP
109
110 #define  OSDependentInit()
111 #define  tape_open            open
112 #define  tape_ioctl           ioctl
113 #define  tape_read            ::read
114 #define  tape_write           ::write
115 #define  tape_close           ::close
116
117 #endif
118
119
120 #ifdef ENABLE_NLS
121    #include <libintl.h>
122    #include <locale.h>
123    #ifndef _
124       #define _(s) gettext((s))
125    #endif /* _ */
126    #ifndef N_
127       #define N_(s) (s)
128    #endif /* N_ */
129 #else /* !ENABLE_NLS */
130    #undef _
131    #undef N_
132    #undef textdomain
133    #undef bindtextdomain
134    #undef setlocale
135
136    #ifndef _
137       #define _(s) (s)
138    #endif
139    #ifndef N_
140       #define N_(s) (s)
141    #endif
142    #ifndef textdomain
143       #define textdomain(d)
144    #endif
145    #ifndef bindtextdomain
146       #define bindtextdomain(p, d)
147    #endif
148    #ifndef setlocale
149       #define setlocale(p, d)
150    #endif
151 #endif /* ENABLE_NLS */
152
153
154 /* Use the following for strings not to be translated */
155 #define NT_(s) (s)   
156
157 /* This should go away! ****FIXME***** */
158 #define MAXSTRING 500
159
160 /* Maximum length to edit time/date */
161 #define MAX_TIME_LENGTH 50
162
163 /* Maximum Name length including EOS */
164 #define MAX_NAME_LENGTH 128
165
166 /* Maximume number of user entered command args */
167 #define MAX_CMD_ARGS 30
168
169 /* All tape operations MUST be a multiple of this */
170 #define TAPE_BSIZE 1024
171
172 #ifdef DEV_BSIZE 
173 #define B_DEV_BSIZE DEV_BSIZE
174 #endif
175
176 #if !defined(B_DEV_BSIZE) & defined(BSIZE)
177 #define B_DEV_BSIZE BSIZE
178 #endif
179
180 #ifndef B_DEV_BSIZE
181 #define B_DEV_BSIZE 512
182 #endif
183
184 /*
185  * Set to time limit for other end to respond to
186  *  authentication.  Normally 10 minutes is *way*
187  *  more than enough. The idea is to keep the Director
188  *  from hanging because there is a dead connection on
189  *  the other end.
190  */
191 #define AUTH_TIMEOUT 60 * 10
192
193 /*
194  * Default network buffer size
195  */
196 #define DEFAULT_NETWORK_BUFFER_SIZE (64 * 1024)
197
198 /*
199  * Stream definitions.  Once defined these must NEVER
200  *   change as they go on the storage media.
201  * Note, the following streams are passed from the SD to the DIR
202  *   so that they may be put into the catalog (actually only the
203  *   stat packet part of the attr record is put in the catalog.
204  *
205  *   STREAM_UNIX_ATTRIBUTES
206  *   STREAM_UNIX_ATTRIBUTES_EX
207  *   STREAM_MD5_DIGEST
208  *   STREAM_SHA1_DIGEST
209  *   STREAM_SHA256_DIGEST
210  *   STREAM_SHA512_DIGEST
211  */
212 #define STREAM_NONE               0    /* Reserved Non-Stream */
213 #define STREAM_UNIX_ATTRIBUTES    1    /* Generic Unix attributes */
214 #define STREAM_FILE_DATA          2    /* Standard uncompressed data */
215 #define STREAM_MD5_SIGNATURE      3    /* deprecated */
216 #define STREAM_MD5_DIGEST         3    /* MD5 digest for the file */
217 #define STREAM_GZIP_DATA          4    /* GZip compressed file data */
218 /* Extended Unix attributes with Win32 Extended data.  Deprecated. */
219 #define STREAM_UNIX_ATTRIBUTES_EX 5    /* Extended Unix attr for Win32 EX */
220 #define STREAM_SPARSE_DATA        6    /* Sparse data stream */
221 #define STREAM_SPARSE_GZIP_DATA   7
222 #define STREAM_PROGRAM_NAMES      8    /* program names for program data */
223 #define STREAM_PROGRAM_DATA       9    /* Data needing program */
224 #define STREAM_SHA1_SIGNATURE    10    /* deprecated */
225 #define STREAM_SHA1_DIGEST       10    /* SHA1 digest for the file */
226 #define STREAM_WIN32_DATA        11    /* Win32 BackupRead data */
227 #define STREAM_WIN32_GZIP_DATA   12    /* Gzipped Win32 BackupRead data */
228 #define STREAM_MACOS_FORK_DATA   13    /* Mac resource fork */
229 #define STREAM_HFSPLUS_ATTRIBUTES 14   /* Mac OS extra attributes */
230 /*** FIXME ***/
231 #define STREAM_UNIX_ATTRIBUTES_ACCESS_ACL 15 /* Standard ACL attributes on UNIX */
232 #define STREAM_UNIX_ATTRIBUTES_DEFAULT_ACL 16 /* Default ACL attributes on UNIX */
233 /*** FIXME ***/
234 #define STREAM_SHA256_DIGEST              17   /* SHA-256 digest for the file */
235 #define STREAM_SHA512_DIGEST              18   /* SHA-512 digest for the file */
236 #define STREAM_SIGNED_DIGEST              19   /* Signed File Digest, ASN.1, DER Encoded */
237 #define STREAM_ENCRYPTED_FILE_DATA        20   /* Encrypted, uncompressed data */
238 #define STREAM_ENCRYPTED_WIN32_DATA       21   /* Encrypted, uncompressed Win32 BackupRead data */
239 #define STREAM_ENCRYPTED_SESSION_DATA     22   /* Encrypted Session Data, ASN.1, DER Encoded */
240 #define STREAM_ENCRYPTED_FILE_GZIP_DATA   23   /* Encrypted, compressed data */
241 #define STREAM_ENCRYPTED_WIN32_GZIP_DATA  24   /* Encrypted, compressed Win32 BackupRead data */
242 #define STREAM_ENCRYPTED_MACOS_FORK_DATA  25   /* Encrypted, uncompressed Mac resource fork */
243
244
245 /*
246  *  File type (Bacula defined).
247  *  NOTE!!! These are saved in the Attributes record on the tape, so
248  *          do not change them. If need be, add to them.
249  *
250  *  This is stored as 32 bits on tape, but only FT_MASK bits are
251  *    used for the file type. The upper bits are used to indicate
252  *    additional optional fields in the attribute record.
253  */
254 #define FT_MASK       0xFFFF          /* Bits used by FT (type) */
255 #define FT_LNKSAVED   1               /* hard link to file already saved */
256 #define FT_REGE       2               /* Regular file but empty */
257 #define FT_REG        3               /* Regular file */
258 #define FT_LNK        4               /* Soft Link */
259 #define FT_DIREND     5               /* Directory at end (saved) */
260 #define FT_SPEC       6               /* Special file -- chr, blk, fifo, sock */
261 #define FT_NOACCESS   7               /* Not able to access */
262 #define FT_NOFOLLOW   8               /* Could not follow link */
263 #define FT_NOSTAT     9               /* Could not stat file */
264 #define FT_NOCHG     10               /* Incremental option, file not changed */
265 #define FT_DIRNOCHG  11               /* Incremental option, directory not changed */
266 #define FT_ISARCH    12               /* Trying to save archive file */
267 #define FT_NORECURSE 13               /* No recursion into directory */
268 #define FT_NOFSCHG   14               /* Different file system, prohibited */
269 #define FT_NOOPEN    15               /* Could not open directory */
270 #define FT_RAW       16               /* Raw block device */
271 #define FT_FIFO      17               /* Raw fifo device */
272 /* The DIRBEGIN packet is sent to the FD file processing routine so
273  * that it can filter packets, but otherwise, it is not used
274  * or saved */
275 #define FT_DIRBEGIN  18               /* Directory at beginning (not saved) */
276 #define FT_INVALIDFS 19               /* File system not allowed for */
277 #define FT_INVALIDDT 20               /* Drive type not allowed for */
278 #define FT_REPARSE   21               /* Win NTFS reparse point */
279
280 /* Definitions for upper part of type word (see above). */
281 #define AR_DATA_STREAM (1<<16)        /* Data stream id present */
282
283 /*
284  * Tape label types -- stored in catalog
285  */
286 #define B_BACULA_LABEL 0
287 #define B_ANSI_LABEL   1
288 #define B_IBM_LABEL    2
289
290 /* Size of File Address stored in STREAM_SPARSE_DATA. Do NOT change! */
291 #define SPARSE_FADDR_SIZE (sizeof(uint64_t))
292
293 /* Size of crypto length stored at head of crypto buffer. Do NOT change! */
294 #define CRYPTO_LEN_SIZE ((int)sizeof(uint32_t))
295
296
297 /* This is for dumb compilers/libraries like Solaris. Linux GCC
298  * does it correctly, so it might be worthwhile
299  * to remove the isascii(c) with ifdefs on such
300  * "smart" systems.
301  */
302 #define B_ISSPACE(c) (isascii((int)(c)) && isspace((int)(c)))
303 #define B_ISALPHA(c) (isascii((int)(c)) && isalpha((int)(c)))
304 #define B_ISUPPER(c) (isascii((int)(c)) && isupper((int)(c)))
305 #define B_ISDIGIT(c) (isascii((int)(c)) && isdigit((int)(c)))
306
307 /* For multiplying by 10 with shift and addition */
308 #define B_TIMES10(d) ((d<<3)+(d<<1))
309
310
311 typedef void (HANDLER)();
312 typedef int (INTHANDLER)();
313
314 #ifdef SETPGRP_VOID
315 # define SETPGRP_ARGS(x, y) /* No arguments */
316 #else
317 # define SETPGRP_ARGS(x, y) (x, y)
318 #endif
319
320 #ifndef S_ISLNK
321 #define S_ISLNK(m) (((m) & S_IFM) == S_IFLNK)
322 #endif
323
324 /* Added by KES to deal with Win32 systems */
325 #ifndef S_ISWIN32
326 #define S_ISWIN32 020000
327 #endif
328
329 #ifndef INADDR_NONE
330 #define INADDR_NONE ((unsigned long) -1)
331 #endif
332
333 #ifdef TIME_WITH_SYS_TIME
334 # include <sys/time.h>
335 # include <time.h>
336 #else
337 # ifdef HAVE_SYS_TIME_H
338 #  include <sys/time.h>
339 # else
340 #  include <time.h>
341 # endif
342 #endif
343
344 #ifndef O_BINARY
345 #define O_BINARY 0
346 #endif
347
348 #ifndef O_NOFOLLOW
349 #define O_NOFOLLOW 0
350 #endif
351
352 #ifndef MODE_RW
353 #define MODE_RW 0666
354 #endif
355
356 #if defined(HAVE_WIN32)
357 typedef int64_t   boffset_t;
358 #else
359 typedef off_t     boffset_t;
360 #endif
361
362 #if defined(DEBUG_MUTEX)
363 extern void _p(char *file, int line, pthread_mutex_t *m);
364 extern void _v(char *file, int line, pthread_mutex_t *m);
365
366 #define P(x) _p(__FILE__, __LINE__, &(x))
367 #define V(x) _v(__FILE__, __LINE__, &(x))
368
369 #else
370 extern void _p(pthread_mutex_t *m);
371 extern void _v(pthread_mutex_t *m);
372
373 #define P(x) _p(&(x))
374 #define V(x) _v(&(x))
375
376 #endif /* DEBUG_MUTEX */
377
378 /* These probably should be subroutines */
379 #define Pw(x) \
380    do { int errstat; if ((errstat=rwl_writelock(&(x)))) \
381       e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock lock failure. ERR=%s\n",\
382            strerror(errstat)); \
383    } while(0)
384
385 #define Vw(x) \
386    do { int errstat; if ((errstat=rwl_writeunlock(&(x)))) \
387          e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock unlock failure. ERR=%s\n",\
388            strerror(errstat)); \
389    } while(0)
390
391 #define LockRes()   b_LockRes(__FILE__, __LINE__)
392 #define UnlockRes() b_UnlockRes(__FILE__, __LINE__)
393
394 #ifdef DEBUG_MEMSET
395 #define memset(a, v, n) b_memset(__FILE__, __LINE__, a, v, n)
396 void b_memset(const char *file, int line, void *mem, int val, size_t num);
397 #endif
398
399
400 /*
401  * The digit following Dmsg and Emsg indicates the number of substitutions in
402  * the message string. We need to do this kludge because non-GNU compilers
403  * do not handle varargs #defines.
404  */
405 /* Debug Messages that are printed */
406 #ifdef DEBUG
407 #define Dmsg0(lvl, msg)             if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg)
408 #define Dmsg1(lvl, msg, a1)         if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1)
409 #define Dmsg2(lvl, msg, a1, a2)     if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
410 #define Dmsg3(lvl, msg, a1, a2, a3) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
411 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
412 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
413 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
414 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
415 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
416 #define Dmsg9(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9) if ((lvl)<=debug_level) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9)
417 #define Dmsg10(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10) if ((lvl)<=debug_level) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10)
418 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11) if ((lvl)<=debug_level) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
419 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12) if ((lvl)<=debug_level) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
420 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13) if ((lvl)<=debug_level) d_msg(__FILE__,__LINE__,lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
421 #else
422 #define Dmsg0(lvl, msg)
423 #define Dmsg1(lvl, msg, a1)
424 #define Dmsg2(lvl, msg, a1, a2)
425 #define Dmsg3(lvl, msg, a1, a2, a3)
426 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4)
427 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5)
428 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
429 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
430 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
431 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
432 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
433 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
434 #endif /* DEBUG */
435
436 #ifdef TRACE_FILE
437 #define Tmsg0(lvl, msg)             t_msg(__FILE__, __LINE__, lvl, msg)
438 #define Tmsg1(lvl, msg, a1)         t_msg(__FILE__, __LINE__, lvl, msg, a1)
439 #define Tmsg2(lvl, msg, a1, a2)     t_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
440 #define Tmsg3(lvl, msg, a1, a2, a3) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
441 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4) t_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
442 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
443 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
444 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
445 #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)
446 #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)
447 #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)
448 #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)
449 #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)
450 #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)
451 #else
452 #define Tmsg0(lvl, msg)
453 #define Tmsg1(lvl, msg, a1)
454 #define Tmsg2(lvl, msg, a1, a2)
455 #define Tmsg3(lvl, msg, a1, a2, a3)
456 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4)
457 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5)
458 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
459 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
460 #define Tmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
461 #define Tmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
462 #define Tmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
463 #define Tmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
464 #endif /* TRACE_FILE */
465
466
467
468 /* Messages that are printed (uses d_msg) */
469 #define Pmsg0(lvl, msg)             p_msg(__FILE__, __LINE__, lvl, msg)
470 #define Pmsg1(lvl, msg, a1)         p_msg(__FILE__, __LINE__, lvl, msg, a1)
471 #define Pmsg2(lvl, msg, a1, a2)     p_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
472 #define Pmsg3(lvl, msg, a1, a2, a3) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
473 #define Pmsg4(lvl, msg, arg1, arg2, arg3, arg4) p_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
474 #define Pmsg5(lvl, msg, a1, a2, a3, a4, a5) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
475 #define Pmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
476 #define Pmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
477 #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)
478 #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)
479 #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)
480 #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)
481 #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)
482 #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)
483 #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)
484
485
486 /* Daemon Error Messages that are delivered according to the message resource */
487 #define Emsg0(typ, lvl, msg)             e_msg(__FILE__, __LINE__, typ, lvl, msg)
488 #define Emsg1(typ, lvl, msg, a1)         e_msg(__FILE__, __LINE__, typ, lvl, msg, a1)
489 #define Emsg2(typ, lvl, msg, a1, a2)     e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2)
490 #define Emsg3(typ, lvl, msg, a1, a2, a3) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3)
491 #define Emsg4(typ, lvl, msg, a1, a2, a3, a4) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4)
492 #define Emsg5(typ, lvl, msg, a1, a2, a3, a4, a5) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5)
493 #define Emsg6(typ, lvl, msg, a1, a2, a3, a4, a5, a6) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
494
495 /* Job Error Messages that are delivered according to the message resource */
496 #define Jmsg0(jcr, typ, lvl, msg)             j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
497 #define Jmsg1(jcr, typ, lvl, msg, a1)         j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
498 #define Jmsg2(jcr, typ, lvl, msg, a1, a2)     j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
499 #define Jmsg3(jcr, typ, lvl, msg, a1, a2, a3) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
500 #define Jmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
501 #define Jmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
502 #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)
503
504 /* Queued Job Error Messages that are delivered according to the message resource */
505 #define Qmsg0(jcr, typ, lvl, msg)             q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
506 #define Qmsg1(jcr, typ, lvl, msg, a1)         q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
507 #define Qmsg2(jcr, typ, lvl, msg, a1, a2)     q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
508 #define Qmsg3(jcr, typ, lvl, msg, a1, a2, a3) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
509 #define Qmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
510 #define Qmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
511 #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)
512
513
514 /* Memory Messages that are edited into a Pool Memory buffer */
515 #define Mmsg0(buf, msg)             m_msg(__FILE__, __LINE__, buf, msg)
516 #define Mmsg1(buf, msg, a1)         m_msg(__FILE__, __LINE__, buf, msg, a1)
517 #define Mmsg2(buf, msg, a1, a2)     m_msg(__FILE__, __LINE__, buf, msg, a1, a2)
518 #define Mmsg3(buf, msg, a1, a2, a3) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3)
519 #define Mmsg4(buf, msg, a1, a2, a3, a4) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4)
520 #define Mmsg5(buf, msg, a1, a2, a3, a4, a5) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5)
521 #define Mmsg6(buf, msg, a1, a2, a3, a4, a5, a6) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
522 #define Mmsg7(buf, msg, a1, a2, a3, a4, a5, a6, a7) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
523 #define Mmsg8(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6)
524 #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)
525 #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)
526
527 class POOL_MEM;
528 /* Edit message into Pool Memory buffer -- no __FILE__ and __LINE__ */
529 int  Mmsg(POOLMEM **msgbuf, const char *fmt,...);
530 int  Mmsg(POOLMEM *&msgbuf, const char *fmt,...);
531 int  Mmsg(POOL_MEM &msgbuf, const char *fmt,...);
532
533
534 class JCR;
535 void d_msg(const char *file, int line, int level, const char *fmt,...);
536 void p_msg(const char *file, int line, int level, const char *fmt,...);
537 void e_msg(const char *file, int line, int type, int level, const char *fmt,...);
538 void j_msg(const char *file, int line, JCR *jcr, int type, time_t mtime, const char *fmt,...);
539 void q_msg(const char *file, int line, JCR *jcr, int type, time_t mtime, const char *fmt,...);
540 int  m_msg(const char *file, int line, POOLMEM **msgbuf, const char *fmt,...);
541 int  m_msg(const char *file, int line, POOLMEM *&pool_buf, const char *fmt, ...);
542
543
544 /* Use our strdup with smartalloc */
545 #ifndef HAVE_WXCONSOLE
546 #undef strdup
547 #define strdup(buf) bad_call_on_strdup_use_bstrdup(buf)
548 #else 
549 /* Groan, WxWidgets has its own way of doing NLS so cleanup */
550 #ifndef ENABLE_NLS
551 #undef _
552 #undef setlocale
553 #undef textdomain
554 #undef bindtextdomain
555 #endif  
556 #endif
557
558 /* Use our fgets which handles interrupts */
559 #undef fgets
560 #define fgets(x,y,z) bfgets((x), (y), (z))
561
562 /* Use our sscanf, which is safer and works with known sizes */
563 #define sscanf bsscanf
564
565 #ifdef DEBUG
566 #define bstrdup(str) strcpy((char *)b_malloc(__FILE__,__LINE__,strlen((str))+1),(str))
567 #else
568 #define bstrdup(str) strcpy((char *)bmalloc(strlen((str))+1),(str))
569 #endif
570
571 #ifdef DEBUG
572 #define bmalloc(size) b_malloc(__FILE__, __LINE__, (size))
573 #endif
574
575 /*
576  * Replace codes needed in both file routines and non-file routines
577  * Job replace codes -- in "replace"
578  */
579 #define REPLACE_ALWAYS   'a'
580 #define REPLACE_IFNEWER  'w'
581 #define REPLACE_NEVER    'n'
582 #define REPLACE_IFOLDER  'o'
583
584 /* This probably should be done on a machine by machine basis, but it works */
585 /* This is critical for the smartalloc routines to properly align memory */
586 #define ALIGN_SIZE (sizeof(double))
587 #define BALIGN(x) (((x) + ALIGN_SIZE - 1) & ~(ALIGN_SIZE -1))
588
589
590 /* =============================================================
591  *               OS Dependent defines
592  * ============================================================= 
593  */
594
595 #ifndef HAVE_FSEEKO
596 /* Bad news. This OS cannot handle 64 bit fseeks and ftells */
597 #define fseeko fseek
598 #define ftello ftell
599 #endif
600
601 #if defined (__digital__) && defined (__unix__)
602 /* Tru64 - it does have fseeko and ftello , but since ftell/fseek are also 64 bit */
603 /* take this 'shortcut' */
604 #define fseeko fseek
605 #define ftello ftell
606 #endif
607
608
609 #ifdef __alpha__
610 #define OSF 1
611 #endif
612
613 #ifdef HAVE_SUN_OS
614    /*
615     * On Solaris 2.5, threads are not timesliced by default, so we need to
616     * explictly increase the conncurrency level.
617     */
618 #include <thread.h>
619 #define set_thread_concurrency(x)  thr_setconcurrency(x)
620 extern int thr_setconcurrency(int);
621 #define SunOS 1
622
623 #else
624
625
626 /* Not needed on most systems */
627 #define set_thread_concurrency(x)
628
629 #endif
630
631 #if defined(HAVE_DARWIN_OS) || defined(HAVE_OSF1_OS)
632 #undef HAVE_VA_COPY
633 /* Apparently someone forgot to wrap getdomainname as a C function */
634 extern "C" int getdomainname(char *name, int len);
635 #endif
636
637
638
639 #if defined(HAVE_WIN32)
640 #define DEFAULT_CONFIGDIR "C:\\Documents and Settings\\All Users\\Application Data\\Bacula"
641 #define PathSeparator '\\'
642
643 inline bool IsPathSeparator(int ch) { return ch == '/' || ch == '\\'; }
644 inline char *first_path_separator(char *path) { return strpbrk(path, "/\\"); }
645 inline const char *first_path_separator(const char *path) { return strpbrk(path, "/\\"); }
646
647 #else
648 #define PathSeparator '/'
649 /* Define Winsock functions if we aren't on Windows */
650
651 #define WSA_Init() 0 /* 0 = success */
652 #define WSACleanup() 0 /* 0 = success */
653
654 inline bool IsPathSeparator(int ch) { return ch == '/'; }
655 inline char *first_path_separator(char *path) { return strchr(path, '/'); }
656 inline const char *first_path_separator(const char *path) { return strchr(path, '/'); }
657 #endif
658
659
660 /* HP-UX 11 specific workarounds */
661
662 #ifdef HAVE_HPUX_OS
663 # undef h_errno
664 #undef HAVE_VA_COPY
665 extern int h_errno;
666 /* the {get,set}domainname() functions exist in HPUX's libc.
667  * the configure script detects that correctly.
668  * the problem is no system headers declares the prototypes for these functions
669  * this is done below
670  */
671 extern "C" int getdomainname(char *name, int namelen);
672 extern "C" int setdomainname(char *name, int namelen);
673 #endif /* HAVE_HPUX_OS */
674
675
676 #ifdef HAVE_OSF1_OS
677 #undef HAVE_VA_COPY
678 extern "C" int fchdir(int filedes);
679 extern "C" long gethostid(void);
680 extern "C" int mknod ( const char *path, int mode, dev_t device );
681 #endif
682
683
684 /* Disabled because it breaks internationalisation...
685 #undef HAVE_SETLOCALE
686 #ifdef HAVE_SETLOCALE
687 #include <locale.h>
688 #else
689 #define setlocale(x, y) ("ANSI_X3.4-1968")
690 #endif
691 #ifdef HAVE_NL_LANGINFO
692 #include <langinfo.h>
693 #else
694 #define nl_langinfo(x) ("ANSI_X3.4-1968")
695 #endif
696 */
697
698 #endif /* _BACONFIG_H */