Annotation of researchv10no/cmd/sed/sed1.c, revision 1.1.1.1

1.1       root        1: #include       <stdio.h>
                      2: #include "sed.h"
                      3: 
                      4: #define Read(f, buf, n)        (fflush(stdout), read(f, buf, n))
                      5: uchar *lformat();
                      6: 
                      7: execute(file)
                      8: uchar *file;
                      9: {
                     10:        register uchar *p1, *p2;
                     11:        register union reptr    *ipc;
                     12:        int     c;
                     13:        long    l;
                     14:        uchar   *execp;
                     15: 
                     16:        if (file) {
                     17:                if ((f = open(file, 0)) < 0) {
                     18:                        fprintf(stderr, "sed: Can't open %s\n", file);
                     19:                }
                     20:        } else
                     21:                f = 0;
                     22: 
                     23:        ebp = ibuf;
                     24:        cbp = ibuf;
                     25: 
                     26:        if(pending) {
                     27:                ipc = pending;
                     28:                pending = 0;
                     29:                goto yes;
                     30:        }
                     31: 
                     32:        for(;;) {
                     33:                if((execp = gline(linebuf)) == badp) {
                     34:                        close(f);
                     35:                        return;
                     36:                }
                     37:                spend = execp;
                     38: 
                     39:                for(ipc = ptrspace; ipc->r1.command; ) {
                     40: 
                     41:                        p1 = ipc->r1.ad1;
                     42:                        p2 = ipc->r1.ad2;
                     43: 
                     44:                        if(p1) {
                     45: 
                     46:                                if(ipc->r1.inar) {
                     47:                                        if(*p2 == CEND) {
                     48:                                                p1 = 0;
                     49:                                        } else if(*p2 == CLNUM) {
                     50:                                                l = p2[1]&0377
                     51:                                                        | ((p2[2]&0377)<<8)
                     52:                                                        | ((p2[3]&0377)<<16)
                     53:                                                        | ((p2[4]&0377)<<24);
                     54:                                                if(lnum > l) {
                     55:                                                        ipc->r1.inar = 0;
                     56:                                                        if(ipc->r1.negfl)
                     57:                                                                goto yes;
                     58:                                                        ipc++;
                     59:                                                        continue;
                     60:                                                }
                     61:                                                if(lnum == l) {
                     62:                                                        ipc->r1.inar = 0;
                     63:                                                }
                     64:                                        } else if(match(p2, 0)) {
                     65:                                                ipc->r1.inar = 0;
                     66:                                        }
                     67:                                } else if(*p1 == CEND) {
                     68:                                        if(!dolflag) {
                     69:                                                if(ipc->r1.negfl)
                     70:                                                        goto yes;
                     71:                                                ipc++;
                     72:                                                continue;
                     73:                                        }
                     74: 
                     75:                                } else if(*p1 == CLNUM) {
                     76:                                        l = p1[1]&0377
                     77:                                                | ((p1[2]&0377)<<8)
                     78:                                                | ((p1[3]&0377)<<16)
                     79:                                                | ((p1[4]&0377)<<24);
                     80:                                        if(lnum != l) {
                     81:                                                if(ipc->r1.negfl)
                     82:                                                        goto yes;
                     83:                                                ipc++;
                     84:                                                continue;
                     85:                                        }
                     86:                                        if(p2)
                     87:                                                ipc->r1.inar = 1;
                     88:                                } else if(match(p1, 0)) {
                     89:                                        if(p2)
                     90:                                                ipc->r1.inar = 1;
                     91:                                } else {
                     92:                                        if(ipc->r1.negfl)
                     93:                                                goto yes;
                     94:                                        ipc++;
                     95:                                        continue;
                     96:                                }
                     97:                        }
                     98: 
                     99:                        if(ipc->r1.negfl) {
                    100:                                ipc++;
                    101:                                continue;
                    102:                        }
                    103:        yes:
                    104:                        command(ipc);
                    105: 
                    106:                        if(delflag)
                    107:                                break;
                    108: 
                    109:                        if(jflag) {
                    110:                                jflag = 0;
                    111:                                if((ipc = ipc->r2.lb1) == 0) {
                    112:                                        ipc = ptrspace;
                    113:                                        break;
                    114:                                }
                    115:                        } else
                    116:                                ipc++;
                    117: 
                    118:                }
                    119:                if(!nflag && !delflag) {
                    120:                        for(p1 = linebuf; p1 < spend; p1++)
                    121:                                putc(*p1, stdout);
                    122:                        putc('\n', stdout);
                    123:                }
                    124: 
                    125:                if(aptr > abuf) {
                    126:                        arout();
                    127:                }
                    128: 
                    129:                delflag = 0;
                    130: 
                    131:        }
                    132: }
                    133: match(expbuf, gf)
                    134: uchar  *expbuf;
                    135: {
                    136:        register uchar  *p1, *p2;
                    137:        register c;
                    138: 
                    139:        if(gf) {
                    140:                if(*expbuf)     return(0);
                    141:                p1 = linebuf;
                    142:                p2 = genbuf;
                    143:                while(*p1++ = *p2++);
                    144:                locs = p1 = loc2;
                    145:        } else {
                    146:                p1 = linebuf;
                    147:                locs = 0;
                    148:        }
                    149: 
                    150:        p2 = expbuf;
                    151:        if(*p2++) {
                    152:                loc1 = p1;
                    153:                if(*p2 == CCHR && p2[1] != *p1)
                    154:                        return(0);
                    155:                return(advance(p1, p2));
                    156:        }
                    157: 
                    158:        /* fast check for first character */
                    159: 
                    160:        if(*p2 == CCHR) {
                    161:                c = p2[1];
                    162:                do {
                    163:                        if(*p1 != c)
                    164:                                continue;
                    165:                        if(advance(p1, p2)) {
                    166:                                loc1 = p1;
                    167:                                return(1);
                    168:                        }
                    169:                } while(*p1++);
                    170:                return(0);
                    171:        }
                    172: 
                    173:        do {
                    174:                if(advance(p1, p2)) {
                    175:                        loc1 = p1;
                    176:                        return(1);
                    177:                }
                    178:        } while(*p1++);
                    179:        return(0);
                    180: }
                    181: advance(alp, aep)
                    182: uchar  *alp, *aep;
                    183: {
                    184:        register uchar *lp, *ep, *curlp;
                    185:        uchar   c;
                    186:        uchar *bbeg;
                    187:        int     ct;
                    188: 
                    189: /*fprintf(stderr, "*lp = %c, %o\n*ep = %c, %o\n", *lp, *lp, *ep, *ep); /*DEBUG*/
                    190: 
                    191:        lp = alp;
                    192:        ep = aep;
                    193:        for (;;) switch (*ep++) {
                    194: 
                    195:        case CCHR:
                    196:                if (*ep++ == *lp++)
                    197:                        continue;
                    198:                return(0);
                    199: 
                    200:        case CDOT:
                    201:                if (*lp++)
                    202:                        continue;
                    203:                return(0);
                    204: 
                    205:        case CNL:
                    206:        case CDOL:
                    207:                if (*lp == 0)
                    208:                        continue;
                    209:                return(0);
                    210: 
                    211:        case CEOF:
                    212:                loc2 = lp;
                    213:                return(1);
                    214: 
                    215:        case CCL:
                    216:                c = *lp++;
                    217:                if(ep[c>>3] & bittab[c & 07]) {
                    218:                        ep += 32;
                    219:                        continue;
                    220:                }
                    221:                return(0);
                    222: 
                    223:        case CBRA:
                    224:                braslist[*ep++] = lp;
                    225:                continue;
                    226: 
                    227:        case CKET:
                    228:                braelist[*ep++] = lp;
                    229:                continue;
                    230: 
                    231:        case CBACK:
                    232:                bbeg = braslist[*ep];
                    233:                ct = braelist[*ep++] - bbeg;
                    234: 
                    235:                if(ecmp(bbeg, lp, ct)) {
                    236:                        lp += ct;
                    237:                        continue;
                    238:                }
                    239:                return(0);
                    240: 
                    241:        case CBACK|STAR:
                    242:                bbeg = braslist[*ep];
                    243:                ct = braelist[*ep++] - bbeg;
                    244:                curlp = lp;
                    245:                while(ecmp(bbeg, lp, ct))
                    246:                        lp += ct;
                    247: 
                    248:                while(lp >= curlp) {
                    249:                        if(advance(lp, ep))     return(1);
                    250:                        lp -= ct;
                    251:                }
                    252:                return(0);
                    253: 
                    254: 
                    255:        case CDOT|STAR:
                    256:                curlp = lp;
                    257:                while (*lp++);
                    258:                goto star;
                    259: 
                    260:        case CCHR|STAR:
                    261:                curlp = lp;
                    262:                while (*lp++ == *ep);
                    263:                ep++;
                    264:                goto star;
                    265: 
                    266:        case CCL|STAR:
                    267:                curlp = lp;
                    268:                do {
                    269:                        c = *lp++;
                    270:                } while(ep[c>>3] & bittab[c & 07]);
                    271:                ep += 32;
                    272:                goto star;
                    273: 
                    274:        star:
                    275:                if(--lp == curlp) {
                    276:                        continue;
                    277:                }
                    278: 
                    279:                if(*ep == CCHR) {
                    280:                        c = ep[1];
                    281:                        do {
                    282:                                if(*lp != c)
                    283:                                        continue;
                    284:                                if(advance(lp, ep))
                    285:                                        return(1);
                    286:                        } while(lp-- > curlp);
                    287:                        return(0);
                    288:                }
                    289: 
                    290:                if(*ep == CBACK) {
                    291:                        c = *(braslist[ep[1]]);
                    292:                        do {
                    293:                                if(*lp != c)
                    294:                                        continue;
                    295:                                if(advance(lp, ep))
                    296:                                        return(1);
                    297:                        } while(lp-- > curlp);
                    298:                        return(0);
                    299:                }
                    300: 
                    301:                do {
                    302:                        if(lp == locs)  break;
                    303:                        if (advance(lp, ep))
                    304:                                return(1);
                    305:                } while (lp-- > curlp);
                    306:                return(0);
                    307: 
                    308:        default:
                    309:                fprintf(stderr, "sed:  RE botch, %o\n", *--ep);
                    310:                exit(1);
                    311:        }
                    312: }
                    313: substitute(ipc)
                    314: union reptr    *ipc;
                    315: {
                    316:        register uchar  *oloc2;
                    317: 
                    318:        if(match(ipc->r1.re1, 0)) {
                    319: 
                    320:                sflag = 1;
                    321:                if(!ipc->r1.gfl) {
                    322:                        dosub(ipc->r1.rhs);
                    323:                        return(1);
                    324:                }
                    325: 
                    326:                oloc2 = NULL;
                    327:                do {
                    328:                        if(oloc2 == loc2) {
                    329:                                loc2++;
                    330:                                continue;
                    331:                        } else {
                    332:                                dosub(ipc->r1.rhs);
                    333:                                if(*loc2 == 0)
                    334:                                        break;
                    335:                                oloc2 = loc2;
                    336:                        }
                    337:                } while(match(ipc->r1.re1, 1));
                    338:                return(1);
                    339:        }
                    340:        return(0);
                    341: }
                    342: 
                    343: dosub(rhsbuf)
                    344: uchar  *rhsbuf;
                    345: {
                    346:        register uchar *lp, *sp, *rp;
                    347:        int c;
                    348: 
                    349:        lp = linebuf;
                    350:        sp = genbuf;
                    351:        rp = rhsbuf;
                    352:        while (lp < loc1)
                    353:                *sp++ = *lp++;
                    354:        while(c = *rp++) {
                    355:                if (c == '\\') {
                    356:                        c = *rp++;
                    357:                        if (c >= '1' && c < NBRA+'1') {
                    358:                                sp = place(sp, braslist[c-'1'], braelist[c-'1']);
                    359:                                continue;
                    360:                        }
                    361:                } else if(c == '&') {
                    362:                                sp = place(sp, loc1, loc2);
                    363:                                continue;
                    364:                }
                    365:                *sp++ = c;
                    366:                if (sp >= &genbuf[LBSIZE])
                    367:                        fprintf(stderr, "sed: Output line too long.\n");
                    368:        }
                    369:        lp = loc2;
                    370:        loc2 = sp - genbuf + linebuf;
                    371:        while (*sp++ = *lp++)
                    372:                if (sp >= &genbuf[LBSIZE]) {
                    373:                        fprintf(stderr, "sed: Output line too long.\n");
                    374:                }
                    375:        lp = linebuf;
                    376:        sp = genbuf;
                    377:        while (*lp++ = *sp++);
                    378:        spend = lp-1;
                    379: }
                    380: uchar  *place(asp, al1, al2)
                    381: uchar  *asp, *al1, *al2;
                    382: {
                    383:        register uchar *sp, *l1, *l2;
                    384: 
                    385:        sp = asp;
                    386:        l1 = al1;
                    387:        l2 = al2;
                    388:        while (l1 < l2) {
                    389:                *sp++ = *l1++;
                    390:                if (sp >= &genbuf[LBSIZE])
                    391:                        fprintf(stderr, "sed: Output line too long.\n");
                    392:        }
                    393:        return(sp);
                    394: }
                    395: 
                    396: command(ipc)
                    397: union reptr    *ipc;
                    398: {
                    399:        register int    i;
                    400:        register uchar  *p1, *p2;
                    401:        uchar   *execp;
                    402: 
                    403: 
                    404:        switch(ipc->r1.command) {
                    405: 
                    406:                case ACOM:
                    407:                        *aptr++ = ipc;
                    408:                        if(aptr >= &abuf[ABUFSIZE]) {
                    409:                                fprintf(stderr, "sed: Too many appends after line %ld\n",
                    410:                                        lnum);
                    411:                        }
                    412:                        *aptr = 0;
                    413:                        break;
                    414: 
                    415:                case CCOM:
                    416:                        delflag = 1;
                    417:                        if(!ipc->r1.inar || dolflag) {
                    418:                                for(p1 = ipc->r1.re1; *p1; )
                    419:                                        putc(*p1++, stdout);
                    420:                                putc('\n', stdout);
                    421:                        }
                    422:                        break;
                    423:                case DCOM:
                    424:                        delflag++;
                    425:                        break;
                    426:                case CDCOM:
                    427:                        p1 = p2 = linebuf;
                    428: 
                    429:                        while(*p1 != '\n') {
                    430:                                if(*p1++ == 0) {
                    431:                                        delflag++;
                    432:                                        return;
                    433:                                }
                    434:                        }
                    435: 
                    436:                        p1++;
                    437:                        while(*p2++ = *p1++);
                    438:                        spend = p2-1;
                    439:                        jflag++;
                    440:                        break;
                    441: 
                    442:                case EQCOM:
                    443:                        fprintf(stdout, "%ld\n", lnum);
                    444:                        break;
                    445: 
                    446:                case GCOM:
                    447:                        p1 = linebuf;
                    448:                        p2 = holdsp;
                    449:                        while(*p1++ = *p2++);
                    450:                        spend = p1-1;
                    451:                        break;
                    452: 
                    453:                case CGCOM:
                    454:                        *spend++ = '\n';
                    455:                        p1 = spend;
                    456:                        p2 = holdsp;
                    457:                        while(*p1++ = *p2++)
                    458:                                if(p1 >= lbend)
                    459:                                        break;
                    460:                        spend = p1-1;
                    461:                        break;
                    462: 
                    463:                case HCOM:
                    464:                        p1 = holdsp;
                    465:                        p2 = linebuf;
                    466:                        while(*p1++ = *p2++);
                    467:                        hspend = p1-1;
                    468:                        break;
                    469: 
                    470:                case CHCOM:
                    471:                        *hspend++ = '\n';
                    472:                        p1 = hspend;
                    473:                        p2 = linebuf;
                    474:                        while(*p1++ = *p2++)
                    475:                                if(p1 >= hend)
                    476:                                        break;
                    477:                        hspend = p1-1;
                    478:                        break;
                    479: 
                    480:                case ICOM:
                    481:                        for(p1 = ipc->r1.re1; *p1; )
                    482:                                putc(*p1++, stdout);
                    483:                        putc('\n', stdout);
                    484:                        break;
                    485: 
                    486:                case BCOM:
                    487:                        jflag = 1;
                    488:                        break;
                    489: 
                    490:                case LCOM:
                    491:                        p1 = linebuf;
                    492:                        p2 = genbuf;
                    493:                        while(*p1) {
                    494:                                p2 = lformat(*p1++ & 0377, p2);
                    495:                                if(p2>lcomend && *p1) {
                    496:                                        *p2 = 0;
                    497:                                        fprintf(stdout, "%s\\\n", genbuf);
                    498:                                        p2 = genbuf;
                    499:                                }
                    500:                        }
                    501:                        if(p2>genbuf && (p1[-1]==' '||p1[-1]=='\n'))
                    502:                                        p2 = lformat('\n', p2);
                    503:                        *p2 = 0;
                    504:                        fprintf(stdout, "%s\n", genbuf);
                    505:                        break;
                    506: 
                    507:                case NCOM:
                    508:                        if(!nflag) {
                    509:                                for(p1 = linebuf; p1 < spend; p1++)
                    510:                                        putc(*p1, stdout);
                    511:                                putc('\n', stdout);
                    512:                        }
                    513: 
                    514:                        if(aptr > abuf)
                    515:                                arout();
                    516:                        if((execp = gline(linebuf)) == badp) {
                    517:                                pending = ipc;
                    518:                                delflag = 1;
                    519:                                break;
                    520:                        }
                    521:                        spend = execp;
                    522: 
                    523:                        break;
                    524:                case CNCOM:
                    525:                        if(aptr > abuf)
                    526:                                arout();
                    527:                        *spend++ = '\n';
                    528:                        if((execp = gline(spend)) == badp) {
                    529:                                pending = ipc;
                    530:                                delflag = 1;
                    531:                                break;
                    532:                        }
                    533:                        spend = execp;
                    534:                        break;
                    535: 
                    536:                case PCOM:
                    537:                        for(p1 = linebuf; p1 < spend; p1++)
                    538:                                putc(*p1, stdout);
                    539:                        putc('\n', stdout);
                    540:                        break;
                    541:                case CPCOM:
                    542:        cpcom:
                    543:                        for(p1 = linebuf; *p1 != '\n' && *p1 != '\0'; )
                    544:                                putc(*p1++, stdout);
                    545:                        putc('\n', stdout);
                    546:                        break;
                    547: 
                    548:                case QCOM:
                    549:                        if(!nflag) {
                    550:                                for(p1 = linebuf; p1 < spend; p1++)
                    551:                                        putc(*p1, stdout);
                    552:                                putc('\n', stdout);
                    553:                        }
                    554:                        if(aptr > abuf) arout();
                    555:                        fclose(stdout);
                    556:                        lseek(f,(long)(cbp-ebp),2);
                    557:                        exit(0);
                    558:                case RCOM:
                    559: 
                    560:                        *aptr++ = ipc;
                    561:                        if(aptr >= &abuf[ABUFSIZE])
                    562:                                fprintf(stderr, "sed: Too many reads after line%ld\n",
                    563:                                        lnum);
                    564: 
                    565:                        *aptr = 0;
                    566: 
                    567:                        break;
                    568: 
                    569:                case SCOM:
                    570:                        i = substitute(ipc);
                    571:                        if(ipc->r1.pfl && i)
                    572:                                if(ipc->r1.pfl == 1) {
                    573:                                        for(p1 = linebuf; p1 < spend; p1++)
                    574:                                                putc(*p1, stdout);
                    575:                                        putc('\n', stdout);
                    576:                                }
                    577:                                else
                    578:                                        goto cpcom;
                    579:                        if(i && ipc->r1.fcode)
                    580:                                goto wcom;
                    581:                        break;
                    582: 
                    583:                case TCOM:
                    584:                        if(sflag == 0)  break;
                    585:                        sflag = 0;
                    586:                        jflag = 1;
                    587:                        break;
                    588: 
                    589:                wcom:
                    590:                case WCOM:
                    591:                        fprintf(ipc->r1.fcode, "%s\n", linebuf);
                    592:                        fflush(ipc->r1.fcode);
                    593:                        break;
                    594:                case XCOM:
                    595:                        p1 = linebuf;
                    596:                        p2 = genbuf;
                    597:                        while(*p2++ = *p1++);
                    598:                        p1 = holdsp;
                    599:                        p2 = linebuf;
                    600:                        while(*p2++ = *p1++);
                    601:                        spend = p2 - 1;
                    602:                        p1 = genbuf;
                    603:                        p2 = holdsp;
                    604:                        while(*p2++ = *p1++);
                    605:                        hspend = p2 - 1;
                    606:                        break;
                    607: 
                    608:                case YCOM:
                    609:                        p1 = linebuf;
                    610:                        p2 = ipc->r1.re1;
                    611:                        while(*p1 = p2[*p1])    p1++;
                    612:                        break;
                    613:        }
                    614: 
                    615: }
                    616: 
                    617: uchar  *
                    618: gline(addr)
                    619: uchar  *addr;
                    620: {
                    621:        register uchar  *p1, *p2;
                    622:        register        c;
                    623:        sflag = 0;
                    624:        p1 = addr;
                    625:        p2 = cbp;
                    626:        for (;;) {
                    627:                if (p2 >= ebp) {
                    628:                        if ((c = Read(f, ibuf, 512)) <= 0) {
                    629:                                return(badp);
                    630:                        }
                    631:                        p2 = ibuf;
                    632:                        ebp = ibuf+c;
                    633:                }
                    634:                if ((c = *p2++) == '\n') {
                    635:                        if(p2 >=  ebp) {
                    636:                                if((c = Read(f, ibuf, 512)) <= 0) {
                    637:                                        close(f);
                    638:                                        if(eargc == 0)
                    639:                                                        dolflag = 1;
                    640:                                }
                    641: 
                    642:                                p2 = ibuf;
                    643:                                ebp = ibuf + c;
                    644:                        }
                    645:                        break;
                    646:                }
                    647:                if(c)
                    648:                if(p1 < lbend)
                    649:                        *p1++ = c;
                    650:        }
                    651:        lnum++;
                    652:        *p1 = 0;
                    653:        cbp = p2;
                    654: 
                    655:        return(p1);
                    656: }
                    657: ecmp(a, b, count)
                    658: uchar  *a, *b;
                    659: {
                    660:        while(count--)
                    661:                if(*a++ != *b++)        return(0);
                    662:        return(1);
                    663: }
                    664: 
                    665: arout()
                    666: {
                    667:        register uchar  *p1;
                    668:        FILE    *fi;
                    669:        uchar   c;
                    670:        int     t;
                    671: 
                    672:        aptr = abuf - 1;
                    673:        while(*++aptr) {
                    674:                if((*aptr)->r1.command == ACOM) {
                    675:                        for(p1 = (*aptr)->r1.re1; *p1; )
                    676:                                putc(*p1++, stdout);
                    677:                        putc('\n', stdout);
                    678:                } else {
                    679:                        if((fi = fopen((*aptr)->r1.re1, "r")) == NULL)
                    680:                                continue;
                    681:                        while((t = getc(fi)) != EOF) {
                    682:                                c = t;
                    683:                                putc(c, stdout);
                    684:                        }
                    685:                        fclose(fi);
                    686:                }
                    687:        }
                    688:        aptr = abuf;
                    689:        *aptr = 0;
                    690: }
                    691: 
                    692: uchar *
                    693: lformat(c, p)
                    694: uchar *p;
                    695: {
                    696:        int trans = 
                    697:                c=='\b'? 'b':
                    698:                c=='\t'? 't':
                    699:                c=='\n'? 'n':
                    700:                c=='\v'? 'v':
                    701:                c=='\f'? 'f':
                    702:                c=='\r'? 'r':
                    703:                c=='\\'? '\\':
                    704:                0;
                    705:        if(trans) {
                    706:                *p++ = '\\';
                    707:                *p++ = trans;
                    708:        } else if(c<040 || c>=0177) {
                    709:                *p++ = '\\';
                    710:                *p++ = ((c>>6)&07) + '0';
                    711:                *p++ = ((c>>3)&07) + '0';
                    712:                *p++ = (c&07) + '0';
                    713:        } else
                    714:                *p++ = c;
                    715:        return p;
                    716: }
                    717: 

unix.superglobalmegacorp.com

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