diff options
author | Ryan Scott <ryan.gl.scott@gmail.com> | 2022-10-23 17:22:43 -0400 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2022-10-26 00:01:24 -0400 |
commit | f7bfb40c9010ff34d301c9cf8c805261699daad5 (patch) | |
tree | b81c242368617664e2f573e5ba99add79aa93eed /testsuite/tests/gadt/T22235.hs | |
parent | f5a486eb3233b0e577333f04d2087d0f6741af87 (diff) | |
download | haskell-f7bfb40c9010ff34d301c9cf8c805261699daad5.tar.gz |
Broaden the in-scope sets for liftEnvSubst and composeTCvSubst
This patch fixes two distinct (but closely related) buglets that were uncovered
in #22235:
* `liftEnvSubst` used an empty in-scope set, which was not wide enough to cover
the variables in the range of the substitution. This patch fixes this by
populating the in-scope set from the free variables in the range of the
substitution.
* `composeTCvSubst` applied the first substitution argument to the range of the
second substitution argument, but the first substitution's in-scope set was
not wide enough to cover the range of the second substutition. We similarly
fix this issue in this patch by widening the first substitution's in-scope set
before applying it.
Fixes #22235.
Diffstat (limited to 'testsuite/tests/gadt/T22235.hs')
-rw-r--r-- | testsuite/tests/gadt/T22235.hs | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/testsuite/tests/gadt/T22235.hs b/testsuite/tests/gadt/T22235.hs new file mode 100644 index 0000000000..0f4161db72 --- /dev/null +++ b/testsuite/tests/gadt/T22235.hs @@ -0,0 +1,23 @@ +{-# LANGUAGE DataKinds #-} +{-# LANGUAGE GADTs #-} +module T22235 (f) where + +import Data.Kind (Type) +import Data.Type.Equality ((:~:)(..)) + +f :: ST x -> ST y -> x :~: y +f st1@SMkT st2@SMkT = method st1 st2 + +type T :: Type -> Type +data T a where + MkT :: T Int + +type ST :: T a -> Type +data ST (t :: T a) where + SMkT :: ST MkT + +class C f where + method :: f a -> f b -> a :~: b + +instance C ST where + method SMkT SMkT = Refl |