编译原理学习

第二章 一个简单语法制导编译器

根据语法制导定义,使用python实现了一个简单的语法制导翻译器,供大家参考。
m1.py:简单的词法分析模块

import re 
def parse(str):
    tokens = re.findall(r'for|if|\(|\)|other|expr|;',str)
    print(tokens)
    return tokens


if __name__ == '__main__':
    str='''for ( ;expr; expr) 
          other 
    '''
    parse(str)

m2.py:语法制导模块

import m2
str='''for ( ;expr; expr) 
          other 
    '''

lookahead = None

tokens = m2.parse(str)

nextTerminal = iter(tokens)

lookahead = next(nextTerminal)

def stmt():
    global lookahead
    if(lookahead == 'expr'):
        match('expr')
        match(';')
    elif(lookahead == 'if'):
        match('if')
        match('(')
        optexpr()
        match(')')
        stmt()
    elif(lookahead == 'for'):
        match('for')
        match('(')
        optexpr()
        match(';')
        optexpr()
        match(';')
        optexpr()
        match(')')
        stmt()
    elif(lookahead == 'other'):
        match('other')
    elif(lookahead == None):
        return
    else:
        print('syntax error')    


def match(t):
    global lookahead
    global nextTerminal
    if(lookahead == t):
        try:
            print(lookahead + ' matched')
            lookahead = next(nextTerminal)
        except StopIteration as e:
            lookahead = None
def optexpr():
    global lookahead
    if(lookahead == 'expr'):
        match('expr')
    else:
        print('skip expr')

if __name__ == '__main__':
    stmt()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值