Annotation of 43BSDReno/libexec/bugfiler/reply.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1986, 1987 Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms are permitted
                      6:  * provided that: (1) source distributions retain this entire copyright
                      7:  * notice and comment, and (2) distributions including binaries display
                      8:  * the following acknowledgement:  ``This product includes software
                      9:  * developed by the University of California, Berkeley and its contributors''
                     10:  * in the documentation or other materials provided with the distribution
                     11:  * and in all advertising materials mentioning features or use of this
                     12:  * software. Neither the name of the University nor the names of its
                     13:  * contributors may be used to endorse or promote products derived
                     14:  * from this software without specific prior written permission.
                     15:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
                     16:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
                     17:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     18:  */
                     19: 
                     20: #ifndef lint
                     21: static char sccsid[] = "@(#)reply.c    5.8 (Berkeley) 6/1/90";
                     22: #endif /* not lint */
                     23: 
                     24: #include <bug.h>
                     25: #include <sys/file.h>
                     26: #include <stdio.h>
                     27: #include "pathnames.h"
                     28: 
                     29: /*
                     30:  * reply --
                     31:  *     tell the user we got their silly little bug report
                     32:  */
                     33: reply()
                     34: {
                     35:        register char   *C,                     /* traveling pointer */
                     36:                        *to;                    /* who we're replying to */
                     37:        register int    afd,                    /* ack file descriptor */
                     38:                        rval;                   /* return value */
                     39:        FILE    *pf,                            /* pipe pointer */
                     40:                *popen();
                     41:        char    *index();
                     42: 
                     43:        if (mailhead[RPLY_TAG].found) {
                     44:                for (C = mailhead[RPLY_TAG].line + mailhead[RPLY_TAG].len;*C != '\n' && (*C == ' ' || *C == '\t');++C);
                     45:                if (*C)
                     46:                        goto gotone;
                     47:        }
                     48:        if (mailhead[FROM_TAG].found) {
                     49:                for (C = mailhead[FROM_TAG].line + mailhead[FROM_TAG].len;*C != '\n' && (*C == ' ' || *C == '\t');++C);
                     50:                if (*C)
                     51:                        goto gotone;
                     52:        }
                     53:        if (mailhead[CFROM_TAG].found) {
                     54:                for (C = mailhead[CFROM_TAG].line + mailhead[CFROM_TAG].len;*C != '\n' && (*C == ' ' || *C == '\t');++C);
                     55:                if (*C)
                     56:                        goto gotone;
                     57:        }
                     58:        return;
                     59: 
                     60:        /* if it's a foo <XXX>, get the XXX, else get foo (first string) */
                     61: gotone:        if (to = index(C, '<'))
                     62:                for (C = ++to;*C != '\n' && *C != ' ' && *C != '\t' && *C != '>';++C);
                     63:        else {
                     64:                to = C;
                     65:                for (to = C++;*C != '\n' && *C != ' ' && *C != '\t';++C);
                     66:        }
                     67:        *C = EOS;
                     68: 
                     69:        if (!(pf = popen(MAIL_CMD, "w")))
                     70:                error("sendmail pipe failed.", CHN);
                     71: 
                     72:        fprintf(pf, "Reply-To: %s\nFrom: %s (Bugs Bunny)\nTo: %s\n", BUGS_HOME, BUGS_HOME, to);
                     73:        if (mailhead[SUBJ_TAG].found)
                     74:                fprintf(pf, "Subject: Re:%s", mailhead[SUBJ_TAG].line + mailhead[SUBJ_TAG].len);
                     75:        else
                     76:                fputs("Subject: Bug report acknowledgement.\n", pf);
                     77:        if (mailhead[DATE_TAG].found)
                     78:                fprintf(pf, "In-Acknowledgement-Of: Your message of %s", mailhead[DATE_TAG].line + mailhead[DATE_TAG].len);
                     79:        if (mailhead[MSG_TAG].found)
                     80:                fprintf(pf, "\t\t%s", mailhead[MSG_TAG].line);
                     81:        fputs("Precedence: bulk\n\n", pf);      /* vacation(1) uses this... */
                     82:        fflush(pf);
                     83: 
                     84:        (void)sprintf(bfr, "%s/%s", dir, ACK_FILE);
                     85:        if ((afd = open(bfr, O_RDONLY, 0)) >= 0) {
                     86:                while ((rval = read(afd, bfr, sizeof(bfr))) != ERR && rval)
                     87:                        (void)write(fileno(pf), bfr, rval);
                     88:                (void)close(afd);
                     89:        }
                     90:        pclose(pf);
                     91: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.