码迷,mamicode.com
首页 > 编程语言 > 详细

Brainfuck解析器(Python)

时间:2017-06-30 19:53:22      阅读:3993      评论:0      收藏:0      [点我收藏+]

标签:char   ++   val   span   logs   opcode   nbsp   pre   pytho   

global cs
global ip

global ss
#global sp

global ds
global bp

global tab
global out

cs=++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.
ip = 0

ss = []
#sp = 0

ds = []
bp = 0

tab = 0
out = []

def tab_():
    i = tab
    stab = ‘‘
    while i > 0:
        stab += \t
        i -= 1
    return stab

def push(var):
    global ss
    ss.append(var)

def pop():
    global ss
    return ss.pop()

def op_inc_val():
    global ip
    count = 0
    while True:
        op = cs[ip]            
        ip = ip + 1
        if op == +:
            count = count + 1
        else:
            break
    l = len(ds)
    if l <= bp:
        ds.append(0)
    old = ds[bp]
    old += count
    ds[bp] = old
    print tab_()+ds[%d] += %d                  (%d)%(bp, count, old)

def op_dec_val():
    global ip    
    count = 0
    while True:
        op = cs[ip]            
        ip = ip + 1
        if op == -:
            count = count + 1
        else:
            break
    old = ds[bp]
    old -= count
    ds[bp] = old
    print tab_()+ds[%d] -= %d                  (%d)%(bp, count, old)

def op_inc_dp():
    global bp
    bp = bp + 1

def op_dec_dp():
    global bp
    bp = bp - 1

def op_jmp_fwd():
    global tab
    global ip
    print tab_()+while ds[%d]=%d:%(bp, ds[bp])
    tab=tab + 1
    if ds[bp] != 0:
        curip = ip - 1
        push(curip)
    else:
        c = 1; 
        while c > 0:
            op = cs[ip]
            if op == [:
                c += 1
            elif op == ]:
                c -= 1
            ip += 1

def op_jmp_bck():
    global tab
    global ip
    tab = tab - 1
    if ds[bp] != 0:
        ip = pop()

def op_out():
    print tab_()+putchar(ds[%d])                  (%d)%(bp, ds[bp])
    out.append(ds[bp])

def op_in():
    print tab_()+getchar

end = len(cs)
while ip < end:
    op = cs[ip]
    ip = ip + 1
    if op == +:
        ip = ip - 1
        op_inc_val()
        ip = ip - 1
    elif op == -:
        ip = ip - 1
        op_dec_val()
        ip = ip - 1
    elif op == >:
        op_inc_dp()
    elif op == <:
        op_dec_dp()
    elif op == [:
        op_jmp_fwd()
    elif op == ]:
        op_jmp_bck()
    elif op == .:
        op_out()
    elif op == ,:
        op_in()
    else:
        print invalid opcode
        break
    
print out
str = ‘‘
for c in out:
    str += %c%(c)
print str

 

Brainfuck解析器(Python)

标签:char   ++   val   span   logs   opcode   nbsp   pre   pytho   

原文地址:http://www.cnblogs.com/qintangtao/p/7100191.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!