{-# LANGUAGE UnicodeSyntax #-}
{-# LANGUAGE FlexibleContexts #-}
module Control.Concurrent.STM.TQueue.Lifted
( TQueue
, newTQueue
, newTQueueIO
, readTQueue
, tryReadTQueue
, peekTQueue
, tryPeekTQueue
, flushTQueue
, writeTQueue
, unGetTQueue
, isEmptyTQueue
) where
import Control.Monad.Base (MonadBase(..))
import Control.Monad.STM (STM)
import Control.Concurrent.STM.TQueue (TQueue)
import qualified Control.Concurrent.STM.TQueue as STM
newTQueue ∷ MonadBase STM μ ⇒ μ (TQueue α)
newTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => μ (TQueue α)
newTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall a. STM (TQueue a)
STM.newTQueue
{-# INLINE newTQueue #-}
newTQueueIO ∷ MonadBase IO μ ⇒ μ (TQueue α)
newTQueueIO :: forall (μ :: * -> *) α. MonadBase IO μ => μ (TQueue α)
newTQueueIO = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall a. IO (TQueue a)
STM.newTQueueIO
{-# INLINE newTQueueIO #-}
readTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ α
readTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ α
readTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM a
STM.readTQueue
{-# INLINE readTQueue #-}
tryReadTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ (Maybe α)
tryReadTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ (Maybe α)
tryReadTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM (Maybe a)
STM.tryReadTQueue
{-# INLINE tryReadTQueue #-}
peekTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ α
peekTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ α
peekTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM a
STM.peekTQueue
{-# INLINE peekTQueue #-}
tryPeekTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ (Maybe α)
tryPeekTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ (Maybe α)
tryPeekTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM (Maybe a)
STM.tryPeekTQueue
{-# INLINE tryPeekTQueue #-}
flushTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ [α]
flushTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ [α]
flushTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM [a]
STM.flushTQueue
{-# INLINE flushTQueue #-}
writeTQueue ∷ MonadBase STM μ ⇒ TQueue α → α → μ ()
writeTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> α -> μ ()
writeTQueue = (forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
.) forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> a -> STM ()
STM.writeTQueue
{-# INLINE writeTQueue #-}
unGetTQueue ∷ MonadBase STM μ ⇒ TQueue α → α → μ ()
unGetTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> α -> μ ()
unGetTQueue = (forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
.) forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> a -> STM ()
STM.unGetTQueue
{-# INLINE unGetTQueue #-}
isEmptyTQueue ∷ MonadBase STM μ ⇒ TQueue α → μ Bool
isEmptyTQueue :: forall (μ :: * -> *) α. MonadBase STM μ => TQueue α -> μ Bool
isEmptyTQueue = forall (b :: * -> *) (m :: * -> *) α. MonadBase b m => b α -> m α
liftBase forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. TQueue a -> STM Bool
STM.isEmptyTQueue
{-# INLINE isEmptyTQueue #-}