diff options
author | Simon Peyton Jones <simonpj@microsoft.com> | 2021-03-13 23:46:50 +0000 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2021-03-31 11:12:52 -0400 |
commit | dbadd672ba7da67533c34d8594ac7f91dde0f415 (patch) | |
tree | 4c40cc05d77aa270d754c4090ebcaa1fbe62d8f4 /testsuite | |
parent | 44774dc591206291d06e6181f599151631062332 (diff) | |
download | haskell-dbadd672ba7da67533c34d8594ac7f91dde0f415.tar.gz |
The result kind of a signature can't mention quantified vars
This patch fixes a small but egregious bug, which allowed
a type signature like
f :: forall a. blah
not to fail if (blah :: a). Acutally this only showed
up as a ASSERT error (#19495).
The fix is very short, but took quite a bit of head scratching
Hence the long Note [Escaping kind in type signatures]
While I was in town, I also added a short-cut for the
common case of having no quantifiers to tcImplicitTKBndrsX.
Metric Decrease:
T9198
Metric Increase:
T9198
Diffstat (limited to 'testsuite')
-rw-r--r-- | testsuite/tests/dependent/should_fail/T16391b.stderr | 7 | ||||
-rw-r--r-- | testsuite/tests/dependent/should_fail/T19495.hs | 14 | ||||
-rw-r--r-- | testsuite/tests/dependent/should_fail/all.T | 7 |
3 files changed, 25 insertions, 3 deletions
diff --git a/testsuite/tests/dependent/should_fail/T16391b.stderr b/testsuite/tests/dependent/should_fail/T16391b.stderr index 35b5448917..2209886a89 100644 --- a/testsuite/tests/dependent/should_fail/T16391b.stderr +++ b/testsuite/tests/dependent/should_fail/T16391b.stderr @@ -1,6 +1,7 @@ T16391b.hs:10:8: error: - • Quantified type's kind mentions quantified type variable - type: ‘forall (r :: RuntimeRep). T r’ - where the body of the forall has this kind: ‘TYPE r’ + • Expected a type, but ‘T r’ has kind ‘TYPE r’ + ‘r’ is a rigid type variable bound by + the type signature for ‘foo’ + at T16391b.hs:10:1-10 • In the type signature: foo :: T r diff --git a/testsuite/tests/dependent/should_fail/T19495.hs b/testsuite/tests/dependent/should_fail/T19495.hs new file mode 100644 index 0000000000..e4586895ae --- /dev/null +++ b/testsuite/tests/dependent/should_fail/T19495.hs @@ -0,0 +1,14 @@ +{-# LANGUAGE DataKinds #-} +{-# LANGUAGE PolyKinds #-} +{-# LANGUAGE TypeFamilies #-} + +module T19495 where +-- This test is a copy of T16391b, but run with -ddump-tc-trace +-- which (in #19495) triggered a panic + +import GHC.Exts + +type family T (r :: RuntimeRep) :: TYPE r + +foo :: T r +foo = foo diff --git a/testsuite/tests/dependent/should_fail/all.T b/testsuite/tests/dependent/should_fail/all.T index e8705af1e5..a180223eb2 100644 --- a/testsuite/tests/dependent/should_fail/all.T +++ b/testsuite/tests/dependent/should_fail/all.T @@ -53,7 +53,14 @@ test('T16326_Fail9', normal, compile_fail, ['']) test('T16326_Fail10', normal, compile_fail, ['']) test('T16326_Fail11', normal, compile_fail, ['']) test('T16326_Fail12', normal, compile_fail, ['']) + test('T16391b', normal, compile_fail, ['-fprint-explicit-runtime-reps']) + +# T16391b got an ASSERT error during -ddump-tc-trace (#19495) +# So we run it again with -ddump-tc-trace and a new name +# Little changes in the trace output don't matter; just search for "panic!" +test('T19495', [ grep_errmsg(r'panic!') ], compile_fail, ['-dsuppress-uniques -ddump-tc-trace']) + test('T16344', normal, compile_fail, ['']) test('T16344a', normal, compile_fail, ['']) test('T16418', normal, compile_fail, ['']) |