diff options
author | Alexis King <lexi.lambda@gmail.com> | 2020-04-19 13:11:37 -0500 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2020-04-30 01:57:35 -0400 |
commit | 71484b09fa3c676e99785b3d68f69d4cfb14266e (patch) | |
tree | 38df5a81c2394d99c0fa4582e2356d9c7dbd555c /testsuite/tests/parser | |
parent | 8bfb0219587b969d5c8f723c46d433e9493958b4 (diff) | |
download | haskell-71484b09fa3c676e99785b3d68f69d4cfb14266e.tar.gz |
Allow block arguments in arrow control operators
Arrow control operators have their own entries in the grammar, so they
did not cooperate with BlockArguments. This was just a minor oversight,
so this patch adjusts the grammar to add the desired behavior.
fixes #18050
Diffstat (limited to 'testsuite/tests/parser')
5 files changed, 37 insertions, 0 deletions
diff --git a/testsuite/tests/parser/should_compile/BlockArgumentsArrowCmds.hs b/testsuite/tests/parser/should_compile/BlockArgumentsArrowCmds.hs new file mode 100644 index 0000000000..89ac332d31 --- /dev/null +++ b/testsuite/tests/parser/should_compile/BlockArgumentsArrowCmds.hs @@ -0,0 +1,22 @@ +{-# LANGUAGE Arrows, BlockArguments #-} + +module BlockArgumentsArrowCmds where + +import Control.Arrow + +cmdLam :: () -> () +cmdLam = proc () -> (| id \() -> () >- returnA |) () + +cmdCase :: () -> () +cmdCase = proc () -> (| id case () of + () -> () >- returnA |) + +cmdIf :: () -> () +cmdIf = proc () -> (| id if True then () >- returnA else () >- returnA |) + +cmdLet :: () -> () +cmdLet = proc () -> (| id let x = () in x >- returnA |) + +cmdDo :: () -> () +cmdDo = proc () -> (| id do + () >- returnA |) diff --git a/testsuite/tests/parser/should_compile/all.T b/testsuite/tests/parser/should_compile/all.T index 85a7c3c172..fd69d32f0f 100644 --- a/testsuite/tests/parser/should_compile/all.T +++ b/testsuite/tests/parser/should_compile/all.T @@ -86,6 +86,7 @@ test('T3303', [], multimod_compile, ['T3303', '-v0']) test('T3741', normal, compile, ['']) test('DoAndIfThenElse', normal, compile, ['']) test('BlockArguments', normal, compile, ['']) +test('BlockArgumentsArrowCmds', normal, compile, ['']) test('BlockArgumentsLambdaCase', normal, compile, ['']) test('NoBlockArguments', normal, compile, ['']) test('NondecreasingIndentation', normal, compile, ['']) diff --git a/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.hs b/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.hs new file mode 100644 index 0000000000..866b0af4cb --- /dev/null +++ b/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.hs @@ -0,0 +1,7 @@ +{-# LANGUAGE Arrows #-} +module NoBlockArgumentsFailArrowCmds where + +import Control.Arrow + +cmdLam :: () -> () +cmdLam = proc () -> (| id \() -> () >- returnA |) () diff --git a/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.stderr b/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.stderr new file mode 100644 index 0000000000..2a99cda137 --- /dev/null +++ b/testsuite/tests/parser/should_fail/NoBlockArgumentsFailArrowCmds.stderr @@ -0,0 +1,6 @@ + +NoBlockArgumentsFailArrowCmds.hs:7:27: error: + Unexpected lambda command in function application: + \ () -> () >- returnA + You could write it with parentheses + Or perhaps you meant to enable BlockArguments? diff --git a/testsuite/tests/parser/should_fail/all.T b/testsuite/tests/parser/should_fail/all.T index e0000f009e..c6d691bed3 100644 --- a/testsuite/tests/parser/should_fail/all.T +++ b/testsuite/tests/parser/should_fail/all.T @@ -77,6 +77,7 @@ test('NoPatternSynonyms', normal, compile_fail, ['']) test('NoBlockArgumentsFail', normal, compile_fail, ['']) test('NoBlockArgumentsFail2', normal, compile_fail, ['']) test('NoBlockArgumentsFail3', normal, compile_fail, ['']) +test('NoBlockArgumentsFailArrowCmds', normal, compile_fail, ['']) test('NondecreasingIndentationFail', normal, compile_fail, ['']) test('readFailTraditionalRecords1', normal, compile_fail, ['']) test('readFailTraditionalRecords2', normal, compile_fail, ['']) |