Annotation of 43BSD/contrib/dipress/src/bin/ipmetrics/parse.c, revision 1.1.1.1

1.1       root        1: /* parse.c
                      2:  *
                      3:  * Copyright (c) 1984, 1985 Xerox Corp.
                      4:  *
                      5:  *  Items are left on the stack when execution finishes.
                      6:  *
                      7:  *  pop() can be used to remove items from the stack.
                      8:  *  Please remember to free() any item you pop off the stack.
                      9:  *
                     10:  *
                     11:  * HISTORY
                     12:  *
                     13:  * K. Knox, 28-Mar-85 18:26:50, Created first version.
                     14:  *
                     15:  */
                     16: 
                     17: #include <stdio.h>
                     18: #include <iptokens.h>
                     19: 
                     20: FILE *fp;
                     21: long filepos = 0;
                     22: 
                     23: 
                     24: #define len_IP_header 40
                     25: 
                     26: #define token_id          0340
                     27: #define token_mask        0037
                     28: #define token_short_op    0200
                     29: #define token_long_op     0240
                     30: #define token_short_seq   0300
                     31: #define token_long_seq    0340
                     32: 
                     33: parse(fpin)
                     34:   FILE *fpin;
                     35:   {
                     36:   /* variables */
                     37:   int c, len;
                     38:   char  string[len_IP_header+1],
                     39:        *ptr;
                     40:   int last = 0;
                     41:   int seq,
                     42:       hlen;
                     43: 
                     44:   /* Get the header. */
                     45:   fp = fpin;
                     46: 
                     47:   /* get the header */
                     48:   for (hlen = 0, ptr = string; hlen < len_IP_header; hlen++)
                     49:     if ( (*ptr++ = getc(fp)) == ' ' )
                     50:        break;
                     51: 
                     52:   *ptr = '\0';
                     53: 
                     54:   header(string);
                     55: 
                     56:   /* Analyze every token in the file. */
                     57:   while ((c = getc(fp)) != EOF)
                     58:     {
                     59:     filepos = ftell(fp)-1;
                     60:     switch (c & token_id)
                     61:       {
                     62:       case token_short_op:        /* Only allowed short op is "nop". */
                     63:         len = c & token_mask;
                     64:         operator(len);
                     65:        last = 0;
                     66:         break;
                     67:       case token_long_op:
                     68:         len = getc(fp)+((c & token_mask) << 8);
                     69:         if (operator(len)) return;      /* Quit when you hit endBlock. */
                     70:        last = 0;
                     71:         break;
                     72:       case token_short_seq:
                     73:         len = getc(fp);
                     74:        seq = c & token_mask;
                     75:         sequence(seq, len, last);
                     76:        if (seq != sequenceContinued) last = seq;
                     77:         break;
                     78:       case token_long_seq:
                     79:         len = getc(fp) << 16;
                     80:         len = len+(getc(fp) << 8);
                     81:         len = len+getc(fp);
                     82:        seq = c & token_mask;
                     83:         sequence(seq, len, last);
                     84:        if (seq != sequenceContinued) last = seq;
                     85:         break;
                     86:       default:
                     87:         shortnum((c << 8)+getc(fp)-INTEGER_ZERO);
                     88:        last = 0;
                     89:         break;
                     90:       }
                     91:     }
                     92:   /* Shouldn't get here if file ends properly! */
                     93:   fprintf(stderr, "(%d) Unexpected EOF\n", filepos);
                     94:   exit(2);
                     95:   }
                     96: 
                     97: 
                     98: #ifndef debug
                     99: operator(op)
                    100:   int op;
                    101:   {
                    102:   switch (op)
                    103:     {
                    104:     case OP_makevec:                 op_makevec();                break;
                    105:     case OP_makeveclu:               op_makeveclu();             break;
                    106:     case OP_rotate:                  op_rotate();                 break;
                    107:     case OP_scale:                   op_scale();                  break;
                    108:     case OP_scale2:                  op_scale2();                 break;
                    109:     case OP_concat:                  op_concat();                 break;
                    110:     case OP_beginBlock:              op_beginblock();             break;
                    111:     case OP_endBlock:                op_endblock();               return(1);
                    112:     case OP_beginBody:              op_beginbody();              break;
                    113:     case OP_endBody:                op_endbody();                break;
                    114:     default:                         op_unknown(op);              break;
                    115:     }
                    116:   return (0);
                    117:   }
                    118: 
                    119: sequence(type, len, last)
                    120:   int type, len, last;
                    121:   {
                    122:   switch (type)
                    123:     {
                    124:     case sequenceComment:               seq_comment(len);           break;
                    125:     case sequenceIdentifier:            seq_identifier(len);        break;
                    126:     case sequenceInteger:               seq_integer(len);           break;
                    127:     case sequenceLargeVector:           seq_largevector(len);       break;
                    128:     case sequenceRational:              seq_rational(len);          break;
                    129:     case sequenceString:                seq_string(len);            break;
                    130:     default:                            seq_unknown(type, len);     break;
                    131:     }
                    132:   }
                    133: 
                    134: #else
                    135: operator(op)
                    136:   int op;
                    137:   {
                    138:   switch (op)
                    139:     {
                    140:     case OP_makevec:
                    141:       fprintf(stderr, "op_makevec\n");
                    142:       op_makevec();
                    143:       break;
                    144:     case OP_do:
                    145:       fprintf(stderr, "op_do\n");
                    146:       op_do();
                    147:       break;
                    148:     case OP_pop:
                    149:       fprintf(stderr, "op_pop\n");
                    150:       op_pop();
                    151:       break;
                    152:     case OP_copy:
                    153:       fprintf(stderr, "op_copy\n");
                    154:       op_copy();
                    155:       break;
                    156:     case OP_dup:
                    157:       fprintf(stderr, "op_dup\n");
                    158:       op_dup();
                    159:       break;
                    160:     case OP_roll:
                    161:       fprintf(stderr, "op_roll\n");
                    162:       op_roll();
                    163:       break;
                    164:     case OP_exch:
                    165:       fprintf(stderr, "op_exch\n");
                    166:       op_exch();
                    167:       break;
                    168:     case OP_nop:
                    169:       fprintf(stderr, "op_nop\n");
                    170:       op_nop();
                    171:       break;
                    172:     case OP_translate:
                    173:       fprintf(stderr, "op_translate\n");
                    174:       op_translate();
                    175:       break;
                    176:     case OP_rotate:
                    177:       fprintf(stderr, "op_rotate\n");
                    178:       op_rotate();
                    179:       break;
                    180:     case OP_scale:
                    181:       fprintf(stderr, "op_scale\n");
                    182:       op_scale();
                    183:       break;
                    184:     case OP_scale2:
                    185:       fprintf(stderr, "op_scale2\n");
                    186:       op_scale2();
                    187:       break;
                    188:     case OP_concat:
                    189:       fprintf(stderr, "op_concat\n");
                    190:       op_concat();
                    191:       break;
                    192:     case OP_makepixelarray:
                    193:       fprintf(stderr, "op_makepixelarray\n");
                    194:       op_makepixelarray();
                    195:       break;
                    196:     case OP_extractpixelarray:
                    197:       fprintf(stderr, "op_extractpixelarray\n");
                    198:       op_extractpixelarray();
                    199:       break;
                    200:     case OP_finddecompressor:
                    201:       fprintf(stderr, "op_finddecompressor\n");
                    202:       op_finddecompressor();
                    203:       break;
                    204:     case OP_makegray:
                    205:       fprintf(stderr, "op_makegray\n");
                    206:       op_makegray();
                    207:       break;
                    208:     case OP_findcolor:
                    209:       fprintf(stderr, "op_findcolor\n");
                    210:       op_findcolor();
                    211:       break;
                    212:     case OP_findcoloroperator:
                    213:       fprintf(stderr, "op_findcoloroperator\n");
                    214:       op_findcoloroperator();
                    215:       break;
                    216:     case OP_findcolormodeloperator:
                    217:       fprintf(stderr, "op_findcolormodeloperator\n");
                    218:       op_findcolormodeloperator();
                    219:       break;
                    220:     case OP_beginBlock:
                    221:       fprintf(stderr, "op_beginblock\n");
                    222:       op_beginblock();
                    223:       break;
                    224:     case OP_endBlock:
                    225:       fprintf(stderr, "op_endblock\n");
                    226:       op_endblock();
                    227:       return(1);
                    228:     case OP_beginBody:              ;                            break;
                    229:     case OP_endBody:                ;                            break;
                    230:     default:
                    231:       fprintf(stderr, "op_unknown\n");
                    232:       op_unknown(op);
                    233:       break;
                    234:     }
                    235:   return (0);
                    236:   }
                    237: 
                    238: sequence(type, len, last)
                    239:   int type, len, last;
                    240:   {
                    241:   switch (type)
                    242:     {
                    243:     case sequenceAdaptivePixelVector:
                    244:       fprintf(stderr, "seq_adaptivepixel\n");
                    245:       seq_adaptivepixel(len);
                    246:       break;
                    247:     case sequenceComment:
                    248:       fprintf(stderr, "seq_comment\n");
                    249:       seq_comment(len);
                    250:       break;
                    251:     case sequenceCompressedPixelVector:
                    252:       fprintf(stderr, "seq_compressedpixel\n");
                    253:       seq_compressedpixel(len);
                    254:       break;
                    255:     case sequenceContinued:
                    256:       fprintf(stderr, "seq_continued\n");
                    257:       break;
                    258:     case sequenceIdentifier:
                    259:       fprintf(stderr, "seq_identifier\n");
                    260:       seq_identifier(len);
                    261:       break;
                    262:     case sequenceInsertFile:
                    263:       fprintf(stderr, "seq_insertfile\n");
                    264:       seq_insertfile(len);
                    265:       break;
                    266:     case sequenceInteger:
                    267:       fprintf(stderr, "seq_integer\n");
                    268:       seq_integer(len);
                    269:       break;
                    270:     case sequenceLargeVector:
                    271:       fprintf(stderr, "seq_largevector\n");
                    272:       seq_largevector(len);
                    273:       break;
                    274:     case sequencePackedPixelVector:
                    275:       fprintf(stderr, "seq_packedpixel\n");
                    276:       seq_packedpixel(len);
                    277:       break;
                    278:     case sequenceRational:
                    279:       fprintf(stderr, "seq_rational\n");
                    280:       seq_rational(len);
                    281:       break;
                    282:     case sequenceString:
                    283:       fprintf(stderr, "seq_string\n");
                    284:       seq_string(len);
                    285:       break;
                    286:     default:
                    287:       fprintf(stderr, "seq_unknown\n");
                    288:       seq_unknown(type, len);     
                    289:       break;
                    290:     }
                    291:   }
                    292: 
                    293: #endif
                    294: 

unix.superglobalmegacorp.com

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