7
#define SIZE (10*1024*1024)
8
char *buffer = (char*)malloc(SIZE);
9
Relooper::SetOutputBuffer(buffer, SIZE);
11
Block *b0 = new Block("print('entry'); var label; var state; var decisions = [2, 2, 1, 3, 2, 2, 1, 3, 2, 3, 3, 1, 3, 2, 1]; var index = 0; function check() { if (index == decisions.length) throw 'HALT'; return decisions[index++] }");
12
Block *b1 = new Block("print(1); state = check();");
13
Block *b2 = new Block("print(2); state = check();");
14
Block *b3 = new Block("print(3); state = check();");
15
Block *b4 = new Block("print(4); state = check();");
16
b0->AddBranchTo(b2, "state == 2");
17
b0->AddBranchTo(b4, NULL);
18
b1->AddBranchTo(b1, NULL);
19
b2->AddBranchTo(b2, NULL);
20
b3->AddBranchTo(b1, NULL);
21
b4->AddBranchTo(b4, "state == 4");
22
b4->AddBranchTo(b3, NULL);