From 399a1df04754365303cf43bc6446805890c452e5 Mon Sep 17 00:00:00 2001 From: Sam Harwell Date: Sat, 9 Aug 2014 10:54:04 -0500 Subject: [PATCH] Add regression tests for #677 --- .../org/antlr/v4/test/TestLeftRecursion.java | 64 +++++++++++++++++++ 1 file changed, 64 insertions(+) diff --git a/tool/test/org/antlr/v4/test/TestLeftRecursion.java b/tool/test/org/antlr/v4/test/TestLeftRecursion.java index 202fd5e61..b5640da4b 100644 --- a/tool/test/org/antlr/v4/test/TestLeftRecursion.java +++ b/tool/test/org/antlr/v4/test/TestLeftRecursion.java @@ -342,6 +342,70 @@ public class TestLeftRecursion extends BaseTest { runTests(grammar, tests, "s"); } + /** + * This is a regression test for antlr/antlr4#677 "labels not working in + * grammar file". + * https://github.com/antlr/antlr4/issues/677 + * + *

This test treats {@code ,} and {@code >>} as part of a single compound + * operator (similar to a ternary operator).

+ */ + @Test public void testReturnValueAndActionsList1() throws Exception { + String grammar = + "grammar T;\n" + + "s @after {System.out.println($ctx.toStringTree(this));} : expr EOF;\n" + + "expr:\n" + + " a=expr '*' a=expr #Factor\n" + + " | b+=expr (',' b+=expr)* '>>' c=expr #Send\n" + + " | ID #JustId //semantic check on modifiers\n" + + ";\n" + + "\n" + + "ID : ('a'..'z'|'A'..'Z'|'_')\n" + + " ('a'..'z'|'A'..'Z'|'0'..'9'|'_')*\n" + + ";\n" + + "\n" + + "WS : [ \\t\\n]+ -> skip ;\n"; + String[] tests = { + "a*b", "(s (expr (expr a) * (expr b)) )", + "a,c>>x", "(s (expr (expr a) , (expr c) >> (expr x)) )", + "x", "(s (expr x) )", + "a*b,c,x*y>>r", "(s (expr (expr (expr a) * (expr b)) , (expr c) , (expr (expr x) * (expr y)) >> (expr r)) )", + }; + runTests(grammar, tests, "s"); + } + + /** + * This is a regression test for antlr/antlr4#677 "labels not working in + * grammar file". + * https://github.com/antlr/antlr4/issues/677 + * + *

This test treats the {@code ,} and {@code >>} operators separately.

+ */ + @Test public void testReturnValueAndActionsList2() throws Exception { + String grammar = + "grammar T;\n" + + "s @after {System.out.println($ctx.toStringTree(this));} : expr EOF;\n" + + "expr:\n" + + " a=expr '*' a=expr #Factor\n" + + " | b+=expr ',' b+=expr #Comma\n" + + " | b+=expr '>>' c=expr #Send\n" + + " | ID #JustId //semantic check on modifiers\n" + + ";\n" + + "\n" + + "ID : ('a'..'z'|'A'..'Z'|'_')\n" + + " ('a'..'z'|'A'..'Z'|'0'..'9'|'_')*\n" + + ";\n" + + "\n" + + "WS : [ \\t\\n]+ -> skip ;\n"; + String[] tests = { + "a*b", "(s (expr (expr a) * (expr b)) )", + "a,c>>x", "(s (expr (expr (expr a) , (expr c)) >> (expr x)) )", + "x", "(s (expr x) )", + "a*b,c,x*y>>r", "(s (expr (expr (expr (expr (expr a) * (expr b)) , (expr c)) , (expr (expr x) * (expr y))) >> (expr r)) )", + }; + runTests(grammar, tests, "s"); + } + @Test public void testLabelsOnOpSubrule() throws Exception { String grammar = "grammar T;\n" +