summaryrefslogtreecommitdiff
path: root/testsuite
diff options
context:
space:
mode:
authorsheaf <sam.derbyshire@gmail.com>2022-01-26 14:24:48 +0100
committerMarge Bot <ben+marge-bot@smart-cactus.org>2022-02-08 05:27:25 -0500
commita9355e84480e421a22fee57d6ee24d9ec059e128 (patch)
tree7994b81532b131db79c56a25c17d6ee34e1f63dd /testsuite
parentff867c460db9cfc43f5697c8e582f8c1ea4bd572 (diff)
downloadhaskell-a9355e84480e421a22fee57d6ee24d9ec059e128.tar.gz
Allow HasField in quantified constraints
We perform validity checking on user-written HasField instances, for example to disallow: data Foo a = Foo { fld :: Int } instance HasField "fld" (Foo a) Bool However, these checks were also being made on quantified constraints, e.g. data Bar where Bar :: (forall a. HasField s (Foo a) Int) => Proxy s -> Bar This patch simply skips validity checking for quantified constraints, in line with what we already do for equality constraints such as Coercible. Fixes #20989
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/tests/overloadedrecflds/should_compile/T20989.hs38
-rw-r--r--testsuite/tests/overloadedrecflds/should_compile/all.T2
2 files changed, 39 insertions, 1 deletions
diff --git a/testsuite/tests/overloadedrecflds/should_compile/T20989.hs b/testsuite/tests/overloadedrecflds/should_compile/T20989.hs
new file mode 100644
index 0000000000..bf22f170c9
--- /dev/null
+++ b/testsuite/tests/overloadedrecflds/should_compile/T20989.hs
@@ -0,0 +1,38 @@
+{-# LANGUAGE DataKinds #-}
+{-# LANGUAGE FlexibleContexts #-}
+{-# LANGUAGE GADTs #-}
+{-# LANGUAGE QuantifiedConstraints #-}
+{-# LANGUAGE TypeFamilies #-}
+{-# LANGUAGE Haskell2010 #-}
+
+module T20989 where
+
+import Data.Proxy
+ ( Proxy )
+import GHC.Records
+ ( HasField )
+
+data Bar0 where
+ Bar0 :: HasField s r a => Proxy s -> Proxy r -> Proxy a -> Bar0
+
+-- See Note [Validity checking of HasField instances] in GHC.Tc.Validity
+
+-- 1. `HasField _ r _` where r is a variable
+data Bar1 where
+ Bar1 :: (forall r. HasField s r Int) => Proxy s -> Bar1
+
+-- 2. `HasField _ (T ...) _` if T is a data family
+data family Foo2 a
+data Bar2 where
+ Bar2 :: (forall a. HasField s (Foo2 a) Int) => Proxy s -> Bar2
+
+-- 3. `HasField x (T ...) _` where x is a variable,
+-- if T has any fields at all
+data Foo3 a = Foo3 { fld1 :: Int, fld2 :: Bool }
+data Bar3 where
+ Bar3 :: (forall a. HasField s (Foo3 a) Int) => Proxy s -> Bar3
+
+-- 4. `HasField "foo" (T ...) _` if T has a "foo" field.
+data Foo4 a = Foo4 { foo4 :: Int }
+data Bar4 where
+ Bar4 :: (forall a. HasField "foo4" (Foo4 a) Int) => Bar4
diff --git a/testsuite/tests/overloadedrecflds/should_compile/all.T b/testsuite/tests/overloadedrecflds/should_compile/all.T
index 863fbacca8..dd5660b445 100644
--- a/testsuite/tests/overloadedrecflds/should_compile/all.T
+++ b/testsuite/tests/overloadedrecflds/should_compile/all.T
@@ -10,4 +10,4 @@ test('T18999_NoFieldSelectors', normal, compile, [''])
test('T18999_FieldSelectors', normal, compile, [''])
test('T19154', normal, compile, [''])
test('T20723', normal, compile, [''])
-
+test('T20989', normal, compile, [''])