summaryrefslogtreecommitdiff
path: root/testsuite/tests/typecheck/should_fail/T13320.hs
blob: d80dd4f0eb6fa9ab2833f97c5b4ddd4ee830e37b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
{-# language ConstraintKinds, FlexibleContexts, TypeFamilies,
    UndecidableInstances, DeriveFunctor #-}

module T13320 where

import GHC.Exts        (Constraint)

data QCGen

newtype Gen a = MkGen { unGen :: QCGen -> Int -> a }
  deriving Functor

sized :: (Int -> Gen a) -> Gen a
sized f = MkGen (\r n -> let MkGen m = f n in m r n)

class Arbitrary a where
  arbitrary :: Gen a

type family X_Var ξ

data TermX ξ = Var (X_Var ξ)

type ForallX (φ :: * -> Constraint) ξ = ( φ (X_Var ξ) )

-- This type signature used to be necessary to prevent the
-- type checker from looping.
-- genTerm :: ForallX Arbitrary ξ => Int -> Gen (TermX ξ)
genTerm 0 = Var <$> arbitrary
genTerm n = Var <$> genTerm (n - 1)

instance ForallX Arbitrary ξ => Arbitrary (TermX ξ) where
  arbitrary = sized genTerm