Szukaj…


Setup TestRig

ANTLR zawiera narzędzie testujące w swojej bibliotece wykonawczej, narzędzie to może być używane do wyświetlania informacji opisujących, w jaki sposób parsowanie jest wykonywane w celu dopasowania danych wejściowych do zdefiniowanych reguł w pliku gramatyki.

Aby skorzystać z tego narzędzia zawartego w pliku jar ANTLR, należy skonfigurować ścieżkę klas systemu, aby umożliwić dostęp zarówno do narzędzia ANTLR, jak i biblioteki wykonawczej:

export CLASSPATH=".:/usr/local/lib/antlr-4.5.3-complete.jar:$CLASSPATH"

Uwaga: Upewnij się, że kropka poprzedza dowolną ścieżkę, aby maszyna wirtualna Java nie widziała klas w bieżącym katalogu roboczym.

Aliasów można używać w systemach Linux / MAC / Unix, aby uprościć używane polecenia:

alias antlr4='java -jar /usr/local/lib/antlr-4.5.3-complete.jar' 
//or any directory where your jar is located

Uwaga: konfiguracja aliasów i ścieżki klas w systemie Windows może być bardziej skomplikowana, zobacz tutaj, aby uzyskać bardziej szczegółowe informacje.

Dostęp do TestRig

Po skonfigurowaniu aliasu możesz skonfigurować TestRig w następujący sposób, ponownie zaleca się użycie aliasu, ponieważ zmniejsza on czas wymagany do wykonania akcji:

alias grun='java org.antlr.v4.runtime.misc.TestRig'

Jeśli nie chcesz konfigurować aliasu w systemie Windows, możesz uzyskać dostęp do TestRig, uruchamiając następujące polecenie w tej samej lokalizacji, co katalog jar ANTLR:

java -cp .;antlr.4.5.3-complete.jar org.antlr.v4.runtime.misc.TestRig
//or
java -cp .;antlr.4.5.3-complete.jar org.antlr.v4.gui.TestRig

Aby uruchomić TestRig na gramatyce, możesz przekazać parametry gramatyki w następujący sposób:

grun yourGrammar yourRule -tree //using the setup alias
java -cp .;antlr.4.5.3-complete.jar org.antlr.v4.gui.TestRig yourGrammar YourRule -tree //on windows with no alias
java -cp .;antlr.4.5.3-complete.jar org.antlr.v4.gui.TestRig yourGrammar Hello r -tree
//Windows with the grammar Hello.g4 starting from the rule 'r'.

Buduj gramatykę za pomocą wizualnego drzewa analizy

Określenie opcji wiersza polecenia -gui podczas uruchamiania gramatyki ANTLR na platformie testowej spowoduje wyświetlenie okna z wizualną reprezentacją parsowanego drzewa. Na przykład:

Biorąc pod uwagę następującą gramatykę:

JSON.g4

/** Taken from "The Definitive ANTLR 4 Reference" by Terence Parr */

// Derived from http://json.org
grammar JSON;

json
   : value
   ;

object
   : '{' pair (',' pair)* '}'
   | '{' '}'
   ;

pair
   : STRING ':' value
   ;

array
   : '[' value (',' value)* ']'
   | '[' ']'
   ;

value
   : STRING
   | NUMBER
   | object
   | array
   | 'true'
   | 'false'
   | 'null'
   ;


STRING
   : '"' (ESC | ~ ["\\])* '"'
   ;
fragment ESC
   : '\\' (["\\/bfnrt] | UNICODE)
   ;
fragment UNICODE
   : 'u' HEX HEX HEX HEX
   ;
fragment HEX
   : [0-9a-fA-F]
   ;
NUMBER
   : '-'? INT '.' [0-9] + EXP? | '-'? INT EXP | '-'? INT
   ;
fragment INT
   : '0' | [1-9] [0-9]*
   ;
// no leading zeros
fragment EXP
   : [Ee] [+\-]? INT
   ;
// \- since - means "range" inside [...]
WS
   : [ \t\n\r] + -> skip
   ;

Biorąc pod uwagę następujący plik JSON:

przyklad.json

{
  "name": "John Doe",
  "age": 25,
  "address": {
    "streetAddress": "21 2nd Street",
    "city": "New York",
    "state": "NY",
    "postalCode": "10021-3100"
  },
  "phoneNumbers": [
    {
      "type": "home",
      "number": "212 555-1234"
    },
    {
      "type": "mobile",
      "number": "123 456-7890"
    }
  ],
  "children": [],
  "spouse": null
}

Następująca składnia wiersza poleceń:

export CLASSPATH=".:/usr/local/lib/antlr-4.0-complete.jar:$CLASSPATH"                                                                                      
alias antlr4='java -jar /usr/local/lib/antlr-4.0-complete.jar'                                                                                             
alias grun='java org.antlr.v4.runtime.misc.TestRig'

antlr4 -o . -lib . -no-listener -no-visitor  JSON.g4; javac *.java; grun JSON json -gui example.json

spowoduje wygenerowanie plików .java i .tokens , a także skompilowanych plików .class :

JSON.g4                        JSONLexer.class                JSONListener.java JSONParser$PairContext.class   JSON.tokens                    JSONLexer.java JSONParser$ArrayContext.class  JSONParser$ValueContext.class  JSONBaseListener.class JSONLexer.tokens               JSONParser$JsonContext.class   JSONParser.class
JSONBaseListener.java          JSONListener.class
JSONParser$ObjectContext.class JSONParser.java

oraz następujące drzewo analizy:

wprowadź opis zdjęcia tutaj



Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow