Safe Haskell | Safe-Inferred |
---|
A strawman implementation of concurrent Dequeues. This implementation is so simple that it also makes a good reference implementation for debugging.
The queue representation is simply an IORef containing a Data.Sequence.
Also see Data.Concurrent.Deque.Reference.DequeInstance. By convention a module of this name is also provided.
- data SimpleDeque elt = DQ !Int !(IORef (Seq elt))
- newQ :: IO (SimpleDeque elt)
- nullQ :: SimpleDeque elt -> IO Bool
- newBoundedQ :: Int -> IO (SimpleDeque elt)
- pushL :: SimpleDeque t -> t -> IO ()
- pushR :: SimpleDeque t -> t -> IO ()
- tryPopR :: SimpleDeque a -> IO (Maybe a)
- tryPopL :: SimpleDeque a -> IO (Maybe a)
- tryPushL :: SimpleDeque a -> a -> IO Bool
- tryPushR :: SimpleDeque a -> a -> IO Bool
- _is_using_CAS :: Bool
Documentation
data SimpleDeque elt Source
Stores a size bound (if any) as well as a mutable Seq.
newQ :: IO (SimpleDeque elt)Source
nullQ :: SimpleDeque elt -> IO BoolSource
newBoundedQ :: Int -> IO (SimpleDeque elt)Source
pushL :: SimpleDeque t -> t -> IO ()Source
pushR :: SimpleDeque t -> t -> IO ()Source
tryPopR :: SimpleDeque a -> IO (Maybe a)Source
tryPopL :: SimpleDeque a -> IO (Maybe a)Source
tryPushL :: SimpleDeque a -> a -> IO BoolSource
tryPushR :: SimpleDeque a -> a -> IO BoolSource