Sha256: c405e92599f72a18f5bcb7c836af712b0cf658465c37a662fa36ee852c9fcaef

Contents?: true

Size: 1.11 KB

Versions: 8

Compression:

Stored size: 1.11 KB

Contents

# -----------------------------------------------------------------------------
# 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 sys
if ".." not in sys.path: sys.path.insert(0,"..")

import ply.lex as lex

tokens = (
    'H_EDIT_DESCRIPTOR',
    )

# Tokens
t_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 t                                  
    
def t_error(t):
    print("Illegal character '%s'" % t.value[0])
    t.lexer.skip(1)
    
# Build the lexer
lex.lex()
lex.runmain(data="3Habc 10Habcdefghij 2Hxy")



Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
webruby-0.2.7 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.2.5 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.2.4 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.2.2 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.2.1 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.1.2 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.1.1 modules/emscripten/third_party/ply/test/lex_hedit.py
webruby-0.1.0 modules/emscripten/third_party/ply/test/lex_hedit.py