keid-core-0.1.5.1: Core parts of Keid engine.
Safe HaskellNone
LanguageHaskell2010

Engine.Worker

Synopsis

Documentation

data Versioned a Source #

Constructors

Versioned 

Fields

Instances

Instances details
Functor Versioned Source # 
Instance details

Defined in Engine.Worker

Methods

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

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

Foldable Versioned Source # 
Instance details

Defined in Engine.Worker

Methods

fold :: Monoid m => Versioned m -> m #

foldMap :: Monoid m => (a -> m) -> Versioned a -> m #

foldMap' :: Monoid m => (a -> m) -> Versioned a -> m #

foldr :: (a -> b -> b) -> b -> Versioned a -> b #

foldr' :: (a -> b -> b) -> b -> Versioned a -> b #

foldl :: (b -> a -> b) -> b -> Versioned a -> b #

foldl' :: (b -> a -> b) -> b -> Versioned a -> b #

foldr1 :: (a -> a -> a) -> Versioned a -> a #

foldl1 :: (a -> a -> a) -> Versioned a -> a #

toList :: Versioned a -> [a] #

null :: Versioned a -> Bool #

length :: Versioned a -> Int #

elem :: Eq a => a -> Versioned a -> Bool #

maximum :: Ord a => Versioned a -> a #

minimum :: Ord a => Versioned a -> a #

sum :: Num a => Versioned a -> a #

product :: Num a => Versioned a -> a #

Traversable Versioned Source # 
Instance details

Defined in Engine.Worker

Methods

traverse :: Applicative f => (a -> f b) -> Versioned a -> f (Versioned b) #

sequenceA :: Applicative f => Versioned (f a) -> f (Versioned a) #

mapM :: Monad m => (a -> m b) -> Versioned a -> m (Versioned b) #

sequence :: Monad m => Versioned (m a) -> m (Versioned a) #

Eq (Versioned a) Source # 
Instance details

Defined in Engine.Worker

Methods

(==) :: Versioned a -> Versioned a -> Bool #

(/=) :: Versioned a -> Versioned a -> Bool #

Ord (Versioned a) Source # 
Instance details

Defined in Engine.Worker

Show a => Show (Versioned a) Source # 
Instance details

Defined in Engine.Worker

HasOutput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (TVar (Versioned a)) Source #

HasInput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetInput (TVar (Versioned a)) Source #

type GetOutput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

type GetOutput (TVar (Versioned a)) = a
type GetInput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

type GetInput (TVar (Versioned a)) = a

type Var a = TVar (Versioned a) Source #

newVar :: MonadUnliftIO m => a -> m (Var a) Source #

readVar :: MonadUnliftIO m => Var a -> m a Source #

stateVar :: HasInput var => var -> StateVar (GetInput var) Source #

stateVarMap :: HasInput var => (GetInput var -> a) -> (a -> GetInput var -> GetInput var) -> var -> StateVar a Source #

class HasInput a where Source #

Associated Types

type GetInput a Source #

Methods

getInput :: a -> Var (GetInput a) Source #

Instances

Instances details
HasInput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetInput (TVar (Versioned a)) Source #

HasInput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetInput (Cell i o) Source #

Methods

getInput :: Cell i o -> Var (GetInput (Cell i o)) Source #

pushInput :: (MonadIO m, HasInput var) => var -> (GetInput var -> GetInput var) -> m () Source #

pushInputSTM :: HasInput var => var -> (GetInput var -> GetInput var) -> STM () Source #

updateInput :: (MonadIO m, HasInput var) => var -> (GetInput var -> Maybe (GetInput var)) -> m () Source #

updateInputSTM :: HasInput var => var -> (GetInput var -> Maybe (GetInput var)) -> STM () Source #

getInputData :: (HasInput worker, MonadIO m) => worker -> m (GetInput worker) Source #

getInputDataSTM :: HasInput worker => worker -> STM (GetInput worker) Source #

class HasConfig a where Source #

Associated Types

type GetConfig a Source #

Methods

getConfig :: a -> TVar (GetConfig a) Source #

Instances

Instances details
HasConfig (TVar a) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetConfig (TVar a) Source #

Methods

getConfig :: TVar a -> TVar (GetConfig (TVar a)) Source #

HasConfig (Timed config output) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetConfig (Timed config output) Source #

Methods

getConfig :: Timed config output -> TVar (GetConfig (Timed config output)) Source #

modifyConfig :: (MonadIO m, HasConfig var) => var -> (GetConfig var -> GetConfig var) -> m () Source #

modifyConfigSTM :: HasConfig var => var -> (GetConfig var -> GetConfig var) -> STM () Source #

class HasOutput a where Source #

Associated Types

type GetOutput a Source #

Methods

getOutput :: a -> Var (GetOutput a) Source #

Instances

Instances details
HasOutput (TVar (Versioned a)) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (TVar (Versioned a)) Source #

HasOutput (Merge o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Merge o) Source #

Methods

getOutput :: Merge o -> Var (GetOutput (Merge o)) Source #

HasOutput (Timed config output) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Timed config output) Source #

Methods

getOutput :: Timed config output -> Var (GetOutput (Timed config output)) Source #

HasOutput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Cell i o) Source #

Methods

getOutput :: Cell i o -> Var (GetOutput (Cell i o)) Source #

pushOutput :: (MonadIO m, HasOutput var) => var -> (GetOutput var -> GetOutput var) -> m () Source #

pushOutputSTM :: HasOutput var => var -> (GetOutput var -> GetOutput var) -> STM () Source #

updateOutput :: (MonadIO m, HasOutput var) => var -> (GetOutput var -> Maybe (GetOutput var)) -> m () Source #

