{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE FunctionalDependencies #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE UndecidableInstances #-}
#ifdef USE_REFLEX_OPTIMIZER
{-# OPTIONS_GHC -fplugin=Reflex.Optimizer #-}
#endif
module Reflex.DynamicWriter.Class
( MonadDynamicWriter
, DynamicWriter(..)
) where
import Control.Monad.Reader (ReaderT, lift)
import Reflex.Class (Dynamic)
{-# DEPRECATED MonadDynamicWriter "Use 'DynamicWriter' instead" #-}
type MonadDynamicWriter = DynamicWriter
class (Monad m, Monoid w) => DynamicWriter t w m | m -> t w where
tellDyn :: Dynamic t w -> m ()
instance DynamicWriter t w m => DynamicWriter t w (ReaderT r m) where
tellDyn = lift . tellDyn