parrotcode: Untitled | |
Contents | Language Implementations | bc |
These are some rumblings on using ANTLR 3 for Parrot bc, or with Parrot in general.
See http://www.antlr.org/v3/index.html.
Bc.java needs to find the needed classes. This works for me:
export ANTLR_HOME=/home/bernhard/devel/ANTLR/antlr-3
export PARROT_HOME=/home/bernhard/devel/Parrot/repos/parrot
export CLASSPATH=$ANTLR_HOME/lib/antlr-2.7.6.jar:$ANTLR_HOME/lib/antlr-3.0ea10.jar:$ANTLR_HOME/lib/stringtemplate-2.3b7.jar:$PARROT_HOME/languages/bc/grammar/antlr_3:$PARROT_HOME/languages/bc
And see the targest maintain-java, build-java, test-java in bc/Makefile.
Lexer, Parser and TreeParser are in the same file, speak grammar. C and C++ style comments are accepted.
'+' is one or many
'( )' is for grouping '|' as for alternation "''" Sring delimeter, honoring '\t', '\n', '\r'
'{ }' are actions ';' delimits rules 'grammar <name>', set name of Parser, Name of autogenerated Lexer is generated from it
Tell to generate an AST options { output=AST; ASTLabelType=CommonTree; }
'Sigil $' is for referencing alternations in actions, Lexer items only ???, also for setting returns
'->' Is for tree construction '^' Is for definition and matching of tree nodes
@members declare additional member variables in the parser class
@init ??
scope a stack for symbols
{ channel = 99; } put match into Nirwana
The lexer specification can be in the parser specification. A lexer grammar is automatically generated. 'protected' is gone.
Bernhard Schmalhofer - <Bernhard.Schmalhofer@gmx.de>
L<http://www.antlr.org/>
L<http://www.antlr.org/blog/index.tml>
L<http://www.antlr.org:8080/pipermail/antlr-dev/>
|