compdata-param-0.9.2: Parametric Compositional Data Types

Copyright(c) 2011 Patrick Bahr Tom Hvitved
LicenseBSD3
MaintainerTom Hvitved <hvitved@diku.dk>
Stabilityexperimental
Portabilitynon-portable (GHC Extensions)
Safe HaskellNone
LanguageHaskell98

Data.Comp.Param.FreshM

Description

This module defines a monad for generating fresh, abstract names, useful e.g. for defining equality on terms.

Synopsis

Documentation

data FreshM a Source #

Monad for generating fresh (abstract) names.

Instances
Monad FreshM Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

(>>=) :: FreshM a -> (a -> FreshM b) -> FreshM b #

(>>) :: FreshM a -> FreshM b -> FreshM b #

return :: a -> FreshM a #

fail :: String -> FreshM a #

Functor FreshM Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

fmap :: (a -> b) -> FreshM a -> FreshM b #

(<$) :: a -> FreshM b -> FreshM a #

Applicative FreshM Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

pure :: a -> FreshM a #

(<*>) :: FreshM (a -> b) -> FreshM a -> FreshM b #

liftA2 :: (a -> b -> c) -> FreshM a -> FreshM b -> FreshM c #

(*>) :: FreshM a -> FreshM b -> FreshM b #

(<*) :: FreshM a -> FreshM b -> FreshM a #

data Name Source #

Abstract notion of a name (the constructor is hidden).

Instances
Eq Name Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

(==) :: Name -> Name -> Bool #

(/=) :: Name -> Name -> Bool #

Ord Name Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

compare :: Name -> Name -> Ordering #

(<) :: Name -> Name -> Bool #

(<=) :: Name -> Name -> Bool #

(>) :: Name -> Name -> Bool #

(>=) :: Name -> Name -> Bool #

max :: Name -> Name -> Name #

min :: Name -> Name -> Name #

Show Name Source # 
Instance details

Defined in Data.Comp.Param.FreshM

Methods

showsPrec :: Int -> Name -> ShowS #

show :: Name -> String #

showList :: [Name] -> ShowS #

(EqD f, PEq a) => PEq (Cxt h f Name a) Source # 
Instance details

Defined in Data.Comp.Param.Equality

Methods

peq :: Cxt h f Name a -> Cxt h f Name a -> FreshM Bool Source #

(OrdD f, POrd a) => POrd (Cxt h f Name a) Source # 
Instance details

Defined in Data.Comp.Param.Ordering

Methods

pcompare :: Cxt h f Name a -> Cxt h f Name a -> FreshM Ordering Source #

withName :: (Name -> FreshM a) -> FreshM a Source #

Run the given computation with the next available name.

evalFreshM :: FreshM a -> a Source #

Evaluate a computation that uses fresh names.