/* * Copyright (c) 1986, 1987 Regents of the University of California. * All rights reserved. * * %sccs.include.redist.c% */ #ifndef lint static char sccsid[] = "@(#)redist.c 5.12 (Berkeley) 04/01/91"; #endif /* not lint */ #include #include #include #include #include #include "bug.h" #include "pathnames.h" /* * redist -- * Redistribute a bug report to those people indicated in the * redistribution list file. */ redist() { extern FILE *dfp; /* dist file fp */ extern char pfile[]; /* permanent bug file */ register char *C1, *C2; FILE *pf, *popen(); int group; char *p, *index(); (void)sprintf(bfr, "%s/%s", dir, DIST_FILE); if (!freopen(bfr, "r", stdin)) return; for (pf = NULL, group = 0; fgets(bfr, sizeof(bfr), stdin);) { if (C1 = index(bfr, '\n')) *C1 = '\0'; nextline: if (*bfr == COMMENT || isspace(*bfr) || !(C1 = index(bfr, ':'))) continue; *C1 = EOS; if (!strcmp(bfr, folder) || !strcmp(bfr, "all")) { for (++C1; *C1 && (*C1 == ' ' || *C1 == '\t'); ++C1); if (!*C1) /* if empty list */ continue; if (!pf) { if (!(pf = popen(MAIL_CMD, "w"))) error("sendmail pipe failed.", CHN); if (mailhead[SUBJ_TAG].found) fprintf(pf, "%s", mailhead[SUBJ_TAG].line); else fprintf(pf, "Subject: Untitled Bug Report\n"); if (!mailhead[TO_TAG].line) { if (mailhead[APPAR_TO_TAG].line) fprintf(pf, "To%s", index(mailhead[APPAR_TO_TAG].line, ':')); else fprintf(pf, "To: %s\n", BUGS_ID); } fputs("Resent-To: ", pf); } /* * write out first entry, then succeeding entries * backward compatible, handles back slashes at end * of line */ if (group++) fputs(", ", pf); for (;;) { if (C2 = index(C1, '\\')) *C2 = EOS; fputs(C1, pf); if (!fgets(bfr, sizeof(bfr), stdin)) break; if (C1 = index(bfr, '\n')) *C1 = '\0'; if (*bfr != ' ' && *bfr != '\t') goto nextline; for (C1 = bfr; *C1 && (*C1 == ' ' || *C1 == '\t'); ++C1); } } } if (!pf) return; putc('\n', pf); rewind(dfp); /* add Reference header and copy bug report out */ while (fgets(bfr, sizeof(bfr), dfp) && *bfr != '\n') fputs(bfr, pf); fprintf(pf, "\n%sReference: %s\n\n", mailhead[INDX_TAG].line, pfile); while (fgets(bfr, sizeof(bfr), dfp)) fputs(bfr, pf); (void)pclose(pf); }