verifiable-expressions-0.4.0: An intermediate language for Hoare logic style verification.

Safe HaskellNone
LanguageHaskell2010

Language.Expression.Prop

Contents

Description

Propositions and combinators for conveniently constructing them.

Synopsis

Proposition Types

type Prop = HFree LogicOp Source #

Propositions over general expressions.

type Prop' ops v = Prop (HFree' ops v) Source #

Propositions over expressions with the given list of operators.

DSL

expr :: expr a -> Prop expr a Source #

Lift an expression into the land of propositions.

plit :: Bool -> Prop expr Bool Source #

pnot :: Prop expr Bool -> Prop expr Bool Source #

(*&&) :: Prop expr Bool -> Prop expr Bool -> Prop expr Bool infixl 3 Source #

(*||) :: Prop expr Bool -> Prop expr Bool -> Prop expr Bool infixl 2 Source #

(*->) :: Prop expr Bool -> Prop expr Bool -> Prop expr Bool infixr 1 Source #

(*<->) :: Prop expr Bool -> Prop expr Bool -> Prop expr Bool infix 1 Source #

propAnd :: [Prop expr Bool] -> Prop expr Bool Source #

propOr :: [Prop expr Bool] -> Prop expr Bool Source #

HTraversable

data LogicOp t a where Source #

Logical operations

Constructors

LogLit :: Bool -> LogicOp t Bool 
LogNot :: t Bool -> LogicOp t Bool 
LogAnd :: t Bool -> t Bool -> LogicOp t Bool 
LogOr :: t Bool -> t Bool -> LogicOp t Bool 
LogImpl :: t Bool -> t Bool -> LogicOp t Bool 
LogEquiv :: t Bool -> t Bool -> LogicOp t Bool 

Instances

HTraversable * LogicOp Source # 

Methods

htraverse :: Applicative f => (forall (b :: LogicOp). t b -> f (t' b)) -> h t a -> f (h t' a) Source #

hsequence :: Applicative f => h (Compose * LogicOp f t) a -> f (h t a) Source #

HFunctor * LogicOp Source # 

Methods

hmap :: (forall (b :: LogicOp). t b -> t' b) -> h t a -> h t' a Source #

HFoldableAt * Identity LogicOp Source # 

Methods

hfoldMap :: (forall (b :: Identity). t b -> LogicOp b) -> h t a -> LogicOp a Source #

HFoldableAt * SBV LogicOp Source # 

Methods

hfoldMap :: (forall (b :: SBV). t b -> LogicOp b) -> h t a -> LogicOp a Source #

Pretty2 * * LogicOp Source # 

Methods

pretty2 :: Pretty1 LogicOp t => op t a -> String Source #

prettys2Prec :: Pretty1 LogicOp t => Int -> op t a -> ShowS Source #