{-# language DataKinds #-}
{-# language FlexibleContexts #-}
{-# language FlexibleInstances #-}
{-# language GADTs #-}
{-# language LambdaCase #-}
{-# language MultiParamTypeClasses #-}
{-# language QuantifiedConstraints #-}
{-# language RankNTypes #-}
{-# language StandaloneKindSignatures #-}
{-# language TypeFamilies #-}
{-# language UndecidableInstances #-}
module Rel8.Table.Unreify
( Unreifiable, Unreifiability(..), unreifiability
, Unreifies
)
where
import Data.Kind ( Constraint, Type )
import Prelude ()
import Rel8.Aggregate ( Aggregate )
import Rel8.Expr ( Expr )
import Rel8.Kind.Context ( SContext(..), Reifiable, sReifiable )
import Rel8.Schema.Dict ( Dict( Dict ) )
import Rel8.Schema.Insert ( Insert )
import qualified Rel8.Schema.Kind as K
import Rel8.Schema.Name ( Name )
import Rel8.Schema.Reify ( Reify )
import Rel8.Schema.Result ( Result )
import Rel8.Table ( Table, Context, Congruent, Unreify )
type Unreifies :: K.Context -> Type -> Constraint
type family Unreifies context a where
Unreifies (Reify context) a = Unreifier context a
Unreifies _ _ = ()
type Unreifiable :: Type -> Constraint
class
( Context a ~ Reify Aggregate => Unreifier Aggregate a
, Context a ~ Reify Expr => Unreifier Expr a
, Context a ~ Reify Insert => Unreifier Insert a
, Context a ~ Reify Name => Unreifier Name a
, (forall ctx. (Context a ~ Reify (Reify ctx), Reifiable ctx) => Unreifier (Reify ctx) a)
)
=> Unreifiable a
instance
( Context a ~ Reify Aggregate => Unreifier Aggregate a
, Context a ~ Reify Expr => Unreifier Expr a
, Context a ~ Reify Insert => Unreifier Insert a
, Context a ~ Reify Name => Unreifier Name a
, (forall ctx. (Context a ~ Reify (Reify ctx), Reifiable ctx) => Unreifier (Reify ctx) a)
)
=> Unreifiable a
type Unreifier :: K.Context -> Type -> Constraint
class
( Table context (Unreify a)
, Congruent a (Unreify a)
)
=> Unreifier context a
instance
( Table context (Unreify a)
, Congruent a (Unreify a)
)
=> Unreifier context a
type Unreifiability :: K.Context -> Type -> Type
data Unreifiability context a where
UResult :: Unreifiability Result a
Unreifiability :: Unreifier context a
=> SContext context -> Unreifiability context a
unreifiability :: (Context a ~ Reify context, Unreifiable a)
=> SContext context -> Unreifiability context a
unreifiability :: SContext context -> Unreifiability context a
unreifiability = \case
SContext context
SAggregate -> SContext Aggregate -> Unreifiability Aggregate a
forall (context :: Context) a.
Unreifier context a =>
SContext context -> Unreifiability context a
Unreifiability SContext Aggregate
SAggregate
SContext context
SExpr -> SContext Expr -> Unreifiability Expr a
forall (context :: Context) a.
Unreifier context a =>
SContext context -> Unreifiability context a
Unreifiability SContext Expr
SExpr
SContext context
SInsert -> SContext Insert -> Unreifiability Insert a
forall (context :: Context) a.
Unreifier context a =>
SContext context -> Unreifiability context a
Unreifiability SContext Insert
SInsert
SContext context
SName -> SContext Name -> Unreifiability Name a
forall (context :: Context) a.
Unreifier context a =>
SContext context -> Unreifiability context a
Unreifiability SContext Name
SName
SContext context
SResult -> Unreifiability context a
forall a. Unreifiability Result a
UResult
SReify SContext context
context -> case SContext context -> Dict Reifiable context
forall (context :: Context).
SContext context -> Dict Reifiable context
sReifiable SContext context
context of
Dict Reifiable context
Dict -> SContext (Reify context) -> Unreifiability (Reify context) a
forall (context :: Context) a.
Unreifier context a =>
SContext context -> Unreifiability context a
Unreifiability (SContext context -> SContext (Reify context)
forall (context :: Context).
SContext context -> SContext (Reify context)
SReify SContext context
context)