summaryrefslogtreecommitdiff
path: root/testsuite/tests/polykinds/T8566a.hs
blob: 22b628553f0b99fc79a6062e3e9a70acc3a4c266 (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
{-# LANGUAGE DataKinds                  #-}
{-# LANGUAGE PolyKinds                  #-}
{-# LANGUAGE TypeFamilies               #-}
{-# LANGUAGE GADTs                      #-}
{-# LANGUAGE ScopedTypeVariables        #-}
{-# LANGUAGE TypeOperators              #-}
module T8566a where

import Data.Kind (Type)

data Field = forall k. APP k [Field]

data InField (u :: Field) :: Type where
  A :: AppVars t (ExpandField args) -> InField (APP t args)

type family ExpandField (args :: [Field]) :: [Type]
type family AppVars (t :: k) (vs :: [Type]) :: Type

-- This function fails to compile, because we discard
-- 'given' kind equalities.  See comment 7 in Trac #8566
-- This is really a bug, I claim
unA :: InField (APP t args) -> AppVars t (ExpandField args)
unA (A x) = x