module ComputingWithMonads.MonadTrans whereimport Prelude
import Effect (Effect)
import Effect.Console (log)
import Data.Tuple (Tuple(..))
-- Stateimport Control.Monad.State.Class (classMonadState, get, gets, modify_)
import Control.Monad.State (State, runState)
-- Writerimport Control.Monad.Writer.Class (classMonadWriter, tell)
import Control.Monad.Writer.Trans (WriterT, runWriterT)
program :: forall m.
MonadStateInt m =>
MonadWriterString m =>
m Stringprogram = do
currentState <- get
tell $ "Current State is now: " <> show currentState
modify_ (_ + 10)
gets show
run :: forall a. WriterTString (StateInt) a
-> Int
-> Tuple (Tuple a String) Intrun function initialState = runState (runWriterT function) initialState
main :: EffectUnitmain = case run program 0ofTuple (Tuple output nonOutputData) nextState -> do
log $ "Finished!"
log $ "(Computation) final output: " <> show output
log $ "(Writer) non-output data: " <> show nonOutputData
log $ "(State) next state: " <> show nextState
let (Tuple (Tuple o _ ) _ ) = run program 8
log $ "Using pattern matching to get the computation's output: " <> show o