{-# LANGUAGE LinearTypes #-}
{-# OPTIONS_HADDOCK hide #-}
module Data.Unrestricted.Linear.Internal.UrT
( UrT (..),
runUrT,
liftUrT,
evalUrT,
)
where
import qualified Control.Functor.Linear as Linear
import Data.Unrestricted.Linear.Internal.Movable
import Data.Unrestricted.Linear.Internal.Ur
newtype UrT m a = UrT (m (Ur a))
runUrT :: UrT m a %1 -> m (Ur a)
runUrT :: forall (m :: * -> *) a. UrT m a %1 -> m (Ur a)
runUrT (UrT m (Ur a)
ma) = m (Ur a)
ma
instance (Linear.Functor m) => Functor (UrT m) where
fmap :: forall a b. (a -> b) -> UrT m a -> UrT m b
fmap a -> b
f (UrT m (Ur a)
ma) = forall (m :: * -> *) a. m (Ur a) -> UrT m a
UrT (forall (f :: * -> *) a b.
Functor f =>
(a %1 -> b) %1 -> f a %1 -> f b
Linear.fmap (\(Ur a
a) -> forall a. a -> Ur a
Ur (a -> b
f a
a)) m (Ur a)
ma)
instance (Linear.Applicative m) => Applicative (UrT m) where
pure :: forall a. a -> UrT m a
pure a
a = forall (m :: * -> *) a. m (Ur a) -> UrT m a
UrT (forall (f :: * -> *) a. Applicative f => a %1 -> f a
Linear.pure (forall a. a -> Ur a
Ur a
a))
UrT m (Ur (a -> b))
mf <*> :: forall a b. UrT m (a -> b) -> UrT m a -> UrT m b
<*> UrT m (Ur a)
ma = forall (m :: * -> *) a. m (Ur a) -> UrT m a
UrT (forall (f :: * -> *) a b c.
Applicative f =>
(a %1 -> b %1 -> c) %1 -> f a %1 -> f b %1 -> f c
Linear.liftA2 (\(Ur a -> b
f) (Ur a
a) -> forall a. a -> Ur a
Ur (a -> b
f a
a)) m (Ur (a -> b))
mf m (Ur a)
ma)
instance (Linear.Monad m) => Monad (UrT m) where
UrT m (Ur a)
ma >>= :: forall a b. UrT m a -> (a -> UrT m b) -> UrT m b
>>= a -> UrT m b
f = forall (m :: * -> *) a. m (Ur a) -> UrT m a
UrT (m (Ur a)
ma forall (m :: * -> *) a b.
Monad m =>
m a %1 -> (a %1 -> m b) %1 -> m b
Linear.>>= (\(Ur a
a) -> case a -> UrT m b
f a
a of (UrT m (Ur b)
mb) -> m (Ur b)
mb))
liftUrT :: (Movable a, Linear.Functor m) => m a %1 -> UrT m a
liftUrT :: forall a (m :: * -> *). (Movable a, Functor m) => m a %1 -> UrT m a
liftUrT m a
ma = forall (m :: * -> *) a. m (Ur a) -> UrT m a
UrT (forall (f :: * -> *) a b.
Functor f =>
(a %1 -> b) %1 -> f a %1 -> f b
Linear.fmap forall a. Movable a => a %1 -> Ur a
move m a
ma)
evalUrT :: (Linear.Functor m) => UrT m a %1 -> m a
evalUrT :: forall (m :: * -> *) a. Functor m => UrT m a %1 -> m a
evalUrT UrT m a
u = forall (f :: * -> *) a b.
Functor f =>
(a %1 -> b) %1 -> f a %1 -> f b
Linear.fmap forall a. Ur a %1 -> a
unur (forall (m :: * -> *) a. UrT m a %1 -> m (Ur a)
runUrT UrT m a
u)