{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE QuantifiedConstraints #-}
{-# LANGUAGE UndecidableInstances #-}
module Test.QuickCheck.StateModel.Variables (
Var,
Any (..),
HasVariables (..),
HasNoVariables (..),
VarContext,
mkVar,
ctxAtType,
arbitraryVar,
shrinkVar,
extendContext,
isWellTyped,
allVariables,
isEmptyCtx,
unsafeCoerceVar,
unsafeNextVarIndex,
) where
import Data.Data
import Data.Kind
import Data.List
import Data.Map (Map)
import Data.Map qualified as Map
import Data.Ord
import Data.Set (Set)
import Data.Set qualified as Set
import GHC.Generics
import GHC.TypeLits
import GHC.Word
import Test.QuickCheck as QC
newtype Var a = Var Int
deriving (Var a -> Var a -> Bool
(Var a -> Var a -> Bool) -> (Var a -> Var a -> Bool) -> Eq (Var a)
forall a. Var a -> Var a -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: forall a. Var a -> Var a -> Bool
== :: Var a -> Var a -> Bool
$c/= :: forall a. Var a -> Var a -> Bool
/= :: Var a -> Var a -> Bool
Eq, Eq (Var a)
Eq (Var a) =>
(Var a -> Var a -> Ordering)
-> (Var a -> Var a -> Bool)
-> (Var a -> Var a -> Bool)
-> (Var a -> Var a -> Bool)
-> (Var a -> Var a -> Bool)
-> (Var a -> Var a -> Var a)
-> (Var a -> Var a -> Var a)
-> Ord (Var a)
Var a -> Var a -> Bool
Var a -> Var a -> Ordering
Var a -> Var a -> Var a
forall a. Eq (Var a)
forall a.
Eq a =>
(a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
forall a. Var a -> Var a -> Bool
forall a. Var a -> Var a -> Ordering
forall a. Var a -> Var a -> Var a
$ccompare :: forall a. Var a -> Var a -> Ordering
compare :: Var a -> Var a -> Ordering
$c< :: forall a. Var a -> Var a -> Bool
< :: Var a -> Var a -> Bool
$c<= :: forall a. Var a -> Var a -> Bool
<= :: Var a -> Var a -> Bool
$c> :: forall a. Var a -> Var a -> Bool
> :: Var a -> Var a -> Bool
$c>= :: forall a. Var a -> Var a -> Bool
>= :: Var a -> Var a -> Bool
$cmax :: forall a. Var a -> Var a -> Var a
max :: Var a -> Var a -> Var a
$cmin :: forall a. Var a -> Var a -> Var a
min :: Var a -> Var a -> Var a
Ord, Typeable, Typeable (Var a)
Typeable (Var a) =>
(forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Var a -> c (Var a))
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (Var a))
-> (Var a -> Constr)
-> (Var a -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c (Var a)))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Var a)))
-> ((forall b. Data b => b -> b) -> Var a -> Var a)
-> (forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r)
-> (forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r)
-> (forall u. (forall d. Data d => d -> u) -> Var a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> Var a -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a))
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a))
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a))
-> Data (Var a)
Var a -> Constr
Var a -> DataType
(forall b. Data b => b -> b) -> Var a -> Var a
forall a. Data a => Typeable (Var a)
forall a. Data a => Var a -> Constr
forall a. Data a => Var a -> DataType
forall a. Data a => (forall b. Data b => b -> b) -> Var a -> Var a
forall a u.
Data a =>
Int -> (forall d. Data d => d -> u) -> Var a -> u
forall a u. Data a => (forall d. Data d => d -> u) -> Var a -> [u]
forall a r r'.
Data a =>
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
forall a r r'.
Data a =>
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
forall a (m :: * -> *).
(Data a, Monad m) =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
forall a (m :: * -> *).
(Data a, MonadPlus m) =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
forall a (c :: * -> *).
Data a =>
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (Var a)
forall a (c :: * -> *).
Data a =>
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Var a -> c (Var a)
forall a (t :: * -> *) (c :: * -> *).
(Data a, Typeable t) =>
(forall d. Data d => c (t d)) -> Maybe (c (Var a))
forall a (t :: * -> * -> *) (c :: * -> *).
(Data a, Typeable t) =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Var a))
forall a.
Typeable a =>
(forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> Var a -> u
forall u. (forall d. Data d => d -> u) -> Var a -> [u]
forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (Var a)
forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Var a -> c (Var a)
forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c (Var a))
forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Var a))
$cgfoldl :: forall a (c :: * -> *).
Data a =>
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Var a -> c (Var a)
gfoldl :: forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Var a -> c (Var a)
$cgunfold :: forall a (c :: * -> *).
Data a =>
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (Var a)
gunfold :: forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (Var a)
$ctoConstr :: forall a. Data a => Var a -> Constr
toConstr :: Var a -> Constr
$cdataTypeOf :: forall a. Data a => Var a -> DataType
dataTypeOf :: Var a -> DataType
$cdataCast1 :: forall a (t :: * -> *) (c :: * -> *).
(Data a, Typeable t) =>
(forall d. Data d => c (t d)) -> Maybe (c (Var a))
dataCast1 :: forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c (Var a))
$cdataCast2 :: forall a (t :: * -> * -> *) (c :: * -> *).
(Data a, Typeable t) =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Var a))
dataCast2 :: forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Var a))
$cgmapT :: forall a. Data a => (forall b. Data b => b -> b) -> Var a -> Var a
gmapT :: (forall b. Data b => b -> b) -> Var a -> Var a
$cgmapQl :: forall a r r'.
Data a =>
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
gmapQl :: forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
$cgmapQr :: forall a r r'.
Data a =>
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
gmapQr :: forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Var a -> r
$cgmapQ :: forall a u. Data a => (forall d. Data d => d -> u) -> Var a -> [u]
gmapQ :: forall u. (forall d. Data d => d -> u) -> Var a -> [u]
$cgmapQi :: forall a u.
Data a =>
Int -> (forall d. Data d => d -> u) -> Var a -> u
gmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Var a -> u
$cgmapM :: forall a (m :: * -> *).
(Data a, Monad m) =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
gmapM :: forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
$cgmapMp :: forall a (m :: * -> *).
(Data a, MonadPlus m) =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
gmapMp :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
$cgmapMo :: forall a (m :: * -> *).
(Data a, MonadPlus m) =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
gmapMo :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Var a -> m (Var a)
Data)
mkVar :: Int -> Var a
mkVar :: forall a. Int -> Var a
mkVar = Int -> Var a
forall a. Int -> Var a
Var
instance Show (Var a) where
show :: Var a -> String
show (Var Int
i) = String
"var" String -> ShowS
forall a. [a] -> [a] -> [a]
++ Int -> String
forall a. Show a => a -> String
show Int
i
class HasVariables a where
getAllVariables :: a -> Set (Any Var)
instance HasVariables a => HasVariables (Smart a) where
getAllVariables :: Smart a -> Set (Any Var)
getAllVariables (Smart Int
_ a
a) = a -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables a
a
instance Typeable a => HasVariables (Var a) where
getAllVariables :: Var a -> Set (Any Var)
getAllVariables = Any Var -> Set (Any Var)
forall a. a -> Set a
Set.singleton (Any Var -> Set (Any Var))
-> (Var a -> Any Var) -> Var a -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Var a -> Any Var
forall a (f :: * -> *). (Typeable a, Eq (f a)) => f a -> Any f
Some
instance (HasVariables k, HasVariables v) => HasVariables (Map k v) where
getAllVariables :: Map k v -> Set (Any Var)
getAllVariables = [(k, v)] -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables ([(k, v)] -> Set (Any Var))
-> (Map k v -> [(k, v)]) -> Map k v -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Map k v -> [(k, v)]
forall k a. Map k a -> [(k, a)]
Map.toList
instance HasVariables a => HasVariables (Set a) where
getAllVariables :: Set a -> Set (Any Var)
getAllVariables = [a] -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables ([a] -> Set (Any Var)) -> (Set a -> [a]) -> Set a -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Set a -> [a]
forall a. Set a -> [a]
Set.toList
instance (forall a. HasVariables (f a)) => HasVariables (Any f) where
getAllVariables :: Any f -> Set (Any Var)
getAllVariables (Some f a
a) = f a -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables f a
a
newtype HasNoVariables a = HasNoVariables a
deriving via a instance Show a => Show (HasNoVariables a)
deriving via a instance Eq a => Eq (HasNoVariables a)
instance HasVariables (HasNoVariables a) where
getAllVariables :: HasNoVariables a -> Set (Any Var)
getAllVariables HasNoVariables a
_ = Set (Any Var)
forall a. Monoid a => a
mempty
deriving via HasNoVariables Integer instance HasVariables Integer
deriving via HasNoVariables Int instance HasVariables Int
deriving via HasNoVariables Char instance HasVariables Char
deriving via HasNoVariables Word8 instance HasVariables Word8
deriving via HasNoVariables Word16 instance HasVariables Word16
deriving via HasNoVariables Word32 instance HasVariables Word32
deriving via HasNoVariables Word64 instance HasVariables Word64
data Any f where
Some :: (Typeable a, Eq (f a)) => f a -> Any f
instance Eq (Any f) where
Some (f a
a :: f a) == :: Any f -> Any f -> Bool
== Some (f a
b :: f b) =
case forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
forall a b. (Typeable a, Typeable b) => Maybe (a :~: b)
eqT @a @b of
Just a :~: a
Refl -> f a
a f a -> f a -> Bool
forall a. Eq a => a -> a -> Bool
== f a
f a
b
Maybe (a :~: a)
Nothing -> Bool
False
instance (forall a. Ord (f a)) => Ord (Any f) where
compare :: Any f -> Any f -> Ordering
compare (Some (f a
a :: f a)) (Some (f a
a' :: f a')) =
case forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
forall a b. (Typeable a, Typeable b) => Maybe (a :~: b)
eqT @a @a' of
Just a :~: a
Refl -> f a -> f a -> Ordering
forall a. Ord a => a -> a -> Ordering
compare f a
a f a
f a
a'
Maybe (a :~: a)
Nothing -> TypeRep -> TypeRep -> Ordering
forall a. Ord a => a -> a -> Ordering
compare (f a -> TypeRep
forall {k} (proxy :: k -> *) (a :: k).
Typeable a =>
proxy a -> TypeRep
typeRep f a
a) (f a -> TypeRep
forall {k} (proxy :: k -> *) (a :: k).
Typeable a =>
proxy a -> TypeRep
typeRep f a
a')
newtype VarContext = VarCtx (Set (Any Var))
deriving (NonEmpty VarContext -> VarContext
VarContext -> VarContext -> VarContext
(VarContext -> VarContext -> VarContext)
-> (NonEmpty VarContext -> VarContext)
-> (forall b. Integral b => b -> VarContext -> VarContext)
-> Semigroup VarContext
forall b. Integral b => b -> VarContext -> VarContext
forall a.
(a -> a -> a)
-> (NonEmpty a -> a)
-> (forall b. Integral b => b -> a -> a)
-> Semigroup a
$c<> :: VarContext -> VarContext -> VarContext
<> :: VarContext -> VarContext -> VarContext
$csconcat :: NonEmpty VarContext -> VarContext
sconcat :: NonEmpty VarContext -> VarContext
$cstimes :: forall b. Integral b => b -> VarContext -> VarContext
stimes :: forall b. Integral b => b -> VarContext -> VarContext
Semigroup, Semigroup VarContext
VarContext
Semigroup VarContext =>
VarContext
-> (VarContext -> VarContext -> VarContext)
-> ([VarContext] -> VarContext)
-> Monoid VarContext
[VarContext] -> VarContext
VarContext -> VarContext -> VarContext
forall a.
Semigroup a =>
a -> (a -> a -> a) -> ([a] -> a) -> Monoid a
$cmempty :: VarContext
mempty :: VarContext
$cmappend :: VarContext -> VarContext -> VarContext
mappend :: VarContext -> VarContext -> VarContext
$cmconcat :: [VarContext] -> VarContext
mconcat :: [VarContext] -> VarContext
Monoid) via Set (Any Var)
instance Show VarContext where
show :: VarContext -> String
show (VarCtx Set (Any Var)
vs) =
String
"[" String -> ShowS
forall a. [a] -> [a] -> [a]
++ String -> [String] -> String
forall a. [a] -> [[a]] -> [a]
intercalate String
", " ((Any Var -> String) -> [Any Var] -> [String]
forall a b. (a -> b) -> [a] -> [b]
map Any Var -> String
showBinding ([Any Var] -> [String])
-> ([Any Var] -> [Any Var]) -> [Any Var] -> [String]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Any Var -> Any Var -> Ordering) -> [Any Var] -> [Any Var]
forall a. (a -> a -> Ordering) -> [a] -> [a]
sortBy ((Any Var -> Int) -> Any Var -> Any Var -> Ordering
forall a b. Ord a => (b -> a) -> b -> b -> Ordering
comparing Any Var -> Int
getIdx) ([Any Var] -> [String]) -> [Any Var] -> [String]
forall a b. (a -> b) -> a -> b
$ Set (Any Var) -> [Any Var]
forall a. Set a -> [a]
Set.toList Set (Any Var)
vs) String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
"]"
where
getIdx :: Any Var -> Int
getIdx (Some (Var Int
i)) = Int
i
showBinding :: Any Var -> String
showBinding :: Any Var -> String
showBinding (Some Var a
v) = Var a -> String
forall a. Show a => a -> String
show Var a
v String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
" :: " String -> ShowS
forall a. [a] -> [a] -> [a]
++ TypeRep -> String
forall a. Show a => a -> String
show (Var a -> TypeRep
forall {k} (proxy :: k -> *) (a :: k).
Typeable a =>
proxy a -> TypeRep
typeRep Var a
v)
isEmptyCtx :: VarContext -> Bool
isEmptyCtx :: VarContext -> Bool
isEmptyCtx (VarCtx Set (Any Var)
ctx) = Set (Any Var) -> Bool
forall a. Set a -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null Set (Any Var)
ctx
isWellTyped :: Typeable a => Var a -> VarContext -> Bool
isWellTyped :: forall a. Typeable a => Var a -> VarContext -> Bool
isWellTyped Var a
v (VarCtx Set (Any Var)
ctx) = Bool -> Bool
not (Set (Any Var) -> Bool
forall a. Set a -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null Set (Any Var)
ctx) Bool -> Bool -> Bool
&& Var a -> Any Var
forall a (f :: * -> *). (Typeable a, Eq (f a)) => f a -> Any f
Some Var a
v Any Var -> Set (Any Var) -> Bool
forall a. Ord a => a -> Set a -> Bool
`Set.member` Set (Any Var)
ctx
extendContext :: Typeable a => VarContext -> Var a -> VarContext
extendContext :: forall a. Typeable a => VarContext -> Var a -> VarContext
extendContext (VarCtx Set (Any Var)
ctx) Var a
v = Set (Any Var) -> VarContext
VarCtx (Set (Any Var) -> VarContext) -> Set (Any Var) -> VarContext
forall a b. (a -> b) -> a -> b
$ Any Var -> Set (Any Var) -> Set (Any Var)
forall a. Ord a => a -> Set a -> Set a
Set.insert (Var a -> Any Var
forall a (f :: * -> *). (Typeable a, Eq (f a)) => f a -> Any f
Some Var a
v) Set (Any Var)
ctx
allVariables :: HasVariables a => a -> VarContext
allVariables :: forall a. HasVariables a => a -> VarContext
allVariables = Set (Any Var) -> VarContext
VarCtx (Set (Any Var) -> VarContext)
-> (a -> Set (Any Var)) -> a -> VarContext
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables
ctxAtType :: Typeable a => VarContext -> [Var a]
ctxAtType :: forall a. Typeable a => VarContext -> [Var a]
ctxAtType (VarCtx Set (Any Var)
vs) = [Var a
v | Some (Var a -> Maybe (Var a)
forall a b. (Typeable a, Typeable b) => a -> Maybe b
cast -> Just Var a
v) <- Set (Any Var) -> [Any Var]
forall a. Set a -> [a]
Set.toList Set (Any Var)
vs]
arbitraryVar :: Typeable a => VarContext -> Gen (Var a)
arbitraryVar :: forall a. Typeable a => VarContext -> Gen (Var a)
arbitraryVar = [Var a] -> Gen (Var a)
forall a. [a] -> Gen a
elements ([Var a] -> Gen (Var a))
-> (VarContext -> [Var a]) -> VarContext -> Gen (Var a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. VarContext -> [Var a]
forall a. Typeable a => VarContext -> [Var a]
ctxAtType
shrinkVar :: Typeable a => VarContext -> Var a -> [Var a]
shrinkVar :: forall a. Typeable a => VarContext -> Var a -> [Var a]
shrinkVar VarContext
ctx Var a
v = (Var a -> Bool) -> [Var a] -> [Var a]
forall a. (a -> Bool) -> [a] -> [a]
filter (Var a -> Var a -> Bool
forall a. Ord a => a -> a -> Bool
< Var a
v) ([Var a] -> [Var a]) -> [Var a] -> [Var a]
forall a b. (a -> b) -> a -> b
$ VarContext -> [Var a]
forall a. Typeable a => VarContext -> [Var a]
ctxAtType VarContext
ctx
unsafeCoerceVar :: Var a -> Var b
unsafeCoerceVar :: forall a b. Var a -> Var b
unsafeCoerceVar (Var Int
i) = Int -> Var b
forall a. Int -> Var a
Var Int
i
unsafeNextVarIndex :: VarContext -> Int
unsafeNextVarIndex :: VarContext -> Int
unsafeNextVarIndex (VarCtx Set (Any Var)
vs) = Int
1 Int -> Int -> Int
forall a. Num a => a -> a -> a
+ [Int] -> Int
forall a. Ord a => [a] -> a
forall (t :: * -> *) a. (Foldable t, Ord a) => t a -> a
maximum (Int
0 Int -> [Int] -> [Int]
forall a. a -> [a] -> [a]
: [Int
i | Some (Var Int
i) <- Set (Any Var) -> [Any Var]
forall a. Set a -> [a]
Set.toList Set (Any Var)
vs])
data Dummy x
type family Break (c :: Constraint) (rep :: Type -> Type) :: Constraint where
Break _ Dummy = ((), ())
Break _ _ = ()
instance
{-# OVERLAPPABLE #-}
( Break
(TypeError ('Text "Missing instance of HasVariables for non-Generic type " ':<>: 'ShowType a))
(Rep a)
, Generic a
, GenericHasVariables (Rep a)
)
=> HasVariables a
where
getAllVariables :: a -> Set (Any Var)
getAllVariables = Rep a Any -> Set (Any Var)
forall k. Rep a k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables (Rep a Any -> Set (Any Var))
-> (a -> Rep a Any) -> a -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Rep a Any
forall x. a -> Rep a x
forall a x. Generic a => a -> Rep a x
from
class GenericHasVariables f where
genericGetAllVariables :: f k -> Set (Any Var)
instance GenericHasVariables f => GenericHasVariables (M1 i c f) where
genericGetAllVariables :: forall k. M1 i c f k -> Set (Any Var)
genericGetAllVariables = f k -> Set (Any Var)
forall k. f k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables (f k -> Set (Any Var))
-> (M1 i c f k -> f k) -> M1 i c f k -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. M1 i c f k -> f k
forall k i (c :: Meta) (f :: k -> *) (p :: k). M1 i c f p -> f p
unM1
instance HasVariables c => GenericHasVariables (K1 i c) where
genericGetAllVariables :: forall k. K1 i c k -> Set (Any Var)
genericGetAllVariables = c -> Set (Any Var)
forall a. HasVariables a => a -> Set (Any Var)
getAllVariables (c -> Set (Any Var))
-> (K1 i c k -> c) -> K1 i c k -> Set (Any Var)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. K1 i c k -> c
forall k i c (p :: k). K1 i c p -> c
unK1
instance GenericHasVariables U1 where
genericGetAllVariables :: forall k. U1 k -> Set (Any Var)
genericGetAllVariables U1 k
_ = Set (Any Var)
forall a. Monoid a => a
mempty
instance (GenericHasVariables f, GenericHasVariables g) => GenericHasVariables (f :*: g) where
genericGetAllVariables :: forall k. (:*:) f g k -> Set (Any Var)
genericGetAllVariables (f k
x :*: g k
y) = f k -> Set (Any Var)
forall k. f k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables f k
x Set (Any Var) -> Set (Any Var) -> Set (Any Var)
forall a. Semigroup a => a -> a -> a
<> g k -> Set (Any Var)
forall k. g k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables g k
y
instance (GenericHasVariables f, GenericHasVariables g) => GenericHasVariables (f :+: g) where
genericGetAllVariables :: forall k. (:+:) f g k -> Set (Any Var)
genericGetAllVariables (L1 f k
x) = f k -> Set (Any Var)
forall k. f k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables f k
x
genericGetAllVariables (R1 g k
x) = g k -> Set (Any Var)
forall k. g k -> Set (Any Var)
forall (f :: * -> *) k.
GenericHasVariables f =>
f k -> Set (Any Var)
genericGetAllVariables g k
x