diff options
author | Ryan Scott <ryan.gl.scott@gmail.com> | 2020-04-03 08:53:14 -0400 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2020-04-04 07:07:58 -0400 |
commit | bd75e5da0f1f05f107325733b570bf28b379d2f2 (patch) | |
tree | 3da9fb9c1427ea99205a08546126b6ee4e2d4411 /testsuite | |
parent | 40a85563a46c682eaab5fdf970f7c46afca78cb3 (diff) | |
download | haskell-bd75e5da0f1f05f107325733b570bf28b379d2f2.tar.gz |
Enable ImpredicativeTypes internally when typechecking selector bindings
This is necessary for certain record selectors with higher-rank
types, such as the examples in #18005. See
`Note [Impredicative record selectors]` in `TcTyDecls`.
Fixes #18005.
Diffstat (limited to 'testsuite')
-rw-r--r-- | testsuite/tests/typecheck/should_compile/T18005.hs | 30 | ||||
-rw-r--r-- | testsuite/tests/typecheck/should_compile/all.T | 1 |
2 files changed, 31 insertions, 0 deletions
diff --git a/testsuite/tests/typecheck/should_compile/T18005.hs b/testsuite/tests/typecheck/should_compile/T18005.hs new file mode 100644 index 0000000000..9b4ddbd366 --- /dev/null +++ b/testsuite/tests/typecheck/should_compile/T18005.hs @@ -0,0 +1,30 @@ +{-# LANGUAGE PatternSynonyms #-} +{-# LANGUAGE RankNTypes #-} +{-# LANGUAGE ViewPatterns #-} +module T18005 where + +type S1 = Int -> (forall a. a -> a) -> Int + +data T1a = MkT1a {unT1a :: S1} + | Dummy1 + +newtype T1b = MkT1b S1 + +unT1b' :: T1b -> S1 +unT1b' (MkT1b x) = x + +pattern MkT1b' :: S1 -> T1b +pattern MkT1b' {unT1b} <- (unT1b' -> unT1b) + +type S2 = Int -> forall a. a -> a + +data T2a = MkT2a {unT2a :: S2} + | Dummy2 + +newtype T2b = MkT2b S2 + +unT2b' :: T2b -> S2 +unT2b' (MkT2b x) = x + +pattern MkT2b' :: S2 -> T2b +pattern MkT2b' {unT2b} <- (unT2b' -> unT2b) diff --git a/testsuite/tests/typecheck/should_compile/all.T b/testsuite/tests/typecheck/should_compile/all.T index dd416ad2de..9b60c6cfb0 100644 --- a/testsuite/tests/typecheck/should_compile/all.T +++ b/testsuite/tests/typecheck/should_compile/all.T @@ -701,3 +701,4 @@ test('T17710', normal, compile, ['']) test('T17792', normal, compile, ['']) test('T17024', normal, compile, ['']) test('T17021a', normal, compile, ['']) +test('T18005', normal, compile, ['']) |