Annotation of researchv10no/cmd/troff/Old/jc.c, revision 1.1

1.1     ! root        1: /*
        !             2:  *     drive jerq terminal.
        !             3:  *     not many sizes and fonts right now
        !             4:  */
        !             5: 
        !             6: /*
        !             7: output language from troff:
        !             8: all numbers are character strings
        !             9: 
        !            10: sn     size in points
        !            11: fn     font as number from 1-n
        !            12: cx     ascii character x
        !            13: Cxyz   funny char xyz. terminated by white space
        !            14: Hn     go to absolute horizontal position n
        !            15: Vn     go to absolute vertical position n (down is positive)
        !            16: hn     go n units horizontally (relative)
        !            17: vn     ditto vertically
        !            18: nnc    move right nn, then print c (exactly 2 digits!)
        !            19:                (this wart is an optimization that shrinks output file size
        !            20:                 about 35% and run-time about 15% while preserving ascii-ness)
        !            21: Dt ...\n       draw operation 't':
        !            22:        Dl x y          line from here by x,y
        !            23:        Dc d            circle of diameter d with left side here
        !            24:        De x y          ellipse of axes x,y with left side here
        !            25:        Da x y r        arc counter-clockwise by x,y of radius r
        !            26:        D~ x y x y ...  wiggly line by x,y then x,y ...
        !            27: nb a   end of line (information only -- no action needed)
        !            28:        b = space before line, a = after
        !            29: p      new page begins -- set v to 0
        !            30: #...\n comment
        !            31: x ...\n        device control functions:
        !            32:        x i     init
        !            33:        x T s   name of device is s
        !            34:        x r n h v       resolution is n/inch
        !            35:                h = min horizontal motion, v = min vert
        !            36:        x p     pause (can restart)
        !            37:        x s     stop -- done for ever
        !            38:        x t     generate trailer
        !            39:        x f n s font position n contains font s
        !            40:        x H n   set character height to n
        !            41:        x S n   set slant to N
        !            42: 
        !            43:        Subcommands like "i" are often spelled out like "init".
        !            44: */
        !            45: 
        !            46: #include       <stdio.h>
        !            47: #include       <signal.h>
        !            48: #include       <math.h>
        !            49: #include       <ctype.h>
        !            50: #include       <sgtty.h>
        !            51: #include "dev.h"
        !            52: #define        NFONT   10
        !            53: 
        !            54: struct sgttyb sttymodes, sttysave, sttychars;
        !            55: int xx, yy;
        !            56: int    xoffset = 0;    /* shift output right by this amount */
        !            57: int    yoffset = 0;    /* shift down (!) by this amount */
        !            58: int    output  = 0;    /* do we do output at all? */
        !            59: int    nolist  = 0;    /* output page list if > 0 */
        !            60: int    olist[20];      /* pairs of page numbers */
        !            61: 
        !            62: int    erase   = 1;
        !            63: float  aspect  = 1;    /* default aspect ratio */
        !            64: int    revmode = 0;    /* reverse video if set */
        !            65: int    (*sigint)();
        !            66: int    (*sigquit)();
        !            67: int    jtcalled = 0;   /* 1 if managed to call jt */
        !            68: 
        !            69: struct dev dev;
        !            70: struct font *fontbase[NFONT+1];
        !            71: short  *pstab;
        !            72: int    nsizes  = 1;
        !            73: int    nfonts;
        !            74: int    smnt;   /* index of first special font */
        !            75: int    nchtab;
        !            76: char   *chname;
        !            77: short  *chtab;
        !            78: char   *fitab[NFONT+1];
        !            79: char   *widthtab[NFONT+1];     /* widtab would be a better name */
        !            80: char   *codetab[NFONT+1];      /* device codes */
        !            81: 
        !            82: #define        FATAL   1
        !            83: #define        BMASK   0377
        !            84: int    dbg     = 0;
        !            85: int    Xflag   = 0;
        !            86: long   lineno  = 0;
        !            87: int    res     = 972;          /* input assumed computed according to this resolution */
        !            88:                                /* initial value to avoid 0 divide */
        !            89: #define        JERQRES 100.0           /* resolution of jerq */
        !            90: FILE   *tf     = NULL;         /* output file pointer */
        !            91: char   outfile[20];
        !            92: char   *fontdir        = "/usr/lib/font";
        !            93: extern char devname[];
        !            94: 
        !            95: FILE *fp       = stdin;        /* input file pointer */
        !            96: 
        !            97: main(argc, argv)
        !            98: char *argv[];
        !            99: {
        !           100:        char buf[BUFSIZ];
        !           101:        int done();
        !           102:        char *getenv(), *jerq;
        !           103: 
        !           104:        jerq = getenv("JERQ");
        !           105:        if (jerq == NULL) {
        !           106:                error(!FATAL, "JERQ parameter not set\n");
        !           107:                exit(1);
        !           108:        }
        !           109:        sprintf(outfile, "/dev/%s", jerq);
        !           110:        while (argc > 1 && argv[1][0] == '-') {
        !           111:                switch (argv[1][1]) {
        !           112:                case 't':
        !           113:                        tf = stdout;
        !           114:                        break;
        !           115:                case 'x':
        !           116:                        xoffset = atoi(&argv[1][2]);
        !           117:                        break;
        !           118:                case 'y':
        !           119:                        yoffset = atoi(&argv[1][2]);
        !           120:                        break;
        !           121:                case 'a':
        !           122:                        aspect = atof(&argv[1][2]);
        !           123:                        break;
        !           124:                case 'e':
        !           125:                        erase = 0;
        !           126:                        break;
        !           127:                case 'o':
        !           128:                        outlist(&argv[1][2]);
        !           129:                        break;
        !           130:                case 'd':
        !           131:                        dbg = atoi(&argv[1][2]);
        !           132:                        if (dbg == 0) dbg = 1;
        !           133:                        tf = stdout;
        !           134:                        break;
        !           135:                case 'j':
        !           136:                        outfile[8] = argv[1][2];        /* kludge */
        !           137:                        break;
        !           138:                case 'X':       /* use experimental version */
        !           139:                        Xflag++;
        !           140:                        break;
        !           141:                }
        !           142:                argc--;
        !           143:                argv++;
        !           144:        }
        !           145: 
        !           146:        if (tf == NULL && (tf = fopen(outfile, "w")) == NULL)
        !           147:                error(FATAL, "can't open terminal %s", outfile);
        !           148:        if (tf != stdout) {
        !           149:                pushmode();
        !           150:                jtcalled++;
        !           151:                if (Xflag)
        !           152:                        system("68ld /usr/bwk/troff/devjerq/jt");
        !           153:                else
        !           154:                        system("68ld /usr/jerq/lib/jt");
        !           155:        }
        !           156:        sigint = signal(SIGINT, done);
        !           157:        sigquit = signal(SIGQUIT, SIG_IGN);
        !           158:        if (argc <= 1)
        !           159:                conv(stdin);
        !           160:        else
        !           161:                while (--argc > 0) {
        !           162:                        if (strcmp(*++argv, "-") == 0)
        !           163:                                fp = stdin;
        !           164:                        else if ((fp = fopen(*argv, "r")) == NULL)
        !           165:                                error(FATAL, "can't open %s", *argv);
        !           166:                        conv(fp);
        !           167:                        fclose(fp);
        !           168:                }
        !           169:        done();
        !           170: }
        !           171: 
        !           172: pushmode()
        !           173: {
        !           174:        ioctl(1, TIOCGETP, &sttymodes);
        !           175:        sttysave=sttymodes;
        !           176:        sttymodes.sg_flags|=RAW;
        !           177:        sttymodes.sg_flags&=~ECHO;
        !           178:        ioctl(1, TIOCSETP, &sttymodes);
        !           179: }
        !           180: 
        !           181: popmode()
        !           182: {
        !           183:        ioctl(1, TIOCSETP, &sttysave);
        !           184: }
        !           185: 
        !           186: outlist(s)     /* process list of page numbers to be printed */
        !           187: char *s;
        !           188: {
        !           189:        int n1, n2, i;
        !           190: 
        !           191:        nolist = 0;
        !           192:        while (*s) {
        !           193:                n1 = 0;
        !           194:                if (isdigit(*s))
        !           195:                        do
        !           196:                                n1 = 10 * n1 + *s++ - '0';
        !           197:                        while (isdigit(*s));
        !           198:                else
        !           199:                        n1 = -9999;
        !           200:                n2 = n1;
        !           201:                if (*s == '-') {
        !           202:                        s++;
        !           203:                        n2 = 0;
        !           204:                        if (isdigit(*s))
        !           205:                                do
        !           206:                                        n2 = 10 * n2 + *s++ - '0';
        !           207:                                while (isdigit(*s));
        !           208:                        else
        !           209:                                n2 = 9999;
        !           210:                }
        !           211:                olist[nolist++] = n1;
        !           212:                olist[nolist++] = n2;
        !           213:                if (*s != '\0')
        !           214:                        s++;
        !           215:        }
        !           216:        olist[nolist] = 0;
        !           217:        if (dbg)
        !           218:                for (i=0; i<nolist; i += 2)
        !           219:                        printf("%3d %3d\n", olist[i], olist[i+1]);
        !           220: }
        !           221: 
        !           222: in_olist(n)    /* is n in olist? */
        !           223: int n;
        !           224: {
        !           225:        int i;
        !           226: 
        !           227:        if (nolist == 0)
        !           228:                return(1);      /* everything is included */
        !           229:        for (i = 0; i < nolist; i += 2)
        !           230:                if (n >= olist[i] && n <= olist[i+1])
        !           231:                        return(1);
        !           232:        return(0);
        !           233: }
        !           234: 
        !           235: conv(fp)
        !           236: register FILE *fp;
        !           237: {
        !           238:        register int c, k;
        !           239:        int m, n, i, n1, m1;
        !           240:        char str[100], buf[300];
        !           241: 
        !           242:        while ((c = getc(fp)) != EOF) {
        !           243:                switch (c) {
        !           244:                case '\n':      /* when input is text */
        !           245:                case ' ':
        !           246:                case 0:         /* occasional noise creeps in */
        !           247:                        break;
        !           248:                case '{':       /* push down current environment */
        !           249:                        t_push();
        !           250:                        break;
        !           251:                case '}':
        !           252:                        t_pop();
        !           253:                        break;
        !           254:                case '0': case '1': case '2': case '3': case '4':
        !           255:                case '5': case '6': case '7': case '8': case '9':
        !           256:                        /* two motion digits plus a character */
        !           257:                        hmot((c-'0')*10 + getc(fp)-'0');
        !           258:                        put1(getc(fp));
        !           259:                        break;
        !           260:                case 'c':       /* single ascii character */
        !           261:                        put1(getc(fp));
        !           262:                        break;
        !           263:                case 'C':
        !           264:                        fscanf(fp, "%s", str);
        !           265:                        put1s(str);
        !           266:                        break;
        !           267:                case 't':       /* straight text */
        !           268:                        fgets(buf, sizeof(buf), fp);
        !           269:                        t_text(buf);
        !           270:                        break;
        !           271:                case 'D':       /* draw function */
        !           272:                        fgets(buf, sizeof(buf), fp);
        !           273:                        switch (buf[0]) {
        !           274:                        case 'l':       /* draw a line */
        !           275:                                sscanf(buf+1, "%d %d", &n, &m);
        !           276:                                drawline(n, m, ".");
        !           277:                                break;
        !           278:                        case 'c':       /* circle */
        !           279:                                sscanf(buf+1, "%d", &n);
        !           280:                                drawcirc(n);
        !           281:                                break;
        !           282:                        case 'e':       /* ellipse */
        !           283:                                sscanf(buf+1, "%d %d", &m, &n);
        !           284:                                drawellip(m, n);
        !           285:                                break;
        !           286:                        case 'a':       /* arc */
        !           287:                                sscanf(buf+1, "%d %d %d %d", &n, &m, &n1, &m1);
        !           288:                                drawarc(n, m, n1, m1);
        !           289:                                break;
        !           290:                        case '~':       /* wiggly line */
        !           291:                                drawwig(buf+1);
        !           292:                                break;
        !           293:                        default:
        !           294:                                error(FATAL, "unknown drawing function %s\n", buf);
        !           295:                                break;
        !           296:                        }
        !           297:                        break;
        !           298:                case 's':
        !           299:                        fscanf(fp, "%d", &n);   /* ignore fractional sizes */
        !           300:                        setsize(t_size(n));
        !           301:                        break;
        !           302:                case 'f':
        !           303:                        fscanf(fp, "%s", str);
        !           304:                        setfont(t_font(str));
        !           305:                        break;
        !           306:                case 'H':       /* absolute horizontal motion */
        !           307:                        /* fscanf(fp, "%d", &n); */
        !           308:                        while ((c = getc(fp)) == ' ')
        !           309:                                ;
        !           310:                        k = 0;
        !           311:                        do {
        !           312:                                k = 10 * k + c - '0';
        !           313:                        } while (isdigit(c = getc(fp)));
        !           314:                        ungetc(c, fp);
        !           315:                        hgoto(k);
        !           316:                        break;
        !           317:                case 'h':       /* relative horizontal motion */
        !           318:                        /* fscanf(fp, "%d", &n); */
        !           319:                        while ((c = getc(fp)) == ' ')
        !           320:                                ;
        !           321:                        k = 0;
        !           322:                        do {
        !           323:                                k = 10 * k + c - '0';
        !           324:                        } while (isdigit(c = getc(fp)));
        !           325:                        ungetc(c, fp);
        !           326:                        hmot(k);
        !           327:                        break;
        !           328:                case 'w':       /* word space */
        !           329:                        break;
        !           330:                case 'V':
        !           331:                        fscanf(fp, "%d", &n);
        !           332:                        vgoto(n);
        !           333:                        break;
        !           334:                case 'v':
        !           335:                        fscanf(fp, "%d", &n);
        !           336:                        vmot(n);
        !           337:                        break;
        !           338:                case 'p':       /* new page */
        !           339:                        fscanf(fp, "%d", &n);
        !           340:                        t_page(n);
        !           341:                        break;
        !           342:                case 'n':       /* end of line */
        !           343:                        while (getc(fp) != '\n')
        !           344:                                ;
        !           345:                        t_newline();
        !           346:                        break;
        !           347:                case '#':       /* comment */
        !           348:                        while (getc(fp) != '\n')
        !           349:                                ;
        !           350:                        break;
        !           351:                case 'x':       /* device control */
        !           352:                        devcntrl(fp);
        !           353:                        break;
        !           354:                default:
        !           355:                        error(!FATAL, "unknown input character %o %c\n", c, c);
        !           356:                        done();
        !           357:                }
        !           358:        }
        !           359: }
        !           360: 
        !           361: devcntrl(fp)   /* interpret device control functions */
        !           362: FILE *fp;
        !           363: {
        !           364:        char str[20], str1[50], buf[50];
        !           365:        int c, n;
        !           366: 
        !           367:        fscanf(fp, "%s", str);
        !           368:        switch (str[0]) {       /* crude for now */
        !           369:        case 'i':       /* initialize */
        !           370:                fileinit();
        !           371:                t_init(0);
        !           372:                break;
        !           373:        case 'T':       /* device name */
        !           374:                fscanf(fp, "%s", devname);
        !           375:                break;
        !           376:        case 't':       /* trailer */
        !           377:                t_trailer();
        !           378:                break;
        !           379:        case 'p':       /* pause -- can restart */
        !           380:                t_reset('p');
        !           381:                break;
        !           382:        case 's':       /* stop */
        !           383:                t_reset('s');
        !           384:                break;
        !           385:        case 'r':       /* resolution assumed when prepared */
        !           386:                fscanf(fp, "%d", &res);
        !           387:                break;
        !           388:        case 'f':       /* font used */
        !           389:                fscanf(fp, "%d %s", &n, str);
        !           390:                fgets(buf, sizeof buf, fp);     /* in case there's a filename */
        !           391:                ungetc('\n', fp);       /* fgets goes too far */
        !           392:                str1[0] = 0;    /* in case there's nothing to come in */
        !           393:                sscanf(buf, "%s", str1);
        !           394:                loadfont(n, str, str1);
        !           395:                break;
        !           396:        /* these don't belong here... */
        !           397:        case 'H':       /* char height */
        !           398:                fscanf(fp, "%d", &n);
        !           399:                t_charht(n);
        !           400:                break;
        !           401:        case 'S':       /* slant */
        !           402:                fscanf(fp, "%d", &n);
        !           403:                t_slant(n);
        !           404:                break;
        !           405:        }
        !           406:        while ((c = getc(fp)) != '\n')  /* skip rest of input line */
        !           407:                if (c == EOF)
        !           408:                        break;
        !           409: }
        !           410: 
        !           411: fileinit()     /* read in font and code files, etc. */
        !           412: {
        !           413:        int i, fin, nw;
        !           414:        char *malloc(), *filebase, *p;
        !           415:        char temp[60];
        !           416: 
        !           417:        /* open table for device,
        !           418:        /* read in resolution, size info, font info, etc.
        !           419:        /* and set params
        !           420:        */
        !           421:        strcpy(devname, "202"); /* this is the only char set we have */
        !           422:                                /* the resolution, etc., is already in */
        !           423:        sprintf(temp, "%s/dev%s/DESC.out", fontdir, devname);
        !           424:        if ((fin = open(temp, 0)) < 0)
        !           425:                error(FATAL, "can't open tables for %s\n", temp);
        !           426:        read(fin, &dev, sizeof(struct dev));
        !           427:        nfonts = dev.nfonts;
        !           428:        nsizes = dev.nsizes;
        !           429:        nchtab = dev.nchtab;
        !           430:        filebase = malloc(dev.filesize);        /* enough room for whole file */
        !           431:        read(fin, filebase, dev.filesize);      /* all at once */
        !           432:        pstab = (short *) filebase;
        !           433:        chtab = pstab + nsizes + 1;
        !           434:        chname = (char *) (chtab + dev.nchtab);
        !           435:        p = chname + dev.lchname;
        !           436:        for (i = 0; i <= nfonts; i++) {
        !           437:                fontbase[i] = NULL;
        !           438:                widthtab[i] = codetab[i] = fitab[i] = NULL;
        !           439:        }
        !           440:        close(fin);
        !           441: }
        !           442: 
        !           443: fontprint(i)   /* debugging print of font i (0,...) */
        !           444: {
        !           445:        int j, k, n;
        !           446:        char *p;
        !           447: 
        !           448:        printf("font %d:\n", i);
        !           449:        p = (char *) fontbase[i];
        !           450:        n = fontbase[i]->nwfont & BMASK;
        !           451:        printf("base=0%o, nchars=%d, spec=%d, name=%s, widtab=0%o, fitab=0%o\n",
        !           452:                p, n, fontbase[i]->specfont, fontbase[i]->namefont, widthtab[i], fitab[i]);
        !           453:        printf("widths:\n");
        !           454:        for (j=0; j <= n; j++) {
        !           455:                printf(" %2d", widthtab[i][j] & BMASK);
        !           456:                if (j % 20 == 19) printf("\n");
        !           457:        }
        !           458:        printf("\ncodetab:\n");
        !           459:        for (j=0; j <= n; j++) {
        !           460:                printf(" %2d", codetab[i][j] & BMASK);
        !           461:                if (j % 20 == 19) printf("\n");
        !           462:        }
        !           463:        printf("\nfitab:\n");
        !           464:        for (j=0; j <= dev.nchtab + 128-32; j++) {
        !           465:                printf(" %2d", fitab[i][j] & BMASK);
        !           466:                if (j % 20 == 19) printf("\n");
        !           467:        }
        !           468:        printf("\n");
        !           469: }
        !           470: 
        !           471: loadfont(n, s, s1)     /* load font info for font s on position n (0...) */
        !           472: int n;
        !           473: char *s, *s1;
        !           474: {
        !           475:        char temp[60];
        !           476:        int fin, nw, norig;
        !           477: 
        !           478:        if (n < 0 || n > NFONT)
        !           479:                error(FATAL, "illegal fp command %d %s", n, s);
        !           480:        if (fontbase[n] != NULL && strcmp(s, fontbase[n]->namefont) == 0)
        !           481:                return;
        !           482:        if (s1 == NULL || s1[0] == '\0')
        !           483:                sprintf(temp, "%s/dev%s/%s.out", fontdir, devname, s);
        !           484:        else
        !           485:                sprintf(temp, "%s/%s.out", s1, s);
        !           486:        if ((fin = open(temp, 0)) < 0) {
        !           487:                error(!FATAL, "can't open font table %s", temp);
        !           488:                return;
        !           489:        }
        !           490:        if (fontbase[n] != NULL)
        !           491:                free(fontbase[n]);
        !           492:        fontbase[n] = (struct font *) malloc(3*255 + dev.nchtab +
        !           493:                                (128-32) + sizeof(struct font));
        !           494:        if (fontbase[n] == NULL)
        !           495:                error(FATAL, "Out of space in loadfont %s\n", s);
        !           496:        read(fin, fontbase[n], 3*255 + nchtab+128-32 + sizeof(struct font));
        !           497:        close(fin);
        !           498:        if (smnt == 0 && fontbase[n]->specfont == 1)
        !           499:                smnt = n;
        !           500:        nw = fontbase[n]->nwfont & BMASK;
        !           501:        widthtab[n] = (char *) fontbase[n] + sizeof(struct font);
        !           502:        codetab[n] = (char *) widthtab[n] + 2 * nw;
        !           503:        fitab[n] = (char *) widthtab[n] + 3 * nw;
        !           504:        t_fp(n, fontbase[n]->namefont, fontbase[n]->intname);
        !           505:        if (dbg > 1) fontprint(n);
        !           506: }
        !           507: 
        !           508: #define        MINY    0
        !           509: #define        MAXY    (1023-10)
        !           510: #define        MAXX    800
        !           511: 
        !           512: error(f, s, a1, a2, a3, a4, a5, a6, a7) {
        !           513:        if (dbg) {
        !           514:                fprintf(stderr, "jc: ");
        !           515:                fprintf(stderr, s, a1, a2, a3, a4, a5, a6, a7);
        !           516:                fprintf(stderr, " near line %ld\n", lineno);
        !           517:        }
        !           518:        if (f)
        !           519:                done(2);
        !           520: }
        !           521: 
        !           522: 
        !           523: /*
        !           524:        Here beginneth all the stuff that really depends
        !           525:        on the jerq (we hope).
        !           526: */
        !           527: 
        !           528: 
        !           529: char   devname[20]     = "jerq";
        !           530: 
        !           531: #define        oput(c) if (output) xychar(xx, yy, c); else;
        !           532: 
        !           533: int    stopped = 0;
        !           534: int    size    = 1;
        !           535: int    font    = 1;            /* current font */
        !           536: int    hpos;           /* horizontal position where we are supposed to be next (left = 0) */
        !           537: int    vpos;           /* current vertical position (down positive) */
        !           538: 
        !           539: int    horig;          /* h origin of current block; hpos rel to this */
        !           540: int    vorig;          /* v origin of current block; vpos rel to this */
        !           541: 
        !           542: int    DX      = 8;    /* step size in x for drawing */
        !           543: int    DY      = 8;    /* step size in y for drawing */
        !           544: int    drawdot = '.';  /* draw with this character */
        !           545: int    drawsize = 1;   /* shrink by this factor when drawing */
        !           546: 
        !           547: t_init(reinit) /* initialize device */
        !           548: int reinit;
        !           549: {
        !           550:        int i;
        !           551: 
        !           552:        if (! reinit) {
        !           553:                fprintf(tf, "i\n");
        !           554:                for (i = 0; i < nchtab; i++)
        !           555:                        if (strcmp(&chname[chtab[i]], "l.") == 0)
        !           556:                                break;
        !           557:                if (i < nchtab) {
        !           558:                        drawdot = i + 128;
        !           559:                        drawsize = 1;
        !           560:                } else {
        !           561:                        drawdot = '.';
        !           562:                        drawsize = 2;   /* half size */
        !           563:                }
        !           564:        }
        !           565:        fflush(tf);
        !           566:        stopped = 0;
        !           567:        if (erase) {
        !           568:                fprintf(tf, "e\n");
        !           569:                fflush(tf);
        !           570:        }
        !           571:        hpos = vpos = 0;
        !           572:        setsize(t_size(10));    /* start somewhere */
        !           573:        sendpt();
        !           574: }
        !           575: 
        !           576: #define        MAXSTATE        5
        !           577: 
        !           578: struct state {
        !           579:        int     ssize;
        !           580:        int     sfont;
        !           581:        int     shpos;
        !           582:        int     svpos;
        !           583:        int     shorig;
        !           584:        int     svorig;
        !           585: };
        !           586: struct state   state[MAXSTATE];
        !           587: struct state   *statep = state;
        !           588: 
        !           589: t_push()       /* begin a new block */
        !           590: {
        !           591:        hflush();
        !           592:        statep->ssize = size;
        !           593:        statep->sfont = font;
        !           594:        statep->shorig = horig;
        !           595:        statep->svorig = vorig;
        !           596:        statep->shpos = hpos;
        !           597:        statep->svpos = vpos;
        !           598:        horig = hpos;
        !           599:        vorig = vpos;
        !           600:        hpos = vpos = 0;
        !           601:        if (statep++ >= state+MAXSTATE)
        !           602:                error(FATAL, "{ nested too deep");
        !           603:        hpos = vpos = 0;
        !           604: }
        !           605: 
        !           606: t_pop()        /* pop to previous state */
        !           607: {
        !           608:        if (--statep < state)
        !           609:                error(FATAL, "extra }");
        !           610:        size = statep->ssize;
        !           611:        font = statep->sfont;
        !           612:        hpos = statep->shpos;
        !           613:        vpos = statep->svpos;
        !           614:        horig = statep->shorig;
        !           615:        vorig = statep->svorig;
        !           616: }
        !           617: 
        !           618: int    np;     /* number of pages seen */
        !           619: int    npmax;  /* high-water mark of np */
        !           620: int    pgnum[100];     /* their actual numbers */
        !           621: long   pgadr[100];     /* their seek addresses */
        !           622: 
        !           623: t_page(n)      /* do whatever new page functions */
        !           624: {
        !           625:        long ftell();
        !           626:        int c, m, i;
        !           627:        char buf[100], *bp;
        !           628: 
        !           629:        pgnum[np++] = n;
        !           630:        pgadr[np] = ftell(fp);
        !           631:        if (np > npmax)
        !           632:                npmax = np;
        !           633:        if (output == 0) {
        !           634:                output = in_olist(n);
        !           635:                t_init(1);
        !           636:                return;
        !           637:        }
        !           638:        /* have just printed something, and seen p<n> for next one */
        !           639:        vgoto(11 * res - 100);
        !           640:        sendpt();
        !           641:        fflush(tf);
        !           642: 
        !           643:   next:
        !           644:        for (bp = buf; (*bp = readch()); )
        !           645:                if (*bp++ == '\n')
        !           646:                        break;
        !           647:        *bp = 0;
        !           648:        switch (buf[0]) {
        !           649:        case '\004':
        !           650:        case '\177':
        !           651:        case 0:
        !           652:                done();
        !           653:                break;
        !           654:        case '\n':
        !           655:                if (stopped)
        !           656:                        done();
        !           657:                output = in_olist(n);
        !           658:                t_init(1);
        !           659:                return;
        !           660:        case '!':
        !           661:                callunix(&buf[1]);
        !           662:                fputs("!\n", stderr);
        !           663:                break;
        !           664:        case 'e':
        !           665:                erase = 1 - erase;
        !           666:                if (erase) {
        !           667:                        putc('e', tf);
        !           668:                        fflush(tf);
        !           669:                }
        !           670:                break;
        !           671:        case 'r':
        !           672:                putc('r', tf);
        !           673:                fflush(tf);
        !           674:                break;
        !           675:        case 'a':
        !           676:                aspect = atof(&buf[1]);
        !           677:                break;
        !           678:        case 'x':
        !           679:                xoffset = atoi(&buf[1]);
        !           680:                break;
        !           681:        case 'y':
        !           682:                yoffset = atoi(&buf[1]);
        !           683:                break;
        !           684:        case '-':
        !           685:        case 'p':
        !           686:                m = atoi(&buf[1]) + 1;
        !           687:                if (fp == stdin) {
        !           688:                        fputs("you can't; it's not a file\n", stderr);
        !           689:                        break;
        !           690:                }
        !           691:                if (np - m <= 0) {
        !           692:                        fputs("too far back\n", stderr);
        !           693:                        break;
        !           694:                }
        !           695:                np -= m;
        !           696:                fseek(fp, pgadr[np], 0);
        !           697:                output = 1;
        !           698:                t_init(1);
        !           699:                return;
        !           700:        case '0': case '1': case '2': case '3': case '4':
        !           701:        case '5': case '6': case '7': case '8': case '9':
        !           702:                m = atoi(&buf[0]);
        !           703:                for (i = 0; i < npmax; i++)
        !           704:                        if (m == pgnum[i])
        !           705:                                break;
        !           706:                if (i >= npmax || fp == stdin) {
        !           707:                        fputs("you can't\n", stderr);
        !           708:                        break;
        !           709:                }
        !           710:                np = i + 1;
        !           711:                fseek(fp, pgadr[np], 0);
        !           712:                output = 1;
        !           713:                t_init(1);
        !           714:                return;
        !           715:        case 'o':
        !           716:                outlist(&buf[1]);
        !           717:                output = 0;
        !           718:                t_init(1);
        !           719:                return;
        !           720:        case 'q':
        !           721:                done();
        !           722:                break;
        !           723:        case '?':
        !           724:                fputs("!cmd     unix cmd\n", stderr);
        !           725:                fputs("p        print this page again\n", stderr);
        !           726:                fputs("-n       go back n pages\n", stderr);
        !           727:                fputs("n        print page n (previously printed)\n", stderr);
        !           728:                fputs("o...     set the -o output list to ...\n", stderr);
        !           729:                fputs("en       n=0 -> don't erase; n=1 -> erase\n", stderr);
        !           730:                fputs("an       set aspect ratio to n\n", stderr);
        !           731:                fputs("xn       set x offset to n (+ => right)\n", stderr);
        !           732:                fputs("yn       set y offset to n (+ => down)\n", stderr);
        !           733:                break;
        !           734:        default:
        !           735:                fputs("?\n", stderr);
        !           736:                break;
        !           737:        }
        !           738:        goto next;
        !           739: }
        !           740: 
        !           741: t_newline()    /* do whatever for the end of a line */
        !           742: {
        !           743:        hpos = 0;
        !           744: }
        !           745: 
        !           746: t_size(n)      /* convert integer to internal size number*/
        !           747: int n;
        !           748: {
        !           749:        int i;
        !           750: 
        !           751:        if (n <= pstab[0])
        !           752:                return(1);
        !           753:        else if (n >= pstab[nsizes-1])
        !           754:                return(nsizes);
        !           755:        for (i = 0; n > pstab[i]; i++)
        !           756:                ;
        !           757:        return(i+1);
        !           758: }
        !           759: 
        !           760: t_charht(n)    /* set character height to n */
        !           761: int n;
        !           762: {
        !           763:        /* punt for now */
        !           764: }
        !           765: 
        !           766: t_slant(n)     /* set slant to n */
        !           767: int n;
        !           768: {
        !           769:        /* punt for now */
        !           770: }
        !           771: 
        !           772: t_font(s)      /* convert string to internal font number */
        !           773: char *s;
        !           774: {
        !           775:        int n;
        !           776: 
        !           777:        n = atoi(s);
        !           778:        if (n < 1 || n > nfonts)
        !           779:                n = 1;
        !           780:        return(n);
        !           781: }
        !           782: 
        !           783: t_text(s)      /* print string s as text */
        !           784: char *s;
        !           785: {
        !           786:        int c, w;
        !           787:        char str[100];
        !           788: 
        !           789:        if (!output)
        !           790:                return;
        !           791:        w = res / 2 * pstab[size-1] / 72;
        !           792:        while ((c = *s++) != '\n') {
        !           793:                if (c == '\\') {
        !           794:                        switch (c = *s++) {
        !           795:                        case '\\':
        !           796:                        case 'e':
        !           797:                                put1('\\');
        !           798:                                break;
        !           799:                        case '(':
        !           800:                                str[0] = *s++;
        !           801:                                str[1] = *s++;
        !           802:                                str[2] = '\0';
        !           803:                                put1s(str);
        !           804:                                break;
        !           805:                        }
        !           806:                } else {
        !           807:                        put1(c);
        !           808:                }
        !           809:                hmot(w);
        !           810:        }
        !           811: }
        !           812: 
        !           813: t_reset(c)
        !           814: {
        !           815:        int n;
        !           816: 
        !           817:        output = 1;
        !           818:        fflush(tf);
        !           819:        if (c == 's') {
        !           820:                stopped = 1;
        !           821:                t_page(9999);
        !           822:        }
        !           823: }
        !           824: 
        !           825: t_trailer()
        !           826: {
        !           827: }
        !           828: 
        !           829: hgoto(n)
        !           830: {
        !           831:        hpos = n;       /* this is where we want to be */
        !           832:                        /* before printing a character, */
        !           833:                        /* have to make sure it's true */
        !           834: }
        !           835: 
        !           836: hmot(n)        /* generate n units of horizontal motion */
        !           837: int n;
        !           838: {
        !           839:        hgoto(hpos + n);
        !           840: }
        !           841: 
        !           842: hflush()       /* actual horizontal output occurs here */
        !           843: {
        !           844:        if (output)
        !           845:                sendpt();
        !           846: }
        !           847: 
        !           848: vgoto(n)
        !           849: {
        !           850:        vpos = n;
        !           851: }
        !           852: 
        !           853: vmot(n)        /* generate n units of vertical motion */
        !           854: int n;
        !           855: {
        !           856:        vgoto(vpos + n);        /* ignores rounding */
        !           857: }
        !           858: 
        !           859: put1s(s)       /* s is a funny char name */
        !           860: char *s;
        !           861: {
        !           862:        int i;
        !           863: 
        !           864:        if (!output)
        !           865:                return;
        !           866:        if (dbg) printf("%s ", s);
        !           867:        for (i = 0; i < nchtab; i++)
        !           868:                if (strcmp(&chname[chtab[i]], s) == 0)
        !           869:                        break;
        !           870:        if (i < nchtab)
        !           871:                put1(i + 128);
        !           872: }
        !           873: 
        !           874: put1(c)        /* output char c */
        !           875: int c;
        !           876: {
        !           877:        char *pw;
        !           878:        register char *p;
        !           879:        register int i, k;
        !           880:        int j, ofont, code, w;
        !           881: 
        !           882:        if (!output)
        !           883:                return;
        !           884:        c -= 32;
        !           885:        if (c <= 0) {
        !           886:                if (dbg) printf("non-exist 0%o\n", c+32);
        !           887:                return;
        !           888:        }
        !           889:        k = ofont = font;
        !           890:        i = fitab[font][c] & BMASK;
        !           891:        if (i != 0) {   /* it's on this font */
        !           892:                p = codetab[font];
        !           893:                pw = widthtab[font];
        !           894:        } else if (smnt > 0) {          /* on special (we hope) */
        !           895:                for (k=smnt, j=0; j <= nfonts; j++, k = (k+1) % (nfonts+1))
        !           896:                        if ((i = fitab[k][c] & BMASK) != 0) {
        !           897:                                p = codetab[k];
        !           898:                                pw = widthtab[k];
        !           899:                                setfont(k);
        !           900:                                break;
        !           901:                        }
        !           902:        }
        !           903:        if (i == 0 || (code = p[i] & BMASK) == 0 || k > nfonts) {
        !           904:                if (dbg) printf("not found 0%o\n", c+32);
        !           905:                return;
        !           906:        }
        !           907:        hflush();
        !           908:        if (dbg) {
        !           909:                if (isprint(c+32))
        !           910:                        printf("%c %d\n", c+32, code);
        !           911:                else
        !           912:                        printf("%03o %d\n", c+32, code);
        !           913:        } else
        !           914:                oput(code);
        !           915:        if (font != ofont)
        !           916:                setfont(ofont);
        !           917: }
        !           918: 
        !           919: setsize(n)     /* set point size to n (internal) */
        !           920: int n;
        !           921: {
        !           922: 
        !           923:        if (!output)
        !           924:                return;
        !           925:        if (n == size)
        !           926:                return; /* already there */
        !           927:        putc('s', tf);
        !           928:        putint(pstab[n-1]);
        !           929:        size = n;
        !           930: }
        !           931: 
        !           932: /* font position info: */
        !           933: 
        !           934: struct {
        !           935:        char *name;
        !           936:        int number;
        !           937: } fontname[NFONT+1];
        !           938: 
        !           939: t_fp(n, s, si) /* font position n now contains font s, intname si */
        !           940: int n;
        !           941: char *s, *si;
        !           942: {
        !           943:        fontname[n].name = s;
        !           944:        fontname[n].number = atoi(si);
        !           945: }
        !           946: 
        !           947: setfont(n)     /* set font to n */
        !           948: int n;
        !           949: {
        !           950:        if (!output)
        !           951:                return;
        !           952:        if (n < 0 || n > NFONT)
        !           953:                error(FATAL, "illegal font %d\n", n);
        !           954:        putc('f', tf);
        !           955:        /* putint(fontname[n].number); */
        !           956:        putint(n);      /* for now */
        !           957:        font = n;
        !           958: }
        !           959: 
        !           960: done()
        !           961: {
        !           962:        output = 1;
        !           963:        hgoto(0);
        !           964:        vgoto(11 * res - 100);  /* bottom of page */
        !           965:        sendpt();
        !           966:        fflush(tf);
        !           967:        if (jtcalled)
        !           968:                system("run - /usr/jerq/lib/term");
        !           969:        popmode();
        !           970:        exit(0);
        !           971: }
        !           972: 
        !           973: callunix(line)
        !           974: char line[];
        !           975: {
        !           976:        int rc, status, unixpid;
        !           977:        if( (unixpid=fork())==0 ) {
        !           978:                signal(SIGINT,sigint); signal(SIGQUIT,sigquit);
        !           979:                close(0); close(1); dup(2); dup(2);
        !           980:                execl("/bin/sh", "-sh", "-c", line, 0);
        !           981:                exit(255);
        !           982:        }
        !           983:        else if(unixpid == -1)
        !           984:                return;
        !           985:        else{   signal(SIGINT, SIG_IGN); signal(SIGQUIT, SIG_IGN);
        !           986:                while( (rc = wait(&status)) != unixpid && rc != -1 ) ;
        !           987:                signal(SIGINT, done); signal(SIGQUIT,sigquit);
        !           988:        }
        !           989: }
        !           990: readch(){
        !           991:        char c;
        !           992:        if (read(2,&c,1)<1 || (c == '\004') || (c == '\177')) c=0;
        !           993:        return(c);
        !           994: }
        !           995: 
        !           996: scalept(n)
        !           997: {
        !           998:        ((float)(n) * JERQRES / res) * aspect + 0.5;
        !           999: }
        !          1000: 
        !          1001: sendpt()
        !          1002: {
        !          1003:        float fx, fy;
        !          1004: 
        !          1005:        fx = hpos + horig;
        !          1006:        fy = vpos + vorig;
        !          1007:        xx = fx * JERQRES / res * aspect + 0.5;
        !          1008:        xx += xoffset;
        !          1009:        yy = fy * (MAXY-MINY) / (11 * res) + MINY + 0.5;
        !          1010:        yy += yoffset;
        !          1011: }
        !          1012: 
        !          1013: xychar(x,y,c)
        !          1014: {
        !          1015:        static int lasty = 0;
        !          1016:        static int lastx = 0;
        !          1017: 
        !          1018:        if (y != lasty) {
        !          1019:                putc('y', tf);
        !          1020:                putint(y);
        !          1021:                lasty = y;
        !          1022:        }
        !          1023:        /* optimization? */
        !          1024:        if (x-lastx >= 0 && x-lastx <= 255 && c != '0') {
        !          1025:                putc('X', tf);
        !          1026:                putc(x-lastx, tf);
        !          1027:                putc(c, tf);
        !          1028:        } else {
        !          1029:                putc('x', tf);
        !          1030:                putint(x);
        !          1031:                if (c) {
        !          1032:                        putc('c', tf);
        !          1033:                        putc(c, tf);
        !          1034:                }
        !          1035:        }
        !          1036:        lastx = x;
        !          1037: }
        !          1038: 
        !          1039: putint(n)
        !          1040: {
        !          1041:        if (dbg) {
        !          1042:                printf("%02d\n", n);
        !          1043:                return;
        !          1044:        }
        !          1045:        putc(n>>8, tf);
        !          1046:        putc(n, tf);
        !          1047: }

unix.superglobalmegacorp.com

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