1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
// This file is part of PyANTLR. See LICENSE.txt for license
// details..........Copyright (C) Wolfgang Haefelinger, 2004.
//
// $Id$
options {
language=Python;
}
class rewrite_l extends Lexer;
protected
START
options {
ignore=WS;
}
: id:ID ":="! '('! expr:EXPR ')'!
{
// can access text matched for any rule
print "found "+ id.getText() + "," + expr.getText()
// text will be ID+EXPR minus whitespace
}
;
protected
ID : ( let:LETTER { print "letter " + let.getText() } )+
;
protected
LETTER
: 'a'..'z'
{
s = $getText;
$setText(s.upper())
}
;
protected
EXPR: i:INT! // don't include, but i.getText() has access
{$setText(i.getText())} // effect is if no "!" and no "i:"
| ID
;
protected
INT : ('0'..'9')+
;
// what if ! on rule itself and invoker had !...should
// rule return anything in the token to the invoker? NO!
// make sure 'if' is in the right spot
// What about no ! on caller but ! on called rule?
protected
WS! : ( ' ' // whitespace not saved
| '\t'
| '\n' {$newline}
)+
{$skip} // way to set token type
;
|