2 * Copyright (c) 1998,1999,2000
3 * Traakan, Inc., Los Altos, CA
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice unmodified, this list of conditions, and the following
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
39 #ifndef NDMOS_OPTION_NO_CONTROL_AGENT
41 start_index_file (void)
43 if (I_index_file && strcmp (I_index_file, "-") != 0) {
46 if (atoi(I_index_file) != 0) {
47 ndmjob_log (1, "Writing index (-I%s)", I_index_file);
48 ifp = fdopen(atoi(I_index_file), "w");
50 ndmjob_log (1, "Writing index (-I%s)", I_index_file);
51 ifp = fopen (I_index_file, "w");
54 error_byebye ("can't open -I logfile");
57 fprintf (ifp, "##ndmjob -I\n");
66 sort_index_file (void)
68 if (I_index_file && strcmp (I_index_file, "-") != 0 &&
69 atoi(I_index_file) == 0) {
72 fprintf (index_fp, "##ndmjob -J\n"); /* sorts to 2nd line */
74 index_fp = stderr; /* in case anything else happens */
76 sprintf (cmd, "LC_ALL=C sort %s -o %s\n", I_index_file, I_index_file);
77 ndmjob_log (3, "sort command: %s", cmd);
78 ndmjob_log (1, "sorting index");
80 error_byebye ("sort index failed");
81 ndmjob_log (1, "sort index done");
86 #endif /* !NDMOS_OPTION_NO_CONTROL_AGENT */
89 error_byebye (char *fmt, ...)
95 vsnprintf (buf, sizeof(buf), fmt, ap);
97 ndmjob_log (0, "FATAL: %s", buf);
98 fprintf (stderr, "%s: %s\n", progname, buf);
103 ndmjob_log_deliver (struct ndmlog *log, char *tag, int lev, char *msg)
107 if (the_mode == 'D') {
110 sprintf (buf, "%s(%d)", tag, (int)getpid());
111 sprintf (tagbuf, "%-11s", buf);
113 sprintf (tagbuf, "%-4s", tag);
116 if (d_debug >= lev) {
117 g_debug ("%s %s", tagbuf, msg);
120 if (v_verbose >= lev) {
121 printf ("'%s'\n", msg);
126 #ifndef NDMOS_OPTION_NO_CONTROL_AGENT
128 ndmjob_ixlog_deliver (struct ndmlog *log, char *tag, int lev, char *msg)
130 fprintf (index_fp, "%s %s\n", tag, msg);
131 fflush (index_fp); /* this doesn't change the run time */
133 #endif /* !NDMOS_OPTION_NO_CONTROL_AGENT */
136 ndmjob_log (int lev, char *fmt, ...)
142 vsnprintf (buf, sizeof(buf), fmt, ap);
145 ndmjob_log_deliver (&the_param.log, the_param.log_tag, lev, buf);