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 = [4, 1, 7, 2, 6, 6, 8]; 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
Block *b5 = new Block("print(5); state = check();");
17
Block *b6 = new Block("print(6); state = check();");
18
Block *b7 = new Block("print(7); state = check();");
19
Block *b8 = new Block("print(8); state = check();");
20
b0->AddBranchTo(b5, NULL);
21
b1->AddBranchTo(b3, NULL);
22
b2->AddBranchTo(b1, NULL);
23
b3->AddBranchTo(b8, "state == 8");
24
b3->AddBranchTo(b1, NULL);
25
b4->AddBranchTo(b3, "state == 3");
26
b4->AddBranchTo(b1, NULL);
27
b5->AddBranchTo(b6, NULL);
28
b6->AddBranchTo(b7, "state == 7");
29
b6->AddBranchTo(b1, NULL);
30
b7->AddBranchTo(b2, NULL);
31
b8->AddBranchTo(b4, "state == 4");
32
b8->AddBranchTo(b2, NULL);