ghc-8.8.1: The GHC API
Safe HaskellNone
LanguageHaskell2010

StgCmmMonad

Synopsis

Documentation

data FCode a Source #

Instances

Instances details
Monad FCode Source # 
Instance details

Defined in StgCmmMonad

Methods

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

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

return :: a -> FCode a #

Functor FCode Source # 
Instance details

Defined in StgCmmMonad

Methods

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

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

Applicative FCode Source # 
Instance details

Defined in StgCmmMonad

Methods

pure :: a -> FCode a #

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

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

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

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

MonadUnique FCode Source # 
Instance details

Defined in StgCmmMonad

HasDynFlags FCode Source # 
Instance details

Defined in StgCmmMonad

fixC :: (a -> FCode a) -> FCode a Source #

getCodeScoped :: FCode a -> FCode (a, CmmAGraphScoped) Source #

Generate code into a fresh tick (sub-)scope and gather generated code

forkAlts :: [FCode a] -> FCode [a] Source #

forkAltPair :: FCode a -> FCode a -> FCode (a, a) Source #

type ConTagZ = Int Source #

A *zero-indexed* constructor tag

data Sequel Source #

Constructors

Return 
AssignTo [LocalReg] Bool 

Instances

Instances details
Outputable Sequel Source # 
Instance details

Defined in StgCmmMonad

tickScope :: FCode a -> FCode a Source #

Places blocks generated by the given code into a fresh (sub-)scope. This will make sure that Cmm annotations in our scope will apply to the Cmm blocks generated therein - but not the other way around.

getTickScope :: FCode CmmTickScope Source #

The current tick scope. We will assign this to generated blocks.

data CgIdInfo Source #

Constructors

CgIdInfo 

Instances

Instances details
Outputable CgIdInfo Source # 
Instance details

Defined in StgCmmMonad

getBinds :: FCode CgBindings Source #

setBinds :: CgBindings -> FCode () Source #