blob: 5559cb82d377b15e07b3ad8cf60fc5a077046634 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
{-# LANGUAGE GADTs, RankNTypes, ScopedTypeVariables #-}
-- From Yann Regis-Gianas at INRIA
module ShouldCompile where
data T a where
K :: T Int
-- Should fail
i1 :: T a -> a -> Int
i1 t y = (\t1 y1 -> case t1 of K -> y1) t y
-- No type signature; should not type-check,
-- because we can't unify under the equality constraint for K
i1b t y = (\t1 y1 -> case t1 of K -> y1) t y
i2 :: T a -> a -> Int
i2 t (y::b) = case t of { K -> y+(1::Int) }
i3 :: forall a. T a -> a -> Int
i3 t y
= let t1 = t in
let y1 = y in
case t1 of K -> y1
i4 :: forall a. T a -> a -> Int
i4 (t :: T a) (y :: a)
= let t1 = t in
let y1 = y in
case t1 of K -> y1
|