abstract-deque-0.3: Abstract, parameterized interface to mutable Deques.
Safe HaskellSafe-Inferred
LanguageHaskell98

Data.Concurrent.Deque.Reference

Description

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.

Synopsis

Documentation

data SimpleDeque elt Source #

Stores a size bound (if any) as well as a mutable Seq.

Constructors

DQ !Int !(IORef (Seq elt)) 

Instances

Instances details
BoundedL SimpleDeque Source # 
Instance details

Defined in Data.Concurrent.Deque.Reference

Methods

newBoundedQ :: Int -> IO (SimpleDeque elt) Source #

tryPushL :: SimpleDeque elt -> elt -> IO Bool Source #

BoundedR SimpleDeque Source # 
Instance details

Defined in Data.Concurrent.Deque.Reference

Methods

tryPushR :: SimpleDeque elt -> elt -> IO Bool Source #

DequeClass SimpleDeque Source # 
Instance details

Defined in Data.Concurrent.Deque.Reference

PopL SimpleDeque Source # 
Instance details

Defined in Data.Concurrent.Deque.Reference

Methods

tryPopL :: SimpleDeque elt -> IO (Maybe elt) Source #

PushR SimpleDeque Source # 
Instance details

Defined in Data.Concurrent.Deque.Reference

Methods

pushR :: SimpleDeque elt -> elt -> IO () Source #

pushL :: SimpleDeque t -> t -> IO () Source #

pushR :: SimpleDeque t -> t -> IO () Source #