2014-10-11 12:26:29 +01:00
|
|
|
// Copyright 2014 Paul Sokolovsky.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2014-10-15 02:43:13 +01:00
|
|
|
#include "re1.5.h"
|
2014-10-11 12:26:29 +01:00
|
|
|
|
|
|
|
void re1_5_dumpcode(ByteProg *prog)
|
|
|
|
{
|
|
|
|
int pc = 0;
|
|
|
|
char *code = prog->insts;
|
|
|
|
while (pc < prog->bytelen) {
|
|
|
|
printf("%2d: ", pc);
|
|
|
|
switch(code[pc++]) {
|
|
|
|
default:
|
|
|
|
assert(0);
|
|
|
|
// re1_5_fatal("printprog");
|
|
|
|
case Split:
|
|
|
|
printf("split %d (%d)\n", pc + (signed char)code[pc] + 1, (signed char)code[pc]);
|
|
|
|
pc++;
|
|
|
|
break;
|
|
|
|
case RSplit:
|
|
|
|
printf("rsplit %d (%d)\n", pc + (signed char)code[pc] + 1, (signed char)code[pc]);
|
|
|
|
pc++;
|
|
|
|
break;
|
|
|
|
case Jmp:
|
|
|
|
printf("jmp %d (%d)\n", pc + (signed char)code[pc] + 1, (signed char)code[pc]);
|
|
|
|
pc++;
|
|
|
|
break;
|
|
|
|
case Char:
|
|
|
|
printf("char %c\n", code[pc++]);
|
|
|
|
break;
|
|
|
|
case Any:
|
|
|
|
printf("any\n");
|
|
|
|
break;
|
2014-10-16 11:56:13 +01:00
|
|
|
case Class:
|
|
|
|
case ClassNot: {
|
|
|
|
int num = code[pc];
|
|
|
|
printf("class%s %d", (code[pc - 1] == ClassNot ? "not" : ""), num);
|
|
|
|
pc++;
|
2014-10-15 02:43:13 +01:00
|
|
|
while (num--) {
|
|
|
|
printf(" 0x%02x-0x%02x", code[pc], code[pc + 1]);
|
|
|
|
pc += 2;
|
|
|
|
}
|
|
|
|
printf("\n");
|
|
|
|
break;
|
|
|
|
}
|
2014-10-11 12:26:29 +01:00
|
|
|
case Match:
|
|
|
|
printf("match\n");
|
|
|
|
break;
|
|
|
|
case Save:
|
|
|
|
printf("save %d\n", (unsigned char)code[pc++]);
|
|
|
|
break;
|
|
|
|
case Bol:
|
|
|
|
printf("assert bol\n");
|
|
|
|
break;
|
|
|
|
case Eol:
|
|
|
|
printf("assert eol\n");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
printf("Bytes: %d, insts: %d\n", prog->bytelen, prog->len);
|
|
|
|
}
|