6 * Copyright (C) 1987 by the Massachusetts Institute of Technology
7 * For copying and distribution information, please see the file
10 * This program starts the moira server in a "clean" environment.
11 * and then waits for it to exit.
16 static char *rcsid_mr_starter_c = "$Header$";
19 #include <mit-copyright.h>
22 #include <sys/types.h>
25 #include <sys/signal.h>
26 #include <sys/ioctl.h>
27 #include <moira_site.h>
32 extern char *sys_siglist[];
43 while (wait3(&stat, WNOHANG, 0) > 0) {
44 if (WIFEXITED(stat)) {
47 "exited with code %d\n",
50 if (WIFSIGNALED(stat)) {
51 sprintf(buf, "exited on %s signal%s\n",
52 sys_siglist[stat.w_termsig],
53 (stat.w_coredump?"; Core dumped":0));
55 write(rdpipe[1], buf, strlen(buf));
65 int logf, inf, i, done, pid, tty;
68 extern char *sys_errlist[];
70 int nfds = getdtablesize();
73 signal(SIGCHLD, cleanup);
75 sprintf(buf, "%s/moira.log", SMS_DIR);
76 logf = open(buf, O_CREAT|O_WRONLY|O_APPEND, 0640);
81 inf = open("/dev/null", O_RDONLY , 0);
98 tty = open("/dev/tty");
99 ioctl(tty, TIOCNOTTY, 0);
101 sprintf(buf, "%s/%s", BIN_DIR, PROG);
103 if ((pid = fork()) == 0) {
108 for (i = 3; i <nfds; i++) close(i);
110 perror("cannot run moirad");
114 perror("moira_starter");
118 log = fdopen(logf, "w");
119 prog = fdopen(rdpipe[0], "r");
124 extern char *ctime();
129 if (fgets(buf, BUFSIZ, prog) == NULL) {
131 strcpy(buf, "Unable to read from program: ");
132 strcat(buf, sys_errlist[errno]);
137 time_s = ctime(&foo)+4;
138 time_s[strlen(time_s)-6]='\0';
139 fprintf(log, "%s %s", time_s, buf);