updateOutputSTM :: HasOutput var => var -> (GetOutput var -> Maybe (GetOutput var)) -> STM () Source #

getOutputData :: (HasOutput worker, MonadIO m) => worker -> m (GetOutput worker) Source #

getOutputDataSTM :: HasOutput worker => worker -> STM (GetOutput worker) Source #

data Cell input output Source #

Updatable cell for composite input or costly output.

Constructors

Cell 

Fields

Instances

Instances details
HasWorker (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Methods

getWorker :: Cell i o -> ThreadId Source #

HasOutput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Cell i o) Source #

Methods

getOutput :: Cell i o -> Var (GetOutput (Cell i o)) Source #

HasInput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetInput (Cell i o) Source #

Methods

getInput :: Cell i o -> Var (GetInput (Cell i o)) Source #

type GetOutput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

type GetOutput (Cell i o) = o
type GetInput (Cell i o) Source # 
Instance details

Defined in Engine.Worker

type GetInput (Cell i o) = i

spawnCell :: MonadUnliftIO m => (input -> output) -> input -> m (Cell input output) Source #

data Timed config output Source #

Timer-driven stateful producer.

Constructors

Timed 

Fields

Instances

Instances details
HasWorker (Timed c o) Source # 
Instance details

Defined in Engine.Worker

Methods

getWorker :: Timed c o -> ThreadId Source #

HasOutput (Timed config output) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Timed config output) Source #

Methods

getOutput :: Timed config output -> Var (GetOutput (Timed config output)) Source #

HasConfig (Timed config output) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetConfig (Timed config output) Source #

Methods

getConfig :: Timed config output -> TVar (GetConfig (Timed config output)) Source #

type GetOutput (Timed config output) Source # 
Instance details

Defined in Engine.Worker

type GetOutput (Timed config output) = output
type GetConfig (Timed config output) Source # 
Instance details

Defined in Engine.Worker

type GetConfig (Timed config output) = config

spawnTimed :: MonadUnliftIO m => Bool -> Either Int (config -> Int) -> (config -> m (output, state)) -> (state -> config -> m (Maybe output, state)) -> config -> m (Timed config output) Source #

spawnTimed_ :: MonadUnliftIO m => Bool -> Int -> output -> m output -> m (Timed () output) Source #

data Merge o Source #

Supply-driven step cell.

Constructors

Merge 

Instances

Instances details
HasWorker (Merge o) Source # 
Instance details

Defined in Engine.Worker

HasOutput (Merge o) Source # 
Instance details

Defined in Engine.Worker

Associated Types

type GetOutput (Merge o) Source #

Methods

getOutput :: Merge o -> Var (GetOutput (Merge o)) Source #

type GetOutput (Merge o) Source # 
Instance details

Defined in Engine.Worker

type GetOutput (Merge o) = o

spawnMerge1 :: (MonadUnliftIO m, HasOutput i) => (GetOutput i -> o) -> i -> m (Merge o) Source #

spawnMerge2 :: (MonadUnliftIO m, HasOutput i1, HasOutput i2) => (GetOutput i1 -> GetOutput i2 -> o) -> i1 -> i2 -> m (Merge o) Source #

spawnMerge3 :: (MonadUnliftIO m, HasOutput i1, HasOutput i2, HasOutput i3) => (GetOutput i1 -> GetOutput i2 -> GetOutput i3 -> o) -> i1 -> i2 -> i3 -> m (Merge o) Source #

spawnMerge4 :: (MonadUnliftIO m, HasOutput i1, HasOutput i2, HasOutput i3, HasOutput i4) => (GetOutput i1 -> GetOutput i2 -> GetOutput i3 -> GetOutput i4 -> o) -> i1 -> i2 -> i3 -> i4 -> m (Merge o) Source #

spawnMergeT :: (Traversable t, HasOutput input, MonadUnliftIO m) => (t (GetOutput input) -> output) -> t input -> m (Merge output) Source #

Spawn a merge over a homogeneous traversable collection of processes.

A merging function will receive a collection of outputs to summarize.

observeIO :: (MonadUnliftIO m, HasOutput output) => output -> ObserverIO a -> (a -> GetOutput output -> m a) -> m a Source #

observeIO_ :: (MonadUnliftIO m, HasOutput output) => output -> ObserverIO a -> (a -> GetOutput output -> m a) -> m () Source #

readObservedIO :: MonadUnliftIO m => IORef (Versioned a) -> m a Source #

data Source a Source #

newSource :: (MonadUnliftIO m, UnagiPrim a) => m (Source a) Source #

pubSource :: (MonadUnliftIO m, UnagiPrim a) => Source a -> a -> m () Source #

subSource :: MonadUnliftIO m => Source a -> m (OutChan a) Source #

class HasWorker a where Source #

Methods

getWorker :: a -> ThreadId Source #

Instances

Instances details
HasWorker (Merge o) Source # 
Instance details

Defined in Engine.Worker

HasWorker (Timed c o) Source # 
Instance details

Defined in Engine.Worker

Methods

getWorker :: Timed c o -> ThreadId Source #

HasWorker (Cell i o) Source # 
Instance details

Defined in Engine.Worker

Methods

getWorker :: Cell i o -> ThreadId Source #

register :: (MonadResource m, HasWorker process) => process -> m ReleaseKey Source #

registerCollection :: (MonadResource m, HasWorker process, Foldable t) => t process -> m ReleaseKey Source #

registered :: (MonadResource m, HasWorker a) => m a -> m (ReleaseKey, a) Source #

registeredCollection :: (MonadResource m, HasWorker process, Traversable t) => (input -> m process) -> t input -> m (ReleaseKey, t process) Source #