1 /*************************************************
2 * Exim - an Internet mail transport agent *
3 *************************************************/
5 /* Copyright (c) University of Cambridge 1995 - 2009 */
6 /* See the file NOTICE for conditions of use and distribution. */
8 /* This file is not part of the main Exim code. There are little bits of test
9 code for some of Exim's modules, and when they are used, the module they are
10 testing may call other main Exim functions that are not available and/or
11 should not be used in a test. The classic case is log_write(). This module
12 contains dummy versions of such functions - well not really dummies, more like
20 /* We don't have the full Exim headers dragged in, but this function
21 is used for debugging output. */
23 extern gstring * string_vformat(gstring *, unsigned, const char *, va_list);
26 /*************************************************
27 * Handle calls to write the log *
28 *************************************************/
30 /* The message gets written to stderr when log_write() is called from a
31 utility. The message always gets '\n' added on the end of it.
34 selector not relevant when running a utility
35 flags not relevant when running a utility
36 format a printf() format
37 ... arguments for format
43 log_write(unsigned int selector, int flags, char *format, ...)
47 vfprintf(stderr, format, ap);
48 fprintf(stderr, "\n");
53 /*************************************************
54 * Handle calls to print debug output *
55 *************************************************/
57 /* The message just gets written to stderr.
58 We use tainted memory to format into just so that we can handle
62 format a printf() format
63 ... arguments for format
69 debug_printf(char *format, ...)
72 rmark reset_point = store_mark();
73 gstring * g = string_get_tainted(1024, TRUE);
77 if (!string_vformat(g, 0, format, ap))
79 char * s = "**** debug string overflowed buffer ****\n";
80 char * p = CS g->s + g->ptr;
81 int maxlen = g->size - (int)strlen(s) - 3;
82 if (p > g->s + maxlen) p = g->s + maxlen;
83 if (p > g->s && p[-1] != '\n') *p++ = '\n';
87 fprintf(stderr, "%s", string_from_gstring(g));
89 store_reset(reset_point);
95 /*************************************************
97 *************************************************/
99 extern int sigalrm_seen;
102 sigalrm_handler(int sig)
109 /*************************************************
111 *************************************************/
114 header_checkname(void *h, char *name, int len)
120 directory_make(char *parent, char *name, int mode, int panic)
125 host_build_sender_fullhost(void) { }
127 /* This one isn't needed for test_host */
131 host_ntoa(int type, const void *arg, char *buffer, int *portptr)
138 /* End of dummies.c */