ANTLR
ANTLR (ang. ANother Tool for Language Recognition) to narzędzie służące do tworzenia kompilatorów oraz translatorów z opisu gramatyki zawierającego akcje w języku Java, C++, C# lub Python. Autorem jest Terence Parr, pracujący obecnie na Uniwersytecie w San Francisco.
W przeciwieństwie do narzędzi takich jak Bison czy SableCC, ANTLR generuje parser typu LL(*). Z tego powodu formalny opis analizatora składniowego oraz leksera jest bardzo podobny, a generowany kod jest czytelny.
Domyślnie ANTLR generuje lekser i parser w Javie, a plik z gramatyką ma rozszerzenie .g
Historia
[edytuj | edytuj kod]ANTLR jest rozwinięciem idei zawartych w PCCTS (również autorstwa Terence Parra), który umożliwia generowanie parserów i lekserów dla języka C i C++. 17 maja 2007 została opublikowana nowa wersja oprogramowania oznaczona numerem 3.0. Jest ona wykorzystywana między innymi do tworzenia języka programowania Mantra oraz w implementacji JRuby języka Ruby.
Dodatkowe narzędzia
[edytuj | edytuj kod]Istnieją dwa rozszerzenia dla Eclipse ułatwiające prace z ANTLR: otwarte ANTLR plugin for Eclipse oraz komercyjne ANTLR Studio produkowane przez firmę Placid Systems.
Rozwijane jest także niezależne środowisko ANTLRWorks przeznaczone do pracy z ANTLR w wersji 3.
Przykład
[edytuj | edytuj kod]Poniższy przykład, pochodzący z dokumentacji ANTLR, zawiera implementację prostego kalkulatora.
Analizator leksykalny
[edytuj | edytuj kod]class CalcLexer extends Lexer; WS : (' '|'\t'|'\n'| '\r') { $setType = Token.SKIP; }; LPAREN : '(' ; RPAREN : ')' ; STAR : '*' ; PLUS : '+' ; SEMI : ';' ; INT : ('0'..'9')+ ;
Analizator składniowy
[edytuj | edytuj kod]class CalcParser extends Parser; options { buildAST = true; } expr : mexpr (PLUS^ mexpr)* SEMI! ; mexpr : atom (STAR^ atom)* ; atom : INT ;
Analizator drzewa składni abstrakcyjnej
[edytuj | edytuj kod]class CalcTreeWalker extends TreeParser; expr returns [int r] { int a,b; r=0; } : #(PLUS a=expr b=expr) {r = a+b;} | #(STAR a=expr b=expr) {r = a*b;} | i:INT {r = Integer.parseInt(i.getText());} ;
Wywołanie parsera
[edytuj | edytuj kod]import java.io.DataInputStream; import antlr.CommonAST; class Calc { public static void main(String[] args) { try { CalcLexer lexer = new CalcLexer(new DataInputStream(System.in)); CalcParser parser = new CalcParser(lexer); // Analiza składniowa parser.expr(); CommonAST t = (CommonAST)parser.getAST(); CalcTreeWalker walker = new CalcTreeWalker(); // Analiza drzewa składni abstrakcyjnej // i interpretacja programu int r = walker.expr(t); System.out.println("value is "+r); } catch(Exception e) { System.err.println("exception: "+e); } } }
Zobacz też
[edytuj | edytuj kod]Linki zewnętrzne
[edytuj | edytuj kod]- Strona domowa projektu ANTLR
- Podręcznik ANTLR w wersji 2 (w języku angielskim)
- Dokumentacja ANTLR w wersji 3. antlr.org. [zarchiwizowane z tego adresu (2007-05-27)]. (w języku angielskim)
- Strona domowa projekktu PCCTS
- Język programowania Mantra. linguamantra.org. [zarchiwizowane z tego adresu (2006-10-12)].
- The Definitive ANTLR Reference: Building Domain-Specific Languages książka z opisem ANTLR w wersji 3 (w języku angielskim)