Test Trac #9708
authorSimon Peyton Jones <simonpj@microsoft.com>
Thu, 30 Oct 2014 11:39:39 +0000 (11:39 +0000)
committerSimon Peyton Jones <simonpj@microsoft.com>
Tue, 4 Nov 2014 10:38:02 +0000 (10:38 +0000)
testsuite/tests/typecheck/should_compile/T9708.hs [new file with mode: 0644]
testsuite/tests/typecheck/should_compile/T9708.stderr [new file with mode: 0644]
testsuite/tests/typecheck/should_compile/all.T

diff --git a/testsuite/tests/typecheck/should_compile/T9708.hs b/testsuite/tests/typecheck/should_compile/T9708.hs
new file mode 100644 (file)
index 0000000..fa6deb2
--- /dev/null
@@ -0,0 +1,10 @@
+{-# LANGUAGE DataKinds, TypeOperators, TypeFamilies #-}
+module TcTypeNatSimple where
+
+import GHC.TypeLits
+import Data.Proxy
+
+type family SomeFun (n :: Nat)
+
+ti7 :: (x <= y, y <= x) => Proxy (SomeFun x) -> Proxy y -> ()
+ti7 _ _ = ()
diff --git a/testsuite/tests/typecheck/should_compile/T9708.stderr b/testsuite/tests/typecheck/should_compile/T9708.stderr
new file mode 100644 (file)
index 0000000..fca5df7
--- /dev/null
@@ -0,0 +1,17 @@
+\r
+T9708.hs:9:8:\r
+    Could not deduce (SomeFun x ~ SomeFun y)\r
+    from the context (x <= y, y <= x)\r
+      bound by the type signature for\r
+                 ti7 :: (x <= y, y <= x) => Proxy (SomeFun x) -> Proxy y -> ()\r
+      at T9708.hs:9:8-61\r
+    NB: ‘SomeFun’ is a type function, and may not be injective\r
+    Expected type: Proxy (SomeFun x) -> Proxy y -> ()\r
+      Actual type: Proxy (SomeFun y) -> Proxy y -> ()\r
+    In the ambiguity check for:\r
+      forall (x :: Nat) (y :: Nat).\r
+      (x <= y, y <= x) =>\r
+      Proxy (SomeFun x) -> Proxy y -> ()\r
+    To defer the ambiguity check to use sites, enable AllowAmbiguousTypes\r
+    In the type signature for ‘ti7’:\r
+      ti7 :: (x <= y, y <= x) => Proxy (SomeFun x) -> Proxy y -> ()\r
index 8b8155d..a6cb78a 100644 (file)
@@ -421,3 +421,4 @@ test('MutRec', normal, compile, [''])
 test('T8856', normal, compile, [''])
 test('T9117', normal, compile, [''])
 test('T9117_2', expect_broken('9117'), compile, [''])
+test('T9708', normal, compile_fail, [''])