symantic-6.3.0.20170807: Library for Typed Tagless-Final Higher-Order Composable DSL

Safe HaskellNone
LanguageHaskell2010

Language.Symantic.Compiling.Term

Contents

Synopsis

Type Term

data Term src ss ts vs t where Source #

Constructors

Term :: Type src vs q -> Type src vs t -> TeSym ss ts (q #> t) -> Term src ss ts vs (q #> t) 

Instances

AllocVars Type (Term src ss ts) Source # 

Methods

allocVarsL :: Len Type len -> a vs x -> a ((Type ++ len) vs) x Source #

allocVarsR :: Len Type len -> a vs x -> a ((Type ++ vs) len) x Source #

SourceInj (TermT src ss ts vs) src => TypeOf Type (Term src ss ts vs) Source # 

Methods

typeOf :: a t -> Type (Term src ss ts vs) (SourceOf (a t)) (VarsOf (a t)) t Source #

Source src => Eq (Term src ss ts vs t) Source # 

Methods

(==) :: Term src ss ts vs t -> Term src ss ts vs t -> Bool #

(/=) :: Term src ss ts vs t -> Term src ss ts vs t -> Bool #

Source src => Show (Term src ss ts vs t) Source # 

Methods

showsPrec :: Int -> Term src ss ts vs t -> ShowS #

show :: Term src ss ts vs t -> String #

showList :: [Term src ss ts vs t] -> ShowS #

Source src => Sourced (Term src ss ts vs t) Source # 

Methods

sourceOf :: Term src ss ts vs t -> SourceOf (Term src ss ts vs t) #

setSource :: Term src ss ts vs t -> SourceOf (Term src ss ts vs t) -> Term src ss ts vs t #

LenVars (Term src ss ts vs t) Source # 

Methods

lenVars :: Term src ss ts vs t -> Len Type (VarsOf (Term src ss ts vs t)) Source #

ExpandFam (Term src ss ts vs t) Source # 

Methods

expandFam :: Term src ss ts vs t -> Term src ss ts vs t Source #

ConstsOf (Term src ss ts vs t) Source # 

Methods

constsOf :: Term src ss ts vs t -> Set (ConstC (SourceOf (Term src ss ts vs t))) Source #

type SourceOf (Term src ss ts vs t) Source # 
type SourceOf (Term src ss ts vs t) = src
type VarsOf (Term src ss ts vs t) Source # 
type VarsOf (Term src ss ts vs t) = vs

typeOfTerm :: Source src => Term src ss ts vs t -> Type src vs t Source #

Type TermT

data TermT src ss ts vs Source #

Term with existentialized Type.

Constructors

TermT (Term src ss ts vs t) 

Instances

Source src => Show (TermT src ss ts vs) Source # 

Methods

showsPrec :: Int -> TermT src ss ts vs -> ShowS #

show :: TermT src ss ts vs -> String #

showList :: [TermT src ss ts vs] -> ShowS #

Type TermVT

data TermVT src ss ts Source #

Term with existentialized Vars and Type.

Constructors

TermVT (Term src ss ts vs t) 

Instances

Source src => Eq (TermVT src ss ts) Source # 

Methods

(==) :: TermVT src ss ts -> TermVT src ss ts -> Bool #

(/=) :: TermVT src ss ts -> TermVT src ss ts -> Bool #

Source src => Show (TermVT src ss ts) Source # 

Methods

showsPrec :: Int -> TermVT src ss ts -> ShowS #

show :: TermVT src ss ts -> String #

showList :: [TermVT src ss ts] -> ShowS #

Source src => Sourced (TermVT src ss ts) Source # 

Methods

sourceOf :: TermVT src ss ts -> SourceOf (TermVT src ss ts) #

setSource :: TermVT src ss ts -> SourceOf (TermVT src ss ts) -> TermVT src ss ts #

type SourceOf (TermVT src ss ts) Source # 
type SourceOf (TermVT src ss ts) = src

liftTermVT :: TermVT src ss '[] -> TermVT src ss ts Source #

Type TermAVT

data TermAVT src ss Source #

Like TermVT, but CtxTe-free.

Constructors

TermAVT (forall ts. Term src ss ts vs t) 

Instances

Source src => Eq (TermAVT src ss) Source # 

Methods

(==) :: TermAVT src ss -> TermAVT src ss -> Bool #

(/=) :: TermAVT src ss -> TermAVT src ss -> Bool #

Source src => Show (TermAVT src ss) Source # 

Methods

showsPrec :: Int -> TermAVT src ss -> ShowS #

show :: TermAVT src ss -> String #

showList :: [TermAVT src ss] -> ShowS #

Source src => Sourced (TermAVT src ss) Source # 

Methods

sourceOf :: TermAVT src ss -> SourceOf (TermAVT src ss) #

setSource :: TermAVT src ss -> SourceOf (TermAVT src ss) -> TermAVT src ss #

type SourceOf (TermAVT src ss) Source # 
type SourceOf (TermAVT src ss) = src

Type TeSym

newtype TeSym ss ts t Source #

Symantic of a Term.

Constructors

TeSym (forall term. Syms ss term => Sym_Lambda term => QualOf t => CtxTe term ts -> term (UnQualOf t)) 

teSym :: forall s ss ts t. SymInj ss s => (forall term. Sym s term => Sym_Lambda term => QualOf t => term (UnQualOf t)) -> TeSym ss ts t Source #

Like TeSym, but CtxTe-free and using symInj to be able to use Sym s inside.

Type family QualOf

type family QualOf (t :: Type) :: Constraint where ... Source #

Qualification

Equations

QualOf (q #> t) = q 
QualOf t = (() :: Constraint) 

Type family UnQualOf

type family UnQualOf (t :: Type) :: Type where ... Source #

Unqualification

Equations

UnQualOf (q #> t) = t 
UnQualOf t = t 

unQualTy :: Source src => Type src vs (t :: Type) -> (TypeK src vs Constraint, TypeK src vs Type) Source #

Return Constraint and Type part of given Type.

unQualsTy :: Source src => Type src vs (t :: kt) -> TypeK src vs kt Source #

Remove Constraints from given Type.

Type CtxTe

data CtxTe term hs where Source #

GADT for an interpreting context: accumulating at each lambda abstraction the term of the introduced variable.

Constructors

CtxTeZ :: CtxTe term '[] 
CtxTeS :: term t -> CtxTe term ts -> CtxTe term (t ': ts) infixr 5 

Type TermDef

type TermDef s vs t = forall src ss ts. Source src => SymInj ss s => Term src ss ts vs t Source #

Convenient type alias for defining Term.

Type family Sym

type family Sym (s :: k) :: (Type -> Type) -> Constraint Source #

Type family Syms

type family Syms (ss :: [Type]) (term :: Type -> Type) :: Constraint where ... Source #

Equations

Syms '[] term = () 
Syms (Proxy s ': ss) term = (Sym s term, Syms ss term) 

Type SymInj

type SymInj ss s = SymInjP (Index ss (Proxy s)) ss s Source #

Convenient type synonym wrapping SymPInj applied on the correct Index.

symInj :: forall s ss ts t. SymInj ss s => TeSym '[Proxy s] ts t -> TeSym ss ts t Source #

Inject a given symantic s into a list of them, by returning a function which given a TeSym on s returns the same TeSym on ss.

Class SymPInj

class SymInjP p ss s where Source #

Minimal complete definition

symInjP

Methods

symInjP :: TeSym '[Proxy s] ts t -> TeSym ss ts t Source #

Instances

SymInjP k * Zero ((:) * (Proxy k s) ss) s Source # 

Methods

symInjP :: TeSym ((* ': Proxy Zero s) [*]) ts t -> TeSym ss ts t Source #

SymInjP k1 * p ss s => SymInjP k1 * (Succ p) ((:) * (Proxy k not_s) ss) s Source # 

Methods

symInjP :: TeSym ((* ': Proxy (Succ p) s) [*]) ts t -> TeSym ss ts t Source #

Class Sym_Lambda

class Sym_Lambda term where Source #

Methods

apply :: term ((a -> b) -> a -> b) Source #

Function application.

apply :: Sym_Lambda (UnT term) => Trans term => term ((a -> b) -> a -> b) Source #

Function application.

app :: term (a -> b) -> term a -> term b infixr 0 Source #

Lambda application.

app :: Sym_Lambda (UnT term) => Trans term => term (arg -> res) -> term arg -> term res infixr 0 Source #

Lambda application.

lam :: (term a -> term b) -> term (a -> b) Source #

Lambda abstraction.

lam :: Sym_Lambda (UnT term) => Trans term => (term arg -> term res) -> term (arg -> res) Source #

Lambda abstraction.

let_ :: term var -> (term var -> term res) -> term res Source #

Convenient lam and app wrapper.

lam1 :: (term a -> term b) -> term (a -> b) Source #

Lambda abstraction beta-reducable without duplication (i.e. whose variable is used once at most), mainly useful in compiled Terms whose symantics are not a single term but a function between terms, which happens because those are more usable when used as an embedded DSL.

lam1 :: Sym_Lambda (UnT term) => Trans term => (term a -> term b) -> term (a -> b) Source #

Lambda abstraction beta-reducable without duplication (i.e. whose variable is used once at most), mainly useful in compiled Terms whose symantics are not a single term but a function between terms, which happens because those are more usable when used as an embedded DSL.

qual :: proxy q -> term t -> term (q #> t) Source #

Qualification.

Workaround used in readTermWithCtx.

qual :: Sym_Lambda (UnT term) => Trans term => proxy q -> term t -> term (q #> t) Source #

Qualification.

Workaround used in readTermWithCtx.

Instances

Sym_Lambda View Source # 

Methods

apply :: View ((a -> b) -> a -> b) Source #

app :: View (a -> b) -> View a -> View b Source #

lam :: (View a -> View b) -> View (a -> b) Source #

let_ :: View var -> (View var -> View res) -> View res Source #

lam1 :: (View a -> View b) -> View (a -> b) Source #

qual :: proxy q -> View t -> View (q #> t) Source #

Sym_Lambda Eval Source # 

Methods

apply :: Eval ((a -> b) -> a -> b) Source #

app :: Eval (a -> b) -> Eval a -> Eval b Source #

lam :: (Eval a -> Eval b) -> Eval (a -> b) Source #

let_ :: Eval var -> (Eval var -> Eval res) -> Eval res Source #

lam1 :: (Eval a -> Eval b) -> Eval (a -> b) Source #

qual :: proxy q -> Eval t -> Eval (q #> t) Source #

Sym_Lambda term => Sym_Lambda (BetaT term) Source #

lam1 adds annotations, app uses it

Methods

apply :: BetaT term ((a -> b) -> a -> b) Source #

app :: BetaT term (a -> b) -> BetaT term a -> BetaT term b Source #

lam :: (BetaT term a -> BetaT term b) -> BetaT term (a -> b) Source #

let_ :: BetaT term var -> (BetaT term var -> BetaT term res) -> BetaT term res Source #

lam1 :: (BetaT term a -> BetaT term b) -> BetaT term (a -> b) Source #

qual :: proxy q -> BetaT term t -> BetaT term (q #> t) Source #

(Sym_Lambda r1, Sym_Lambda r2) => Sym_Lambda (Dup r1 r2) Source # 

Methods

apply :: Dup r1 r2 ((a -> b) -> a -> b) Source #

app :: Dup r1 r2 (a -> b) -> Dup r1 r2 a -> Dup r1 r2 b Source #

lam :: (Dup r1 r2 a -> Dup r1 r2 b) -> Dup r1 r2 (a -> b) Source #

let_ :: Dup r1 r2 var -> (Dup r1 r2 var -> Dup r1 r2 res) -> Dup r1 r2 res Source #

lam1 :: (Dup r1 r2 a -> Dup r1 r2 b) -> Dup r1 r2 (a -> b) Source #

qual :: proxy q -> Dup r1 r2 t -> Dup r1 r2 (q #> t) Source #

lam2 :: Sym_Lambda term => (term a -> term b -> term c) -> term (a -> b -> c) Source #

lam3 :: Sym_Lambda term => (term a -> term b -> term c -> term d) -> term (a -> b -> c -> d) Source #

lam4 :: Sym_Lambda term => (term a -> term b -> term c -> term d -> term e) -> term (a -> b -> c -> d -> e) Source #