我正在使用这个lex程序来分析每个寄存器的用法,无论它们是用作源,目的地还是用作间接寻址,这些都是我的代码,我必须分析所有12个寄存器......有没有其他有效的方法来做这些反对宣布36个变量和36个规则? (我是学生)。
%{
#include <stdio.h>
int q,w,e,r,t,y,u,i,o,p,a,s = 0;
%}
%%
[push|dec]?+[ ]+(eax|EAX)+[,] q++ ;
[,| ]+(eax|EAX)+[ ]? w++ ;
['[']+(eax|EAX)+[ ]? e++ ;
[push|dec]?+[ ]+(ebx|EBX)+[,] r++ ;
[,| ]+(ebx|EBX)+[ ]? t++ ;
['[']+(ebx|EBX)+[ ]? y++ ;
[push|dec]?+[ ]+(ecx|ECX)+[,] u++ ;
[,| ]+(ecx|ECX)+[ ]? i++ ;
['[']+(ecx|ECX)+[ ]? o++ ;
[push|dec]?+[ ]+(edx|EDX)+[,] p++ ;
[,| ]+(edx|EDX)+[ ]? a++ ;
['[']+(edx|EDX)+[ ]? s++ ;
. ;
%%
main()
{
yylex() ;
printf("EAX as source: %d\n", q) ;
printf("EAX as destination: %d\n", w) ;
printf("EAX as indirect address: %d\n", e) ;
printf("EBX as source: %d\n", r) ;
printf("EBX as destination: %d\n", t) ;
printf("EBX as indirect address: %d\n", y) ;
printf("ECX as source: %d\n", u) ;
printf("ECX as destination: %d\n", i) ;
printf("ECX as indirect address: %d\n", o) ;
printf("EDX as source: %d\n", p) ;
printf("EDX as destination: %d\n", a) ;
printf("EDX as indirect address: %d\n", s) ;
}
这是我的输出:
EAX as source: 56
EAX as destination: 71
EAX as indirect address: 0
EBX as source: 25
EBX as destination: 38
EBX as indirect address: 0
ECX as source: 26
ECX as destination: 30
ECX as indirect address: 0
EDX as source: 30
EDX as destination: 38
EDX as indirect address: 0
ubuntu@ubuntu:~$ ^C
我要分析的文件是this is where the asm file is
答案 0 :(得分:1)
正如我在评论中所说,自从我和lex合作以来已经很久了。但是,这个想法是定义你的寄存器,然后定义一个使用该定义的表达式。
因此,例如,您的lex文件将类似于:
%
R EAX|eax|EBX|ebx|ECX|ecx|EDX|edx
%%
[push|dec]?+[ ]+({R})+[,] q++ ;
[,| ]+({R})+[ ]? w++ ;
['[']+({R})+[ ]? e++ ;
%%
main()
...
我的语法可能不完美,但这是一般的想法。查看一些简单的lex定义示例。