mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-16 02:28:12 +00:00
1.2 KiB
1.2 KiB
kvast
KeyValue storage for AST
To optimize serialized storage use a concatenated string array and use the sdb array string api
eax=33
0.op=set []0=set,eax,33
0.a=eax
0.b=33
ebx=(8*(eax+4))
0.op=set []0=set,ebx,$1
0.a=ebx
0.b=$1
1.op=mul []1=mul,8,$2
1.a=8
1.b=$2
2.op=add []2=add,eax,4
2.a=eax
2.b=4
ebx=8*(eax+4)+3
0.op=set []0=set,ebx,$3
0.a=ebx
0.b=$3
1.op=mul []1=mul,8,$2
1.a=8
1.b=$2
2.op=add []2=add,eax,4
2.a=eax
2.b=4
3.op=add []3=add,$1,3
3.a=$1
3.b=3
ebx=8*(eax+4+ecx+2)+1
0.op=set
0.a=ebx
0.b=$5
1.op=mul
1.a=8
1.b=$4
( 2.op=add 2.a=eax 2.b=4
// update toplevel b reference 3.op=add 3.a=$2 3.b=ecx
// update toplevel b reference 4.op=add 4.a=$3 4.b=2 }
// update toplevel b reference 5.op=add 5.a=$1 5.b=1
Parsing
Parsing is done by a state machine which reads the expression string and creates a keyvalue string that represents the ESIL instruction.
This is an example
switch (ch) {
case '+':
case '-':
case '*':
case '/':
if (expect_arg) {
expect_arg = ch;
}
break;
}