2 Bacula® - The Network Backup Solution
4 Copyright (C) 2000-2008 Free Software Foundation Europe e.V.
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
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.
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
23 Bacula® is a registered trademark of Kern Sibbald.
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.
29 * General header file configurations that apply to
30 * all daemons. System dependent stuff goes here.
39 /* Bacula common configuration defines */
47 #define MAX(a, b) ((a) > (b) ? (a) : (b))
50 #define MIN(a, b) ((a) < (b) ? (a) : (b))
60 #define ETIME ETIMEDOUT
63 #define ioctl_req_t long unsigned int
68 # define __PROTO(p) ()
72 #define ASSERT(x) if (!(x)) { \
74 Emsg1(M_ERROR, 0, _("Failed ASSERT: %s\n"), #x); \
80 /* Allow printing of NULL pointers */
81 #define NPRT(x) (x)?(x):_("*None*")
82 #define NPRTB(x) (x)?(x):""
84 #if defined(HAVE_WIN32)
86 #define WIN32_REPARSE_POINT 1
87 #define WIN32_MOUNT_POINT 2
89 void InitWinAPIWrapper();
91 #define OSDependentInit() InitWinAPIWrapper()
95 #define clear_thread_id(x) memset(&(x), 0, sizeof(x))
97 #if defined(BUILDING_DLL)
98 # define DLL_IMP_EXP _declspec(dllexport)
99 #elif defined(USING_DLL)
100 # define DLL_IMP_EXP _declspec(dllimport)
105 #if defined(USING_CATS)
106 # define CATS_IMP_EXP _declspec(dllimport)
108 # define CATS_IMP_EXP
111 #else /* HAVE_WIN32 */
113 #define clear_thread_id(x) x = 0
118 #define OSDependentInit()
120 #endif /* HAVE_WIN32 */
127 #define _(s) gettext((s))
132 #else /* !ENABLE_NLS */
136 #undef bindtextdomain
146 #define textdomain(d)
148 #ifndef bindtextdomain
149 #define bindtextdomain(p, d)
152 #define setlocale(p, d)
154 #endif /* ENABLE_NLS */
157 /* Use the following for strings not to be translated */
160 /* This should go away! ****FIXME***** */
161 #define MAXSTRING 500
163 /* Maximum length to edit time/date */
164 #define MAX_TIME_LENGTH 50
166 /* Maximum Name length including EOS */
167 #define MAX_NAME_LENGTH 128
169 /* Maximume number of user entered command args */
170 #define MAX_CMD_ARGS 30
172 /* All tape operations MUST be a multiple of this */
173 #define TAPE_BSIZE 1024
176 #define B_DEV_BSIZE DEV_BSIZE
179 #if !defined(B_DEV_BSIZE) & defined(BSIZE)
180 #define B_DEV_BSIZE BSIZE
184 #define B_DEV_BSIZE 512
188 * Set to time limit for other end to respond to
189 * authentication. Normally 10 minutes is *way*
190 * more than enough. The idea is to keep the Director
191 * from hanging because there is a dead connection on
194 #define AUTH_TIMEOUT 60 * 10
197 * Default network buffer size
199 #define DEFAULT_NETWORK_BUFFER_SIZE (64 * 1024)
202 * Stream definitions. Once defined these must NEVER
203 * change as they go on the storage media.
204 * Note, the following streams are passed from the SD to the DIR
205 * so that they may be put into the catalog (actually only the
206 * stat packet part of the attr record is put in the catalog.
208 * STREAM_UNIX_ATTRIBUTES
209 * STREAM_UNIX_ATTRIBUTES_EX
212 * STREAM_SHA256_DIGEST
213 * STREAM_SHA512_DIGEST
215 #define STREAM_NONE 0 /* Reserved Non-Stream */
216 #define STREAM_UNIX_ATTRIBUTES 1 /* Generic Unix attributes */
217 #define STREAM_FILE_DATA 2 /* Standard uncompressed data */
218 #define STREAM_MD5_SIGNATURE 3 /* deprecated */
219 #define STREAM_MD5_DIGEST 3 /* MD5 digest for the file */
220 #define STREAM_GZIP_DATA 4 /* GZip compressed file data */
221 #define STREAM_UNIX_ATTRIBUTES_EX 5 /* Extended Unix attr for Win32 EX - Deprecated */
222 #define STREAM_SPARSE_DATA 6 /* Sparse data stream */
223 #define STREAM_SPARSE_GZIP_DATA 7 /* Sparse gzipped data stream */
224 #define STREAM_PROGRAM_NAMES 8 /* program names for program data */
225 #define STREAM_PROGRAM_DATA 9 /* Data needing program */
226 #define STREAM_SHA1_SIGNATURE 10 /* deprecated */
227 #define STREAM_SHA1_DIGEST 10 /* SHA1 digest for the file */
228 #define STREAM_WIN32_DATA 11 /* Win32 BackupRead data */
229 #define STREAM_WIN32_GZIP_DATA 12 /* Gzipped Win32 BackupRead data */
230 #define STREAM_MACOS_FORK_DATA 13 /* Mac resource fork */
231 #define STREAM_HFSPLUS_ATTRIBUTES 14 /* Mac OS extra attributes */
232 #define STREAM_UNIX_ACCESS_ACL 15 /* Standard ACL attributes on UNIX - Deprecated */
233 #define STREAM_UNIX_DEFAULT_ACL 16 /* Default ACL attributes on UNIX - Deprecated */
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 #define STREAM_PLUGIN_NAME 26 /* Plugin "file" string */
244 #define STREAM_PLUGIN_DATA 27 /* Plugin specific data */
247 * Additional Stream definitions. Once defined these must NEVER
248 * change as they go on the storage media.
250 * The Stream numbers from 1000-1999 are reserved for ACL and extended attribute streams.
251 * Each different platform has its own stream id(s), if a platform supports multiple stream types
252 * it should supply different handlers for each type it supports and this should be called
253 * from the stream dispatch function. Currently in this reserved space we allocate the
254 * different acl streams from 1000 on and the different extended attributes streams from
255 * 1999 down. So the two naming spaces grows towards each other.
257 #define STREAM_ACL_AIX_TEXT 1000 /* AIX specific string representation from acl_get */
258 #define STREAM_ACL_DARWIN_ACCESS_ACL 1001 /* Darwin (OSX) specific acl_t string representation
259 * from acl_to_text (POSIX acl)
261 #define STREAM_ACL_FREEBSD_DEFAULT_ACL 1002 /* FreeBSD specific acl_t string representation
262 * from acl_to_text (POSIX acl) for default acls.
264 #define STREAM_ACL_FREEBSD_ACCESS_ACL 1003 /* FreeBSD specific acl_t string representation
265 * from acl_to_text (POSIX acl) for access acls.
267 #define STREAM_ACL_HPUX_ACL_ENTRY 1004 /* HPUX specific acl_entry string representation
268 * from acltostr (POSIX acl)
270 #define STREAM_ACL_IRIX_DEFAULT_ACL 1005 /* IRIX specific acl_t string representation
271 * from acl_to_text (POSIX acl) for default acls.
273 #define STREAM_ACL_IRIX_ACCESS_ACL 1006 /* IRIX specific acl_t string representation
274 * from acl_to_text (POSIX acl) for access acls.
276 #define STREAM_ACL_LINUX_DEFAULT_ACL 1007 /* Linux specific acl_t string representation
277 * from acl_to_text (POSIX acl) for default acls.
279 #define STREAM_ACL_LINUX_ACCESS_ACL 1008 /* Linux specific acl_t string representation
280 * from acl_to_text (POSIX acl) for access acls.
282 #define STREAM_ACL_TRU64_DEFAULT_ACL 1009 /* Tru64 specific acl_t string representation
283 * from acl_to_text (POSIX acl) for default acls.
285 #define STREAM_ACL_TRU64_DEFAULT_DIR_ACL 1010 /* Tru64 specific acl_t string representation
286 * from acl_to_text (POSIX acl) for default acls.
288 #define STREAM_ACL_TRU64_ACCESS_ACL 1011 /* Tru64 specific acl_t string representation
289 * from acl_to_text (POSIX acl) for access acls.
291 #define STREAM_ACL_SOLARIS_ACLENT 1012 /* Solaris specific aclent_t string representation
292 * from acltotext or acl_totext (POSIX acl)
294 #define STREAM_ACL_SOLARIS_ACE 1013 /* Solaris specific ace_t string representation from
295 * from acl_totext (NFSv4 or ZFS acl)
297 #define STREAM_XATTR_SOLARIS 1995 /* Solaris specific extented attributes and extensible attributes */
298 #define STREAM_XATTR_DARWIN 1996 /* Darwin (OSX) specific extended attributes */
299 #define STREAM_XATTR_FREEBSD 1997 /* FreeBSD specific extended attributes */
300 #define STREAM_XATTR_LINUX 1998 /* Linux specific extended attributes */
301 #define STREAM_XATTR_NETBSD 1999 /* NetBSD specific extended attributes */
304 * File type (Bacula defined).
305 * NOTE!!! These are saved in the Attributes record on the tape, so
306 * do not change them. If need be, add to them.
308 * This is stored as 32 bits on the Volume, but only FT_MASK (16) bits are
309 * used for the file type. The upper bits are used to indicate
310 * additional optional fields in the attribute record.
312 #define FT_MASK 0xFFFF /* Bits used by FT (type) */
313 #define FT_LNKSAVED 1 /* hard link to file already saved */
314 #define FT_REGE 2 /* Regular file but empty */
315 #define FT_REG 3 /* Regular file */
316 #define FT_LNK 4 /* Soft Link */
317 #define FT_DIREND 5 /* Directory at end (saved) */
318 #define FT_SPEC 6 /* Special file -- chr, blk, fifo, sock */
319 #define FT_NOACCESS 7 /* Not able to access */
320 #define FT_NOFOLLOW 8 /* Could not follow link */
321 #define FT_NOSTAT 9 /* Could not stat file */
322 #define FT_NOCHG 10 /* Incremental option, file not changed */
323 #define FT_DIRNOCHG 11 /* Incremental option, directory not changed */
324 #define FT_ISARCH 12 /* Trying to save archive file */
325 #define FT_NORECURSE 13 /* No recursion into directory */
326 #define FT_NOFSCHG 14 /* Different file system, prohibited */
327 #define FT_NOOPEN 15 /* Could not open directory */
328 #define FT_RAW 16 /* Raw block device */
329 #define FT_FIFO 17 /* Raw fifo device */
330 /* The DIRBEGIN packet is sent to the FD file processing routine so
331 * that it can filter packets, but otherwise, it is not used
333 #define FT_DIRBEGIN 18 /* Directory at beginning (not saved) */
334 #define FT_INVALIDFS 19 /* File system not allowed for */
335 #define FT_INVALIDDT 20 /* Drive type not allowed for */
336 #define FT_REPARSE 21 /* Win NTFS reparse point */
337 #define FT_PLUGIN 22 /* Plugin generated filename */
338 #define FT_DELETED 23 /* Deleted file entry */
340 /* Definitions for upper part of type word (see above). */
341 #define AR_DATA_STREAM (1<<16) /* Data stream id present */
344 * Tape label types -- stored in catalog
346 #define B_BACULA_LABEL 0
347 #define B_ANSI_LABEL 1
348 #define B_IBM_LABEL 2
350 /* Size of File Address stored in STREAM_SPARSE_DATA. Do NOT change! */
351 #define SPARSE_FADDR_SIZE (sizeof(uint64_t))
353 /* Size of crypto length stored at head of crypto buffer. Do NOT change! */
354 #define CRYPTO_LEN_SIZE ((int)sizeof(uint32_t))
357 /* This is for dumb compilers/libraries like Solaris. Linux GCC
358 * does it correctly, so it might be worthwhile
359 * to remove the isascii(c) with ifdefs on such
362 #define B_ISSPACE(c) (isascii((int)(c)) && isspace((int)(c)))
363 #define B_ISALPHA(c) (isascii((int)(c)) && isalpha((int)(c)))
364 #define B_ISUPPER(c) (isascii((int)(c)) && isupper((int)(c)))
365 #define B_ISDIGIT(c) (isascii((int)(c)) && isdigit((int)(c)))
367 /* For multiplying by 10 with shift and addition */
368 #define B_TIMES10(d) ((d<<3)+(d<<1))
371 typedef void (HANDLER)();
372 typedef int (INTHANDLER)();
375 # define SETPGRP_ARGS(x, y) /* No arguments */
377 # define SETPGRP_ARGS(x, y) (x, y)
381 #define S_ISLNK(m) (((m) & S_IFM) == S_IFLNK)
384 /* Added by KES to deal with Win32 systems */
386 #define S_ISWIN32 020000
390 #define INADDR_NONE ((unsigned long) -1)
393 #ifdef TIME_WITH_SYS_TIME
394 # include <sys/time.h>
397 # ifdef HAVE_SYS_TIME_H
398 # include <sys/time.h>
416 #if defined(HAVE_WIN32)
417 typedef int64_t boffset_t;
419 typedef off_t boffset_t;
422 /* These probably should be subroutines */
424 do { int errstat; if ((errstat=rwl_writelock(&(x)))) \
425 e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock lock failure. ERR=%s\n",\
426 strerror(errstat)); \
430 do { int errstat; if ((errstat=rwl_writeunlock(&(x)))) \
431 e_msg(__FILE__, __LINE__, M_ABORT, 0, "Write lock unlock failure. ERR=%s\n",\
432 strerror(errstat)); \
435 #define LockRes() b_LockRes(__FILE__, __LINE__)
436 #define UnlockRes() b_UnlockRes(__FILE__, __LINE__)
439 #define memset(a, v, n) b_memset(__FILE__, __LINE__, a, v, n)
440 void b_memset(const char *file, int line, void *mem, int val, size_t num);
445 * The digit following Dmsg and Emsg indicates the number of substitutions in
446 * the message string. We need to do this kludge because non-GNU compilers
447 * do not handle varargs #defines.
449 /* Debug Messages that are printed */
451 #define Dmsg0(lvl, msg) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg)
452 #define Dmsg1(lvl, msg, a1) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1)
453 #define Dmsg2(lvl, msg, a1, a2) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
454 #define Dmsg3(lvl, msg, a1, a2, a3) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
455 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
456 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5) if ((lvl)<=debug_level) d_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
457 #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)
458 #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)
459 #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)
460 #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)
461 #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)
462 #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)
463 #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)
464 #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)
466 #define Dmsg0(lvl, msg)
467 #define Dmsg1(lvl, msg, a1)
468 #define Dmsg2(lvl, msg, a1, a2)
469 #define Dmsg3(lvl, msg, a1, a2, a3)
470 #define Dmsg4(lvl, msg, arg1, arg2, arg3, arg4)
471 #define Dmsg5(lvl, msg, a1, a2, a3, a4, a5)
472 #define Dmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
473 #define Dmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
474 #define Dmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
475 #define Dmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
476 #define Dmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
477 #define Dmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
481 #define Tmsg0(lvl, msg) t_msg(__FILE__, __LINE__, lvl, msg)
482 #define Tmsg1(lvl, msg, a1) t_msg(__FILE__, __LINE__, lvl, msg, a1)
483 #define Tmsg2(lvl, msg, a1, a2) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
484 #define Tmsg3(lvl, msg, a1, a2, a3) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
485 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4) t_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
486 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
487 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
488 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) t_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
489 #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)
490 #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)
491 #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)
492 #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)
493 #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)
494 #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)
496 #define Tmsg0(lvl, msg)
497 #define Tmsg1(lvl, msg, a1)
498 #define Tmsg2(lvl, msg, a1, a2)
499 #define Tmsg3(lvl, msg, a1, a2, a3)
500 #define Tmsg4(lvl, msg, arg1, arg2, arg3, arg4)
501 #define Tmsg5(lvl, msg, a1, a2, a3, a4, a5)
502 #define Tmsg6(lvl, msg, a1, a2, a3, a4, a5, a6)
503 #define Tmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7)
504 #define Tmsg8(lvl, msg, a1, a2, a3, a4, a5, a6, a7, a8)
505 #define Tmsg11(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11)
506 #define Tmsg12(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12)
507 #define Tmsg13(lvl,msg,a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13)
508 #endif /* TRACE_FILE */
512 /* Messages that are printed (uses d_msg) */
513 #define Pmsg0(lvl, msg) p_msg(__FILE__, __LINE__, lvl, msg)
514 #define Pmsg1(lvl, msg, a1) p_msg(__FILE__, __LINE__, lvl, msg, a1)
515 #define Pmsg2(lvl, msg, a1, a2) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2)
516 #define Pmsg3(lvl, msg, a1, a2, a3) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3)
517 #define Pmsg4(lvl, msg, arg1, arg2, arg3, arg4) p_msg(__FILE__, __LINE__, lvl, msg, arg1, arg2, arg3, arg4)
518 #define Pmsg5(lvl, msg, a1, a2, a3, a4, a5) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5)
519 #define Pmsg6(lvl, msg, a1, a2, a3, a4, a5, a6) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6)
520 #define Pmsg7(lvl, msg, a1, a2, a3, a4, a5, a6, a7) p_msg(__FILE__, __LINE__, lvl, msg, a1, a2, a3, a4, a5, a6, a7)
521 #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)
522 #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)
523 #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)
524 #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)
525 #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)
526 #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)
527 #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)
530 /* Daemon Error Messages that are delivered according to the message resource */
531 #define Emsg0(typ, lvl, msg) e_msg(__FILE__, __LINE__, typ, lvl, msg)
532 #define Emsg1(typ, lvl, msg, a1) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1)
533 #define Emsg2(typ, lvl, msg, a1, a2) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2)
534 #define Emsg3(typ, lvl, msg, a1, a2, a3) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3)
535 #define Emsg4(typ, lvl, msg, a1, a2, a3, a4) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4)
536 #define Emsg5(typ, lvl, msg, a1, a2, a3, a4, a5) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5)
537 #define Emsg6(typ, lvl, msg, a1, a2, a3, a4, a5, a6) e_msg(__FILE__, __LINE__, typ, lvl, msg, a1, a2, a3, a4, a5, a6)
539 /* Job Error Messages that are delivered according to the message resource */
540 #define Jmsg0(jcr, typ, lvl, msg) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
541 #define Jmsg1(jcr, typ, lvl, msg, a1) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
542 #define Jmsg2(jcr, typ, lvl, msg, a1, a2) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
543 #define Jmsg3(jcr, typ, lvl, msg, a1, a2, a3) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
544 #define Jmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
545 #define Jmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) j_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
546 #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)
548 /* Queued Job Error Messages that are delivered according to the message resource */
549 #define Qmsg0(jcr, typ, lvl, msg) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg)
550 #define Qmsg1(jcr, typ, lvl, msg, a1) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1)
551 #define Qmsg2(jcr, typ, lvl, msg, a1, a2) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2)
552 #define Qmsg3(jcr, typ, lvl, msg, a1, a2, a3) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3)
553 #define Qmsg4(jcr, typ, lvl, msg, a1, a2, a3, a4) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4)
554 #define Qmsg5(jcr, typ, lvl, msg, a1, a2, a3, a4, a5) q_msg(__FILE__, __LINE__, jcr, typ, lvl, msg, a1, a2, a3, a4, a5)
555 #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)
558 /* Memory Messages that are edited into a Pool Memory buffer */
559 #define Mmsg0(buf, msg) m_msg(__FILE__, __LINE__, buf, msg)
560 #define Mmsg1(buf, msg, a1) m_msg(__FILE__, __LINE__, buf, msg, a1)
561 #define Mmsg2(buf, msg, a1, a2) m_msg(__FILE__, __LINE__, buf, msg, a1, a2)
562 #define Mmsg3(buf, msg, a1, a2, a3) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3)
563 #define Mmsg4(buf, msg, a1, a2, a3, a4) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4)
564 #define Mmsg5(buf, msg, a1, a2, a3, a4, a5) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5)
565 #define Mmsg6(buf, msg, a1, a2, a3, a4, a5, a6) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
566 #define Mmsg7(buf, msg, a1, a2, a3, a4, a5, a6, a7) m_msg(__FILE__, __LINE__, buf, msg, a1, a2, a3, a4, a5, a6)
567 #define Mmsg8(buf,msg,a1,a2,a3,a4,a5,a6,a7,a8) m_msg(__FILE__,__LINE__,buf,msg,a1,a2,a3,a4,a5,a6)
568 #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)
569 #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)
572 /* Edit message into Pool Memory buffer -- no __FILE__ and __LINE__ */
573 int Mmsg(POOLMEM **msgbuf, const char *fmt,...);
574 int Mmsg(POOLMEM *&msgbuf, const char *fmt,...);
575 int Mmsg(POOL_MEM &msgbuf, const char *fmt,...);
579 void d_msg(const char *file, int line, int level, const char *fmt,...);
580 void p_msg(const char *file, int line, int level, const char *fmt,...);
581 void e_msg(const char *file, int line, int type, int level, const char *fmt,...);
582 void j_msg(const char *file, int line, JCR *jcr, int type, utime_t mtime, const char *fmt,...);
583 void q_msg(const char *file, int line, JCR *jcr, int type, utime_t mtime, const char *fmt,...);
584 int m_msg(const char *file, int line, POOLMEM **msgbuf, const char *fmt,...);
585 int m_msg(const char *file, int line, POOLMEM *&pool_buf, const char *fmt, ...);
588 /* Use our strdup with smartalloc */
589 #ifndef HAVE_WXCONSOLE
591 #define strdup(buf) bad_call_on_strdup_use_bstrdup(buf)
593 /* Groan, WxWidgets has its own way of doing NLS so cleanup */
598 #undef bindtextdomain
602 /* Use our fgets which handles interrupts */
604 #define fgets(x,y,z) bfgets((x), (y), (z))
606 /* Use our sscanf, which is safer and works with known sizes */
607 #define sscanf bsscanf
610 #define bstrdup(str) strcpy((char *)b_malloc(__FILE__,__LINE__,strlen((str))+1),(str))
612 #define bstrdup(str) strcpy((char *)bmalloc(strlen((str))+1),(str))
616 #define bmalloc(size) b_malloc(__FILE__, __LINE__, (size))
620 * Replace codes needed in both file routines and non-file routines
621 * Job replace codes -- in "replace"
623 #define REPLACE_ALWAYS 'a'
624 #define REPLACE_IFNEWER 'w'
625 #define REPLACE_NEVER 'n'
626 #define REPLACE_IFOLDER 'o'
628 /* This probably should be done on a machine by machine basis, but it works */
629 /* This is critical for the smartalloc routines to properly align memory */
630 #define ALIGN_SIZE (sizeof(double))
631 #define BALIGN(x) (((x) + ALIGN_SIZE - 1) & ~(ALIGN_SIZE -1))
634 /* =============================================================
635 * OS Dependent defines
636 * =============================================================
640 /* Bad news. This OS cannot handle 64 bit fseeks and ftells */
645 #if defined (__digital__) && defined (__unix__)
646 /* Tru64 - it does have fseeko and ftello , but since ftell/fseek are also 64 bit */
647 /* take this 'shortcut' */
651 #define ioctl_req_t int
658 #define ioctl_req_t int
663 * On Solaris 2.5, threads are not timesliced by default, so we need to
664 * explictly increase the conncurrency level.
667 #define set_thread_concurrency(x) thr_setconcurrency(x)
668 extern int thr_setconcurrency(int);
671 #define ioctl_req_t int
676 /* Not needed on most systems */
677 #define set_thread_concurrency(x)
681 #if defined(HAVE_DARWIN_OS) || defined(HAVE_OSF1_OS)
682 /* Apparently someone forgot to wrap getdomainname as a C function */
683 extern "C" int getdomainname(char *name, int len);
688 #if defined(HAVE_WIN32)
689 #define DEFAULT_CONFIGDIR "C:\\Documents and Settings\\All Users\\Application Data\\Bacula"
690 #define PathSeparator '\\'
692 inline bool IsPathSeparator(int ch) { return ch == '/' || ch == '\\'; }
693 inline char *first_path_separator(char *path) { return strpbrk(path, "/\\"); }
694 inline const char *first_path_separator(const char *path) { return strpbrk(path, "/\\"); }
696 extern void pause_msg(const char *file, const char *func, int line, const char *msg);
697 #define pause(msg) if (debug_level) pause_msg(__FILE__, __func__, __LINE__, (msg))
700 #define PathSeparator '/'
701 /* Define Winsock functions if we aren't on Windows */
703 #define WSA_Init() 0 /* 0 = success */
704 #define WSACleanup() 0 /* 0 = success */
706 inline bool IsPathSeparator(int ch) { return ch == '/'; }
707 inline char *first_path_separator(char *path) { return strchr(path, '/'); }
708 inline const char *first_path_separator(const char *path) { return strchr(path, '/'); }
713 /* HP-UX 11 specific workarounds */
718 /* the {get,set}domainname() functions exist in HPUX's libc.
719 * the configure script detects that correctly.
720 * the problem is no system headers declares the prototypes for these functions
723 extern "C" int getdomainname(char *name, int namelen);
724 extern "C" int setdomainname(char *name, int namelen);
726 #define ioctl_req_t int
727 #endif /* HAVE_HPUX_OS */
731 extern "C" int fchdir(int filedes);
732 extern "C" long gethostid(void);
733 extern "C" int mknod ( const char *path, int mode, dev_t device );
735 #define ioctl_req_t int
739 /* Disabled because it breaks internationalisation...
740 #undef HAVE_SETLOCALE
741 #ifdef HAVE_SETLOCALE
744 #define setlocale(x, y) ("ANSI_X3.4-1968")
746 #ifdef HAVE_NL_LANGINFO
747 #include <langinfo.h>
749 #define nl_langinfo(x) ("ANSI_X3.4-1968")
753 #endif /* _BACONFIG_H */