module Rasa (rasa) where
import Rasa.Internal.Listeners
import Rasa.Internal.Action
import Rasa.Internal.Interpreters
import Control.Monad
import Control.Monad.IO.Class
import Data.Maybe
import Pipes
import Pipes.Concurrent
import Pipes.Parse
rasa :: Action () -> IO ()
rasa initialize = do
(output, input) <- spawn unbounded
evalAction (mkActionState output) $ do
initialize
dispatchInit
dispatchAfterInit
eventLoop $ fromInput input
dispatchExit
eventLoop :: Producer (Action ()) IO () -> Action ()
eventLoop producer = do
dispatchBeforeRender
dispatchOnRender
dispatchAfterRender
dispatchBeforeEvent
(mAction, nextProducer) <- liftIO $ runStateT draw producer
fromMaybe (return ()) mAction
isExiting <- shouldExit
unless isExiting $ eventLoop nextProducer