ANTLR
Z Wikipedii
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(k). Z tego powodu formalny opis parsera 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
Spis treści |
[edytuj] Historia
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 maj 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.
[edytuj] Dodatkowe narzędzia
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.
[edytuj] Przykład
Poniższy przykład, pochodzący z dokumentacji ANTLR, zawiera implementację prostego kalkulatora.
[edytuj] Analizator leksykalny
class CalcLexer extends Lexer;
WS : (' '|'\t'|'\n'| '\r') { $setType = Token.SKIP; };
LPAREN : '(' ;
RPAREN : ')' ;
STAR : '*' ;
PLUS : '+' ;
SEMI : ';' ;
INT : ('0'..'9')+ ;
[edytuj] Analizator składniowy
class CalcParser extends Parser;
options {
buildAST = true;
}
expr : mexpr (PLUS^ mexpr)* SEMI! ;
mexpr : atom (STAR^ atom)* ;
atom : INT ;
[edytuj] Analizator drzewa składni abstrakcyjnej
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());}
;
[edytuj] Wywołanie parsera
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);
}
}
}
[edytuj] Zobacz też
[edytuj] Linki zewnętrzne
- Strona domowa projektu ANTLR
- Podręcznik ANTLR w wersji 2 (w języku angielskim)
- Dokumentacja ANTLR w wersji 3 (w języku angielskim)
- Strona domowa projekktu PCCTS
- Język programowania Mantra
- The Definitive ANTLR Reference: Building Domain-Specific Languages książka z opisem ANTLR w wersji 3 (w języku angielskim)
| Hiszpania: pięć bramek "Barcy", hat-trick 19-latka |
|
W spotkaniu 38. kolejki hiszpańskiej Primera Divosion Real Murcia przegrał przed własną publicznością z FC Barceloną 3:5 (1:3).
|
| MÅš: brÄ…zowy medal dla Finlandii |
|
W spotkaniu o trzecie miejsce rozgrywanych w Kanadzie mistrzostw świata w hokeju na lodzie Finlandia pokonała Szwecję 4:0 (2:0, 0:0, 2:0).
|
| Mityng Grand Prix IAAF w Dakarze |
|
Najlepsze wyniki mityngu Grand Prix IAAF w Dakarze uzyskali w pchnięciu kulą Jamajczyk Dorian Scott - 20,52 i Niemka Nadine Kleinert - 19,51.
|
| Olympique Lyon mistrzem Francji! |
|
W spotkaniu 38. kolejki francuskiej Ligue 1 AJ Auxerre przegrało przed własną publicznością z Olympique Lyon 1:3 (0:2). Dzięki temu zwycięstwu podopieczni Alaina Perrina po raz siódmy z rzędu zdobyli tytuł mistrza Francji.
|
| Liga hokeja na trawie: niespodziewana porażka Pocztowca |
|
Hokeiści na trawie Grunwaldu Poznań awansowali do finału mistrzostw Polski. W drugim półfinale pomiędzy Pocztowcem Poznań a AZS AWF Poznań po dwóch spotkaniach jest remis 1-1.
|