From c47873f0e3b145dd963cc352d887cad5726a8bca Mon Sep 17 00:00:00 2001 From: Alexander Foremny Date: Tue, 13 Aug 2024 11:36:26 +0200 Subject: wip simplify aggregate --- src/Data/Sensor.hs | 32 ++++++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/Data/Sensor.hs b/src/Data/Sensor.hs index 96c48ed..2cb7eaa 100644 --- a/src/Data/Sensor.hs +++ b/src/Data/Sensor.hs @@ -1,3 +1,5 @@ +{-# LANGUAGE UndecidableInstances #-} + module Data.Sensor where import Control.Applicative @@ -149,7 +151,7 @@ combineStale f a@(Stale _) b@(Input _) = Stale (f a.unwrap b.unwrap) combineStale f a b = Fresh (f a.unwrap b.unwrap) class (MonadIO m, Show s, Typeable a) => Aggregate m s a | s -> a where - aggregate :: s -> AggregateT s (SensorT m) () + aggregate :: s -> (a -> m ()) -> m () newtype AggregateT s m a = AggregateT {unAggregateT :: ReaderT AggregateE m a} @@ -161,8 +163,7 @@ deriving instance (Monad m) => Monad (AggregateT s m) deriving instance (MonadIO m) => MonadIO (AggregateT s m) -instance MonadTrans (AggregateT s) where - lift = AggregateT . lift +deriving instance MonadTrans (AggregateT s) deriving instance (MonadFail m) => MonadFail (AggregateT s m) @@ -366,6 +367,13 @@ data LiveAggregate a = LiveAggregate spawnedAt :: Int } +runAggregateT :: AggregateT s m a -> AggregateE -> m a +runAggregateT (AggregateT m) e = + runReaderT m e + +withRunInBase :: ((forall a. (AggregateT s (SensorT m) a) -> m a) -> m x) -> AggregateT s (SensorT m) x +withRunInBase = undefined + startAggregate :: (MonadUnliftIO m) => AnyAggregate m -> SensorT m () startAggregate (AnyAggregate s) = do let self = show s @@ -380,7 +388,23 @@ startAggregate (AnyAggregate s) = do threadId <- forkFinally - (runReaderT (aggregate s).unAggregateT AggregateE {..}) + ( do + sensorE <- ask + (lift :: m a -> SensorT m a) + ( runReaderT + ( runAggregateT + (lift (lift (aggregate s undefined))) + {- + ( withRunInBase $ \runInBase -> + (aggregate s (runInBase . yield)) + )-} + AggregateE {..} :: + SensorT m () + ).unSensorT + sensorE :: + m () + ) + ) ( either ( \e -> if -- cgit v1.2.3