lex_hedit.py

来自「M5,一个功能强大的多处理器系统模拟器.很多针对处理器架构,性能的研究都使用它作」· Python 代码 · 共 48 行

PY
48
字号
# -----------------------------------------------------------------------------# hedit.py## Paring of Fortran H Edit descriptions (Contributed by Pearu Peterson)## These tokens can't be easily tokenized because they are of the following# form:##   nHc1...cn## where n is a positive integer and c1 ... cn are characters.## This example shows how to modify the state of the lexer to parse# such tokens# -----------------------------------------------------------------------------import syssys.path.insert(0,"..")import ply.lex as lextokens = (    'H_EDIT_DESCRIPTOR',    )# Tokenst_ignore = " \t\n"def t_H_EDIT_DESCRIPTOR(t):    r"\d+H.*"                     # This grabs all of the remaining text    i = t.value.index('H')    n = eval(t.value[:i])    # Adjust the tokenizing position    t.lexer.lexpos -= len(t.value) - (i+1+n)    t.value = t.value[i+1:i+1+n]    return tdef t_error(t):    print "Illegal character '%s'" % t.value[0]    t.lexer.skip(1)# Build the lexerlex.lex()lex.runmain(data="3Habc 10Habcdefghij 2Hxy")

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?