diff options
Diffstat (limited to 'testsuite/tests/indexed-types/should_compile/T2850.hs')
-rw-r--r-- | testsuite/tests/indexed-types/should_compile/T2850.hs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/testsuite/tests/indexed-types/should_compile/T2850.hs b/testsuite/tests/indexed-types/should_compile/T2850.hs new file mode 100644 index 0000000000..bdb423b6eb --- /dev/null +++ b/testsuite/tests/indexed-types/should_compile/T2850.hs @@ -0,0 +1,21 @@ +{-# LANGUAGE GeneralizedNewtypeDeriving, TypeFamilies, FlexibleContexts, FlexibleInstances #-}
+
+module T2850 where
+
+class K a where
+ bar :: a -> a
+
+class K (B a) => M a where
+ data B a :: *
+ foo :: B a -> B a
+
+instance M Bool where
+ data B Bool = B1Bool Bool | B2Bool Bool
+ foo = id
+
+instance K (B Bool) where
+ bar = id
+
+instance M Int where
+ newtype B Int = BInt (B Bool) deriving K
+ foo = id
|