Annotation of 43BSDTahoe/new/news/misc/article.c, revision 1.1.1.1

1.1       root        1: /* down!honey 4/84 */
                      2: /* article msg-id [ ... msg-id ] */
                      3:  * where message-id is usually of the form [email protected],
                      4:  * and the domain in the message-id is optional.
                      5:  *
                      6:  * BUGS:
                      7:  *     Cannot handle all domains, for instance, BERKELEY.EDU.
                      8:  */
                      9: 
                     10: #define HISTORY "/usr/lib/news/history"
                     11: #define NEWSDIR "/usr/spool/news"
                     12: 
                     13: char   *formats[] = {          /* add as appropriate */
                     14:        "<%s.uucp>",
                     15:        "<%s>",
                     16:        "<%s.arpa>",
                     17:        "<%s.oz>",
                     18:        0
                     19: };
                     20: 
                     21: #include <stdio.h>
                     22: #include <sysexits.h>
                     23: #include <ctype.h>
                     24: 
                     25: typedef struct {
                     26:        char    *dptr;
                     27:        int     dsize;
                     28: } datum;
                     29: 
                     30: #if defined(USG_INDEX)
                     31: /* S3 or S5 both call strchr() what 4.X BSD calls index */
                     32: #define index strchr
                     33: #endif
                     34: 
                     35: long   lseek();
                     36: char   *index();
                     37: datum  fetch(), dofetch();
                     38: 
                     39: main(argc, argv)
                     40: char **argv;
                     41: {
                     42:        int     fd;
                     43:        char    buf[BUFSIZ], *ptr1, *ptr2;
                     44:        datum   content;
                     45: 
                     46:        if ((fd = open(HISTORY, 0)) < 0) {
                     47:                perror(HISTORY);
                     48:                exit(EX_UNAVAILABLE);
                     49:        }
                     50:        if (dbminit(HISTORY) < 0) {
                     51:                fprintf(stderr, "dbm error\n");
                     52:                exit(EX_UNAVAILABLE);
                     53:        }
                     54:        for (--argc, argv++; argc; --argc, argv++) {
                     55:                long    foff;           /* file offset */
                     56:                content = dofetch(*argv);
                     57:                if (content.dptr == 0) {
                     58:                        printf("%s: No such key\n", *argv);
                     59:                        continue;
                     60:                }
                     61: 
                     62:                /* Correct a machine dependent bug here, caused         */
                     63:                /* because the lseek offset pointed to by dptr might    */
                     64:                /* not be long-aligned.                                 */
                     65:                /* Guy Harris suggested bug fix to prevent core drop.   */
                     66:                /* This bug was written up in net.bugs.4bsd and         */
                     67:                /* cross-posted to net.news.b                           */
                     68:                bcopy(content.dptr, (char *)&foff, sizeof foff);
                     69: 
                     70:                if (lseek(fd, foff, 0) < 0)
                     71:                        continue;
                     72:                if (read(fd, buf, sizeof buf) <= 0)
                     73:                        continue;
                     74: 
                     75:                /*
                     76:                 * To understand this piece of code, you must understand
                     77:                 * that the format of lines in the history file are either:
                     78:                 * <msg-id>TAB<date>SPACE<time>TABthenNL
                     79:                 * <msg-id>TAB<date>SPACE<time>TAB<spoolpathname>NL
                     80:                 * <msg-id>TAB<date>SPACE<time>TAB<spoolpathname>SPACE...
                     81:                 * The first format occurs when expired,
                     82:                 * the second form occurs when exactly one pathname,
                     83:                 * and the third occurs when cross-postings.
                     84:                 */
                     85:                 *
                     86: 
                     87:                /* remove end of line */
                     88:                if ((ptr2 = index(buf, '\n')) == 0)
                     89:                        continue;
                     90:                *ptr2 = '\0';
                     91: 
                     92:                /* The 4th field contains the article file name */
                     93: 
                     94:                if ((ptr1 = index(buf, '\t')) == 0)
                     95:                        continue;
                     96:                ptr1++;
                     97: 
                     98:                /* ptr1 now at begin of field 2 - the date field */
                     99: 
                    100:                if ((ptr1 = index(ptr1, '\t')) == 0)
                    101:                        continue;
                    102:                ptr1++;
                    103: 
                    104:                /* ptr1 now at begin of field 4 - the article spool pathname */
                    105:                /* or the newline that has been converted to a NULL */
                    106: 
                    107:                /* change net.unix/231 to net/unix/231 */
                    108:                for (ptr2 = ptr1; ptr2 = index(ptr2, '.'); *ptr2 = '/')
                    109:                        ;
                    110: 
                    111:                /* terminate after the first pathname, if any */
                    112:                if ((ptr2 = index(ptr1, ' ')) != NULL)
                    113:                        *ptr2 = '\0';
                    114: 
                    115:                if (*ptr1 == '\0')
                    116:                        printf("expired\n");
                    117:                else
                    118:                        printf("%s/%s\n", NEWSDIR, ptr1);
                    119:        }
                    120:        exit(EX_OK);
                    121: }
                    122: 
                    123: datum
                    124: dofetch(str)
                    125: char   *str;
                    126: {
                    127:        datum   key, content;
                    128:        char    buf[BUFSIZ], **fmt;
                    129:        register char *rcp;
                    130: 
                    131:        for (fmt = formats; *fmt; fmt++) {
                    132:                sprintf(buf, *fmt, str);
                    133:                rcp = buf - 1;
                    134:                while (*++rcp)
                    135:                        if (isupper(*rcp))
                    136:                                *rcp = tolower(*rcp);
                    137:                key.dptr = buf;
                    138:                key.dsize = strlen(buf) + 1;
                    139:                content = fetch(key);
                    140:                if (content.dptr)
                    141:                        break;
                    142:        }
                    143:        return(content);
                    144: }

unix.superglobalmegacorp.com

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