.. | ||
.gitignore | ||
check.sh | ||
lexer.l | ||
parser-lalr-main.c | ||
parser-lalr.y | ||
raw-string-literal-ambiguity.md | ||
README.md | ||
RustLexer.g4 | ||
testparser.py | ||
tokens.h | ||
verify.rs | ||
xidcontinue.g4 | ||
xidstart.g4 |
Reference grammar.
Uses antlr4 and a custom Rust tool to compare
ASTs/token streams generated. You can use the make check-lexer
target to
run all of the available tests.
The build of the rust part is included with make tidy
and can be run with make check-build-lexer-verifier
.
Manual build
To use manually, assuming antlr4 is installed at /usr/share/java/antlr-complete.jar
:
antlr4 RustLexer.g4
javac -classpath /usr/share/java/antlr-complete.jar *.java
rustc -O verify.rs
for file in ../*/**.rs; do
echo $file;
grun RustLexer tokens -tokens < "$file" | ./verify "$file" RustLexer.tokens || break
done
Note that the ../*/**.rs
glob will match every *.rs
file in the above
directory and all of its recursive children. This is a Zsh extension.
Cleanup
To cleanup you can use a command like this:
rm -f verify *.class *.java *.tokens