diff options
Diffstat (limited to 'testsuite/tests/unlifted-datatypes/should_fail/UnlDataInvalidResKind2.hs')
-rw-r--r-- | testsuite/tests/unlifted-datatypes/should_fail/UnlDataInvalidResKind2.hs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/testsuite/tests/unlifted-datatypes/should_fail/UnlDataInvalidResKind2.hs b/testsuite/tests/unlifted-datatypes/should_fail/UnlDataInvalidResKind2.hs new file mode 100644 index 0000000000..427e41bf0c --- /dev/null +++ b/testsuite/tests/unlifted-datatypes/should_fail/UnlDataInvalidResKind2.hs @@ -0,0 +1,22 @@ +{-# LANGUAGE UnliftedDatatypes #-} +{-# LANGUAGE TypeFamilies #-} +{-# LANGUAGE TypeFamilyDependencies #-} +{-# LANGUAGE PolyKinds #-} +{-# LANGUAGE GADTs #-} +{-# LANGUAGE KindSignatures #-} +{-# LANGUAGE TypeApplications #-} +{-# LANGUAGE RankNTypes #-} + +module UnlDataInvalidResKind2 where + +import GHC.Exts +import GHC.Types + +type Interpret :: Bool -> RuntimeRep +type family Interpret b = r | r -> b where + Interpret True = BoxedRep Lifted + Interpret False = BoxedRep Unlifted + +-- Not allowed, although well-typed after type fam reduction +type A :: TYPE (Interpret b) +data A = MkA Int |