symantic-lib-0.0.3.20180213: Symantics for common types.

Safe HaskellNone
LanguageHaskell2010

Language.Symantic.Lib.Enum

Contents

Description

Symantic for Enum.

Synopsis

Class Sym_Enum

class Sym_Enum term where Source #

Methods

toEnum :: Enum a => term Int -> term a Source #

fromEnum :: Enum a => term a -> term Int Source #

succ :: Enum a => term a -> term a Source #

pred :: Enum a => term a -> term a Source #

succ :: Sym_Enum (UnT term) => Trans term => Enum a => term a -> term a Source #

pred :: Sym_Enum (UnT term) => Trans term => Enum a => term a -> term a Source #

toEnum :: Sym_Enum (UnT term) => Trans term => Enum a => term Int -> term a Source #

fromEnum :: Sym_Enum (UnT term) => Trans term => Enum a => term a -> term Int Source #

Instances

Sym_Enum View Source # 

Methods

toEnum :: Enum a => View Int -> View a Source #

fromEnum :: Enum a => View a -> View Int Source #

succ :: Enum a => View a -> View a Source #

pred :: Enum a => View a -> View a Source #

Sym_Enum Eval Source # 

Methods

toEnum :: Enum a => Eval Int -> Eval a Source #

fromEnum :: Enum a => Eval a -> Eval Int Source #

succ :: Enum a => Eval a -> Eval a Source #

pred :: Enum a => Eval a -> Eval a Source #

(Sym_Enum term, Sym_Lambda term) => Sym_Enum (BetaT term) Source # 

Methods

toEnum :: Enum a => BetaT term Int -> BetaT term a Source #

fromEnum :: Enum a => BetaT term a -> BetaT term Int Source #

succ :: Enum a => BetaT term a -> BetaT term a Source #

pred :: Enum a => BetaT term a -> BetaT term a Source #

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

Methods

toEnum :: Enum a => Dup r1 r2 Int -> Dup r1 r2 a Source #

fromEnum :: Enum a => Dup r1 r2 a -> Dup r1 r2 Int Source #

succ :: Enum a => Dup r1 r2 a -> Dup r1 r2 a Source #

pred :: Enum a => Dup r1 r2 a -> Dup r1 r2 a Source #

Types

tyEnum :: Source src => Type src vs a -> Type src vs (Enum a) Source #

Terms

teEnum_succ :: TermDef Enum '[Proxy a] (Enum a #> (a -> a)) Source #

teEnum_pred :: TermDef Enum '[Proxy a] (Enum a #> (a -> a)) Source #

Orphan instances

ClassInstancesFor (* -> Constraint) Enum Source # 

Methods

proveConstraintFor :: Source src => proxy c -> Type Constraint src vs q -> Maybe (Qual q) #

TypeInstancesFor (* -> Constraint) Enum Source # 

Methods

expandFamFor :: Source src => proxy c -> Len Type vs -> Const kt src fam -> Types src vs ts -> Maybe (Type kt src vs (Fam kt fam ts)) #

NameTyOf (* -> Constraint) Enum Source # 

Methods

nameTyOf :: proxy c -> Mod NameTy #

isNameTyOp :: proxy c -> Bool #

FixityOf (* -> Constraint) Enum Source # 

Methods

fixityOf :: proxy c -> Maybe Fixity #

(Source src, SymInj (* -> Constraint) ss Enum) => ModuleFor (* -> Constraint) src ss Enum Source # 

Methods

moduleFor :: (PathMod, Module ss Enum) #

Gram_Term_AtomsFor (* -> Constraint) src ss g Enum Source # 

Methods

g_term_atomsFor :: [CF Enum (AST_Term ss g)] #