From 21392e6e6b0ec173dd4a8ad87361badf88ee7789 Mon Sep 17 00:00:00 2001 From: Marcin Szamotulski Date: Mon, 9 Dec 2024 11:06:29 +0100 Subject: [PATCH] io-sim: generalise selector types Generalised `selectTraceEvents'` and friends. It can work with any return type, not just `SimResult`. --- io-sim/CHANGELOG.md | 8 ++++++++ io-sim/src/Control/Monad/IOSim.hs | 13 +++++++------ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/io-sim/CHANGELOG.md b/io-sim/CHANGELOG.md index ae63d855..897deecc 100644 --- a/io-sim/CHANGELOG.md +++ b/io-sim/CHANGELOG.md @@ -14,6 +14,14 @@ the value to other waiting threads. - Faster handling of timeouts and timers by using a more efficient internal representation. +- The signature of: + - `selectTraceEvents'`, + - `selectTraceEventsDynamic'`, + - `selectTraceEventsDynamicWithTime'`, + - `selectTraceEventsSay'` and + - `selectTraceEventsSayWithTime'` + is more general. These functions now accepts trace with any result, rather + than one that finishes with `SimResult`. ## 1.6.0.0 diff --git a/io-sim/src/Control/Monad/IOSim.hs b/io-sim/src/Control/Monad/IOSim.hs index 8111b980..94a83d3b 100644 --- a/io-sim/src/Control/Monad/IOSim.hs +++ b/io-sim/src/Control/Monad/IOSim.hs @@ -144,11 +144,12 @@ selectTraceEvents fn = . traceSelectTraceEvents fn -- | Like 'selectTraceEvents', but it returns even if the simulation trace ends --- with 'Failure'. +-- with 'Failure'. It also works with any return type, not only `SimResult` +-- like `selectTraceEvents` does. -- selectTraceEvents' :: (Time -> SimEventType -> Maybe b) - -> SimTrace a + -> Trace a SimEvent -> [b] selectTraceEvents' fn = bifoldr ( \ _ _ -> [] ) @@ -228,7 +229,7 @@ selectTraceEventsDynamicWithTime = selectTraceEvents fn -- | Like 'selectTraceEventsDynamic' but it returns even if the simulation trace -- ends with 'Failure'. -- -selectTraceEventsDynamic' :: forall a b. Typeable b => SimTrace a -> [b] +selectTraceEventsDynamic' :: forall a b. Typeable b => Trace a SimEvent -> [b] selectTraceEventsDynamic' = selectTraceEvents' fn where fn :: Time -> SimEventType -> Maybe b @@ -238,7 +239,7 @@ selectTraceEventsDynamic' = selectTraceEvents' fn -- | Like `selectTraceEventsDynamic'` but it also captures time of the trace -- event. -- -selectTraceEventsDynamicWithTime' :: forall a b. Typeable b => SimTrace a -> [(Time, b)] +selectTraceEventsDynamicWithTime' :: forall a b. Typeable b => Trace a SimEvent -> [(Time, b)] selectTraceEventsDynamicWithTime' = selectTraceEvents' fn where fn :: Time -> SimEventType -> Maybe (Time, b) @@ -268,7 +269,7 @@ selectTraceEventsSayWithTime = selectTraceEvents fn -- | Like 'selectTraceEventsSay' but it returns even if the simulation trace -- ends with 'Failure'. -- -selectTraceEventsSay' :: SimTrace a -> [String] +selectTraceEventsSay' :: Trace a SimEvent -> [String] selectTraceEventsSay' = selectTraceEvents' fn where fn :: Time -> SimEventType -> Maybe String @@ -277,7 +278,7 @@ selectTraceEventsSay' = selectTraceEvents' fn -- | Like `selectTraceEventsSay'` but it also captures time of the trace event. -- -selectTraceEventsSayWithTime' :: SimTrace a -> [(Time, String)] +selectTraceEventsSayWithTime' :: Trace a SimEvent -> [(Time, String)] selectTraceEventsSayWithTime' = selectTraceEvents' fn where fn :: Time -> SimEventType -> Maybe (Time, String)