module Polysemy.Time.Measure where
import Torsor (Torsor)
import Polysemy.Time.Class.Instant (Instant)
import qualified Polysemy.Time.Data.Time as Time
import Polysemy.Time.Data.Time (Time)
import Polysemy.Time.Data.TimeUnit (TimeUnit)
import Polysemy.Time.Diff (diff)
measure ::
∀ dt t d u r a .
TimeUnit u =>
Torsor dt u =>
Instant t dt =>
Member (Time t d) r =>
Sem r a ->
Sem r (u, a)
measure :: Sem r a -> Sem r (u, a)
measure Sem r a
ma = do
!t
start <- forall (r :: [Effect]). MemberWithError (Time t d) r => Sem r t
forall t d (r :: [Effect]). MemberWithError (Time t d) r => Sem r t
Time.now @t @d
a
a <- Sem r a
ma
!t
end <- forall (r :: [Effect]). MemberWithError (Time t d) r => Sem r t
forall t d (r :: [Effect]). MemberWithError (Time t d) r => Sem r t
Time.now @t @d
pure (t -> t -> u
forall dt u i1 i2.
(TimeUnit u, Torsor dt u, Instant i1 dt, Instant i2 dt) =>
i1 -> i2 -> u
diff t
end t
start, a
a)
{-# inline measure #-}