| Copyright | (c) Ross Paterson 2005 (c) Louis Wasserman 2009 (c) Bertram Felgenhauer David Feuer Ross Paterson and Milan Straka 2014 | 
|---|---|
| License | BSD-style | 
| Maintainer | libraries@haskell.org | 
| Portability | portable | 
| Safe Haskell | Trustworthy | 
| Language | Haskell2010 | 
Data.Sequence.Internal
Description
WARNING
This module is considered internal.
The Package Versioning Policy does not apply.
The contents of this module may change in any way whatsoever and without any warning between minor versions of this package.
Authors importing this module are expected to track development closely.
Description
General purpose finite sequences. Apart from being finite and having strict operations, sequences also differ from lists in supporting a wider variety of operations efficiently.
An amortized running time is given for each operation, with \( n \) referring to the length of the sequence and \( i \) being the integral index used by some operations. These bounds hold even in a persistent (shared) setting.
The implementation uses 2-3 finger trees annotated with sizes, as described in section 4.2 of
- Ralf Hinze and Ross Paterson, "Finger trees: a simple general-purpose data structure", Journal of Functional Programming 16:2 (2006) pp 197-217. http://staff.city.ac.uk/~ross/papers/FingerTree.html
Note: Many of these operations have the same names as similar
 operations on lists in the Prelude. The ambiguity may be resolved
 using either qualification or the hiding clause.
Warning: The size of a Seq must not exceed maxBound::Int.  Violation
 of this condition is not detected and if the size limit is exceeded, the
 behaviour of the sequence is undefined.  This is unlikely to occur in most
 applications, but some care may be required when using ><, <*>, *>, or
 >>, particularly repeatedly and particularly in combination with
 replicate or fromFunction.
Since: containers-0.5.9
Synopsis
- newtype Elem a = Elem {- getElem :: a
 
- data FingerTree a
- data Node a
- data Digit a
- class Sized a where
- class MaybeForce a
- newtype Seq a where
- newtype State s a = State {- runState :: s -> (s, a)
 
- execState :: State s a -> s -> a
- foldDigit :: (b -> b -> b) -> (a -> b) -> Digit a -> b
- foldNode :: (b -> b -> b) -> (a -> b) -> Node a -> b
- foldWithIndexDigit :: Sized a => (b -> b -> b) -> (Int -> a -> b) -> Int -> Digit a -> b
- foldWithIndexNode :: Sized a => (m -> m -> m) -> (Int -> a -> m) -> Int -> Node a -> m
- empty :: Seq a
- singleton :: a -> Seq a
- (<|) :: a -> Seq a -> Seq a
- (|>) :: Seq a -> a -> Seq a
- (><) :: Seq a -> Seq a -> Seq a
- fromList :: [a] -> Seq a
- fromFunction :: Int -> (Int -> a) -> Seq a
- fromArray :: Ix i => Array i a -> Seq a
- replicate :: Int -> a -> Seq a
- replicateA :: Applicative f => Int -> f a -> f (Seq a)
- replicateM :: Applicative m => Int -> m a -> m (Seq a)
- cycleTaking :: Int -> Seq a -> Seq a
- iterateN :: Int -> (a -> a) -> a -> Seq a
- unfoldr :: (b -> Maybe (a, b)) -> b -> Seq a
- unfoldl :: (b -> Maybe (b, a)) -> b -> Seq a
- null :: Seq a -> Bool
- length :: Seq a -> Int
- data ViewL a
- viewl :: Seq a -> ViewL a
- data ViewR a
- viewr :: Seq a -> ViewR a
- scanl :: (a -> b -> a) -> a -> Seq b -> Seq a
- scanl1 :: (a -> a -> a) -> Seq a -> Seq a
- scanr :: (a -> b -> b) -> b -> Seq a -> Seq b
- scanr1 :: (a -> a -> a) -> Seq a -> Seq a
- tails :: Seq a -> Seq (Seq a)
- inits :: Seq a -> Seq (Seq a)
- chunksOf :: Int -> Seq a -> Seq (Seq a)
- takeWhileL :: (a -> Bool) -> Seq a -> Seq a
- takeWhileR :: (a -> Bool) -> Seq a -> Seq a
- dropWhileL :: (a -> Bool) -> Seq a -> Seq a
- dropWhileR :: (a -> Bool) -> Seq a -> Seq a
- spanl :: (a -> Bool) -> Seq a -> (Seq a, Seq a)
- spanr :: (a -> Bool) -> Seq a -> (Seq a, Seq a)
- breakl :: (a -> Bool) -> Seq a -> (Seq a, Seq a)
- breakr :: (a -> Bool) -> Seq a -> (Seq a, Seq a)
- partition :: (a -> Bool) -> Seq a -> (Seq a, Seq a)
- filter :: (a -> Bool) -> Seq a -> Seq a
- lookup :: Int -> Seq a -> Maybe a
- (!?) :: Seq a -> Int -> Maybe a
- index :: Seq a -> Int -> a
- adjust :: (a -> a) -> Int -> Seq a -> Seq a
- adjust' :: forall a. (a -> a) -> Int -> Seq a -> Seq a
- update :: Int -> a -> Seq a -> Seq a
- take :: Int -> Seq a -> Seq a
- drop :: Int -> Seq a -> Seq a
- insertAt :: Int -> a -> Seq a -> Seq a
- deleteAt :: Int -> Seq a -> Seq a
- splitAt :: Int -> Seq a -> (Seq a, Seq a)
- elemIndexL :: Eq a => a -> Seq a -> Maybe Int
- elemIndicesL :: Eq a => a -> Seq a -> [Int]
- elemIndexR :: Eq a => a -> Seq a -> Maybe Int
- elemIndicesR :: Eq a => a -> Seq a -> [Int]
- findIndexL :: (a -> Bool) -> Seq a -> Maybe Int
- findIndicesL :: (a -> Bool) -> Seq a -> [Int]
- findIndexR :: (a -> Bool) -> Seq a -> Maybe Int
- findIndicesR :: (a -> Bool) -> Seq a -> [Int]
- foldMapWithIndex :: Monoid m => (Int -> a -> m) -> Seq a -> m
- foldlWithIndex :: (b -> Int -> a -> b) -> b -> Seq a -> b
- foldrWithIndex :: (Int -> a -> b -> b) -> b -> Seq a -> b
- mapWithIndex :: (Int -> a -> b) -> Seq a -> Seq b
- traverseWithIndex :: Applicative f => (Int -> a -> f b) -> Seq a -> f (Seq b)
- reverse :: Seq a -> Seq a
- intersperse :: a -> Seq a -> Seq a
- liftA2Seq :: (a -> b -> c) -> Seq a -> Seq b -> Seq c
- zip :: Seq a -> Seq b -> Seq (a, b)
- zipWith :: (a -> b -> c) -> Seq a -> Seq b -> Seq c
- zip3 :: Seq a -> Seq b -> Seq c -> Seq (a, b, c)
- zipWith3 :: (a -> b -> c -> d) -> Seq a -> Seq b -> Seq c -> Seq d
- zip4 :: Seq a -> Seq b -> Seq c -> Seq d -> Seq (a, b, c, d)
- zipWith4 :: (a -> b -> c -> d -> e) -> Seq a -> Seq b -> Seq c -> Seq d -> Seq e
- unzip :: Seq (a, b) -> (Seq a, Seq b)
- unzipWith :: (a -> (b, c)) -> Seq a -> (Seq b, Seq c)
Documentation
Instances
| Foldable Elem # | |
| Defined in Data.Sequence.Internal Methods fold :: Monoid m => Elem m -> m Source # foldMap :: Monoid m => (a -> m) -> Elem a -> m Source # foldMap' :: Monoid m => (a -> m) -> Elem a -> m Source # foldr :: (a -> b -> b) -> b -> Elem a -> b Source # foldr' :: (a -> b -> b) -> b -> Elem a -> b Source # foldl :: (b -> a -> b) -> b -> Elem a -> b Source # foldl' :: (b -> a -> b) -> b -> Elem a -> b Source # foldr1 :: (a -> a -> a) -> Elem a -> a Source # foldl1 :: (a -> a -> a) -> Elem a -> a Source # toList :: Elem a -> [a] Source # null :: Elem a -> Bool Source # length :: Elem a -> Int Source # elem :: Eq a => a -> Elem a -> Bool Source # maximum :: Ord a => Elem a -> a Source # minimum :: Ord a => Elem a -> a Source # | |
| Traversable Elem # | |
| Functor Elem # | |
| Generic (Elem a) # | |
| MaybeForce (Elem a) # | |
| Defined in Data.Sequence.Internal Methods maybeRwhnf :: Elem a -> () | |
| Sized (Elem a) # | |
| Defined in Data.Sequence.Internal | |
| NFData a => NFData (Elem a) # | |
| Defined in Data.Sequence.Internal | |
| Generic1 Elem # | |
| type Rep (Elem a) # | Since: containers-0.6.1 | 
| Defined in Data.Sequence.Internal | |
| type Rep1 Elem # | Since: containers-0.6.1 | 
| Defined in Data.Sequence.Internal | |
data FingerTree a #
Instances
Instances
Instances
Instances
| Sized a => Sized (Digit a) # | |
| Defined in Data.Sequence.Internal | |
| Sized (Elem a) # | |
| Defined in Data.Sequence.Internal | |
| Sized a => Sized (FingerTree a) # | |
| Defined in Data.Sequence.Internal Methods size :: FingerTree a -> Int # | |
| Sized (Node a) # | |
| Defined in Data.Sequence.Internal | |
class MaybeForce a #
Minimal complete definition
maybeRwhnf
Instances
| MaybeForce (Elem a) # | |
| Defined in Data.Sequence.Internal Methods maybeRwhnf :: Elem a -> () | |
| MaybeForce (Node a) # | |
| Defined in Data.Sequence.Internal Methods maybeRwhnf :: Node a -> () | |
General-purpose finite sequences.
Constructors
| Seq (FingerTree (Elem a)) | 
Bundled Patterns
| pattern Empty :: Seq a | A bidirectional pattern synonym matching an empty sequence. Since: containers-0.5.8 | 
| pattern (:<|) :: a -> Seq a -> Seq a infixr 5 | A bidirectional pattern synonym viewing the front of a non-empty sequence. Since: containers-0.5.8 | 
| pattern (:|>) :: Seq a -> a -> Seq a infixl 5 | A bidirectional pattern synonym viewing the rear of a non-empty sequence. Since: containers-0.5.8 | 
Instances
| MonadFix Seq # | Since: containers-0.5.11 | 
| MonadZip Seq # | 
 
 | 
| Foldable Seq # | |
| Defined in Data.Sequence.Internal Methods fold :: Monoid m => Seq m -> m Source # foldMap :: Monoid m => (a -> m) -> Seq a -> m Source # foldMap' :: Monoid m => (a -> m) -> Seq a -> m Source # foldr :: (a -> b -> b) -> b -> Seq a -> b Source # foldr' :: (a -> b -> b) -> b -> Seq a -> b Source # foldl :: (b -> a -> b) -> b -> Seq a -> b Source # foldl' :: (b -> a -> b) -> b -> Seq a -> b Source # foldr1 :: (a -> a -> a) -> Seq a -> a Source # foldl1 :: (a -> a -> a) -> Seq a -> a Source # toList :: Seq a -> [a] Source # null :: Seq a -> Bool Source # length :: Seq a -> Int Source # elem :: Eq a => a -> Seq a -> Bool Source # maximum :: Ord a => Seq a -> a Source # minimum :: Ord a => Seq a -> a Source # | |
| Eq1 Seq # | Since: containers-0.5.9 | 
| Ord1 Seq # | Since: containers-0.5.9 | 
| Defined in Data.Sequence.Internal | |
| Read1 Seq # | Since: containers-0.5.9 | 
| Defined in Data.Sequence.Internal Methods liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (Seq a) Source # liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [Seq a] Source # liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (Seq a) Source # liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [Seq a] Source # | |
| Show1 Seq # | Since: containers-0.5.9 | 
| Traversable Seq # | |
| Alternative Seq # | Since: containers-0.5.4 | 
| Applicative Seq # | Since: containers-0.5.4 | 
| Functor Seq # | |
| Monad Seq # | |
| MonadPlus Seq # | |
| Data a => Data (Seq a) # | |
| Defined in Data.Sequence.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Seq a -> c (Seq a) Source # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Seq a) Source # toConstr :: Seq a -> Constr Source # dataTypeOf :: Seq a -> DataType Source # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (Seq a)) Source # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Seq a)) Source # gmapT :: (forall b. Data b => b -> b) -> Seq a -> Seq a Source # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Seq a -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Seq a -> r Source # gmapQ :: (forall d. Data d => d -> u) -> Seq a -> [u] Source # gmapQi :: Int -> (forall d. Data d => d -> u) -> Seq a -> u Source # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Seq a -> m (Seq a) Source # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Seq a -> m (Seq a) Source # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Seq a -> m (Seq a) Source # | |
| a ~ Char => IsString (Seq a) # | Since: containers-0.5.7 | 
| Defined in Data.Sequence.Internal Methods fromString :: String -> Seq a Source # | |
| Monoid (Seq a) # | |
| Semigroup (Seq a) # | Since: containers-0.5.7 | 
| IsList (Seq a) # | |
| Read a => Read (Seq a) # | |
| Show a => Show (Seq a) # | |
| NFData a => NFData (Seq a) # | |
| Defined in Data.Sequence.Internal | |
| Eq a => Eq (Seq a) # | |
| Ord a => Ord (Seq a) # | |
| type Item (Seq a) # | |
| Defined in Data.Sequence.Internal | |
Instances
| Applicative (State s) # | |
| Defined in Utils.Containers.Internal.State | |
| Functor (State s) # | |
| Monad (State s) # | |
Construction
(<|) :: a -> Seq a -> Seq a infixr 5 #
\( O(1) \). Add an element to the left end of a sequence. Mnemonic: a triangle with the single element at the pointy end.
(|>) :: Seq a -> a -> Seq a infixl 5 #
\( O(1) \). Add an element to the right end of a sequence. Mnemonic: a triangle with the single element at the pointy end.
fromFunction :: Int -> (Int -> a) -> Seq a #
\( O(n) \). Convert a given sequence length and a function representing that sequence into a sequence.
Since: containers-0.5.6.2
fromArray :: Ix i => Array i a -> Seq a #
\( O(n) \). Create a sequence consisting of the elements of an Array.
 Note that the resulting sequence elements may be evaluated lazily (as on GHC),
 so you must force the entire structure to be sure that the original array
 can be garbage-collected.
Since: containers-0.5.6.2
Repetition
replicate :: Int -> a -> Seq a #
\( O(\log n) \). replicate n x is a sequence consisting of n copies of x.
replicateA :: Applicative f => Int -> f a -> f (Seq a) #
replicateA is an Applicative version of replicate, and makes
 \( O(\log n) \) calls to liftA2 and pure.
replicateA n x = sequenceA (replicate n x)
replicateM :: Applicative m => Int -> m a -> m (Seq a) #
replicateM is a sequence counterpart of replicateM.
replicateM n x = sequence (replicate n x)
For base >= 4.8.0 and containers >= 0.5.11, replicateM
 is a synonym for replicateA.
cycleTaking :: Int -> Seq a -> Seq a #
O(log k). cycleTaking k xsk by
 repeatedly concatenating xs with itself. xs may only be empty if
 k is 0.
cycleTaking k = fromList . take k . cycle . toList
Iterative construction
iterateN :: Int -> (a -> a) -> a -> Seq a #
\( O(n) \). Constructs a sequence by repeated application of a function to a seed value.
iterateN n f x = fromList (Prelude.take n (Prelude.iterate f x))
unfoldr :: (b -> Maybe (a, b)) -> b -> Seq a #
Builds a sequence from a seed value. Takes time linear in the number of generated elements. WARNING: If the number of generated elements is infinite, this method will not terminate.
Deconstruction
Queries
Views
View of the left end of a sequence.
Instances
| Foldable ViewL # | |
| Defined in Data.Sequence.Internal Methods fold :: Monoid m => ViewL m -> m Source # foldMap :: Monoid m => (a -> m) -> ViewL a -> m Source # foldMap' :: Monoid m => (a -> m) -> ViewL a -> m Source # foldr :: (a -> b -> b) -> b -> ViewL a -> b Source # foldr' :: (a -> b -> b) -> b -> ViewL a -> b Source # foldl :: (b -> a -> b) -> b -> ViewL a -> b Source # foldl' :: (b -> a -> b) -> b -> ViewL a -> b Source # foldr1 :: (a -> a -> a) -> ViewL a -> a Source # foldl1 :: (a -> a -> a) -> ViewL a -> a Source # toList :: ViewL a -> [a] Source # null :: ViewL a -> Bool Source # length :: ViewL a -> Int Source # elem :: Eq a => a -> ViewL a -> Bool Source # maximum :: Ord a => ViewL a -> a Source # minimum :: Ord a => ViewL a -> a Source # | |
| Traversable ViewL # | |
| Defined in Data.Sequence.Internal | |
| Functor ViewL # | |
| Data a => Data (ViewL a) # | |
| Defined in Data.Sequence.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> ViewL a -> c (ViewL a) Source # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (ViewL a) Source # toConstr :: ViewL a -> Constr Source # dataTypeOf :: ViewL a -> DataType Source # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (ViewL a)) Source # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (ViewL a)) Source # gmapT :: (forall b. Data b => b -> b) -> ViewL a -> ViewL a Source # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> ViewL a -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> ViewL a -> r Source # gmapQ :: (forall d. Data d => d -> u) -> ViewL a -> [u] Source # gmapQi :: Int -> (forall d. Data d => d -> u) -> ViewL a -> u Source # gmapM :: Monad m => (forall d. Data d => d -> m d) -> ViewL a -> m (ViewL a) Source # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> ViewL a -> m (ViewL a) Source # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> ViewL a -> m (ViewL a) Source # | |
| Generic (ViewL a) # | |
| Read a => Read (ViewL a) # | |
| Show a => Show (ViewL a) # | |
| Eq a => Eq (ViewL a) # | |
| Ord a => Ord (ViewL a) # | |
| Defined in Data.Sequence.Internal | |
| Generic1 ViewL # | |
| type Rep (ViewL a) # | Since: containers-0.5.8 | 
| Defined in Data.Sequence.Internal type Rep (ViewL a) = D1 ('MetaData "ViewL" "Data.Sequence.Internal" "containers-0.6.4.1" 'False) (C1 ('MetaCons "EmptyL" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons ":<" ('InfixI 'RightAssociative 5) 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 a) :*: S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (Seq a)))) | |
| type Rep1 ViewL # | Since: containers-0.5.8 | 
| Defined in Data.Sequence.Internal type Rep1 ViewL = D1 ('MetaData "ViewL" "Data.Sequence.Internal" "containers-0.6.4.1" 'False) (C1 ('MetaCons "EmptyL" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons ":<" ('InfixI 'RightAssociative 5) 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) Par1 :*: S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec1 Seq))) | |
View of the right end of a sequence.
Constructors
| EmptyR | empty sequence | 
| (Seq a) :> a infixl 5 | the sequence minus the rightmost element, and the rightmost element | 
Instances
| Foldable ViewR # | |
| Defined in Data.Sequence.Internal Methods fold :: Monoid m => ViewR m -> m Source # foldMap :: Monoid m => (a -> m) -> ViewR a -> m Source # foldMap' :: Monoid m => (a -> m) -> ViewR a -> m Source # foldr :: (a -> b -> b) -> b -> ViewR a -> b Source # foldr' :: (a -> b -> b) -> b -> ViewR a -> b Source # foldl :: (b -> a -> b) -> b -> ViewR a -> b Source # foldl' :: (b -> a -> b) -> b -> ViewR a -> b Source # foldr1 :: (a -> a -> a) -> ViewR a -> a Source # foldl1 :: (a -> a -> a) -> ViewR a -> a Source # toList :: ViewR a -> [a] Source # null :: ViewR a -> Bool Source # length :: ViewR a -> Int Source # elem :: Eq a => a -> ViewR a -> Bool Source # maximum :: Ord a => ViewR a -> a Source # minimum :: Ord a => ViewR a -> a Source # | |
| Traversable ViewR # | |
| Defined in Data.Sequence.Internal | |
| Functor ViewR # | |
| Data a => Data (ViewR a) # | |
| Defined in Data.Sequence.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> ViewR a -> c (ViewR a) Source # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (ViewR a) Source # toConstr :: ViewR a -> Constr Source # dataTypeOf :: ViewR a -> DataType Source # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (ViewR a)) Source # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (ViewR a)) Source # gmapT :: (forall b. Data b => b -> b) -> ViewR a -> ViewR a Source # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> ViewR a -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> ViewR a -> r Source # gmapQ :: (forall d. Data d => d -> u) -> ViewR a -> [u] Source # gmapQi :: Int -> (forall d. Data d => d -> u) -> ViewR a -> u Source # gmapM :: Monad m => (forall d. Data d => d -> m d) -> ViewR a -> m (ViewR a) Source # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> ViewR a -> m (ViewR a) Source # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> ViewR a -> m (ViewR a) Source # | |
| Generic (ViewR a) # | |
| Read a => Read (ViewR a) # | |
| Show a => Show (ViewR a) # | |
| Eq a => Eq (ViewR a) # | |
| Ord a => Ord (ViewR a) # | |
| Defined in Data.Sequence.Internal | |
| Generic1 ViewR # | |
| type Rep (ViewR a) # | Since: containers-0.5.8 | 
| Defined in Data.Sequence.Internal type Rep (ViewR a) = D1 ('MetaData "ViewR" "Data.Sequence.Internal" "containers-0.6.4.1" 'False) (C1 ('MetaCons "EmptyR" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons ":>" ('InfixI 'LeftAssociative 5) 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (Seq a)) :*: S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 a))) | |
| type Rep1 ViewR # | Since: containers-0.5.8 | 
| Defined in Data.Sequence.Internal type Rep1 ViewR = D1 ('MetaData "ViewR" "Data.Sequence.Internal" "containers-0.6.4.1" 'False) (C1 ('MetaCons "EmptyR" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons ":>" ('InfixI 'LeftAssociative 5) 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec1 Seq) :*: S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) Par1)) | |
Scans
Sublists
tails :: Seq a -> Seq (Seq a) #
\( O(n) \). Returns a sequence of all suffixes of this sequence, longest first. For example,
tails (fromList "abc") = fromList [fromList "abc", fromList "bc", fromList "c", fromList ""]
Evaluating the \( i \)th suffix takes \( O(\log(\min(i, n-i))) \), but evaluating every suffix in the sequence takes \( O(n) \) due to sharing.
inits :: Seq a -> Seq (Seq a) #
\( O(n) \). Returns a sequence of all prefixes of this sequence, shortest first. For example,
inits (fromList "abc") = fromList [fromList "", fromList "a", fromList "ab", fromList "abc"]
Evaluating the \( i \)th prefix takes \( O(\log(\min(i, n-i))) \), but evaluating every prefix in the sequence takes \( O(n) \) due to sharing.
chunksOf :: Int -> Seq a -> Seq (Seq a) #
\(O \Bigl(\bigl(\frac{n}{c}\bigr) \log c\Bigr)\). chunksOf c xs splits xs into chunks of size c>0.
 If c does not divide the length of xs evenly, then the last element
 of the result will be short.
Side note: the given performance bound is missing some messy terms that only really affect edge cases. Performance degrades smoothly from \( O(1) \) (for \( c = n \)) to \( O(n) \) (for \( c = 1 \)). The true bound is more like \( O \Bigl( \bigl(\frac{n}{c} - 1\bigr) (\log (c + 1)) + 1 \Bigr) \)
Since: containers-0.5.8
Sequential searches
takeWhileL :: (a -> Bool) -> Seq a -> Seq a #
\( O(i) \) where \( i \) is the prefix length. takeWhileL, applied
 to a predicate p and a sequence xs, returns the longest prefix
 (possibly empty) of xs of elements that satisfy p.
takeWhileR :: (a -> Bool) -> Seq a -> Seq a #
\( O(i) \) where \( i \) is the suffix length.  takeWhileR, applied
 to a predicate p and a sequence xs, returns the longest suffix
 (possibly empty) of xs of elements that satisfy p.
takeWhileR p xsreverse (takeWhileL p (reverse xs))
dropWhileL :: (a -> Bool) -> Seq a -> Seq a #
\( O(i) \) where \( i \) is the prefix length.  dropWhileL p xstakeWhileL p xs
dropWhileR :: (a -> Bool) -> Seq a -> Seq a #
\( O(i) \) where \( i \) is the suffix length.  dropWhileR p xstakeWhileR p xs
dropWhileR p xsreverse (dropWhileL p (reverse xs))
spanl :: (a -> Bool) -> Seq a -> (Seq a, Seq a) #
\( O(i) \) where \( i \) is the prefix length.  spanl, applied to
 a predicate p and a sequence xs, returns a pair whose first
 element is the longest prefix (possibly empty) of xs of elements that
 satisfy p and the second element is the remainder of the sequence.
spanr :: (a -> Bool) -> Seq a -> (Seq a, Seq a) #
\( O(i) \) where \( i \) is the suffix length.  spanr, applied to a
 predicate p and a sequence xs, returns a pair whose first element
 is the longest suffix (possibly empty) of xs of elements that
 satisfy p and the second element is the remainder of the sequence.
breakl :: (a -> Bool) -> Seq a -> (Seq a, Seq a) #
\( O(i) \) where \( i \) is the breakpoint index.  breakl, applied to a
 predicate p and a sequence xs, returns a pair whose first element
 is the longest prefix (possibly empty) of xs of elements that
 do not satisfy p and the second element is the remainder of
 the sequence.
partition :: (a -> Bool) -> Seq a -> (Seq a, Seq a) #
\( O(n) \).  The partition function takes a predicate p and a
 sequence xs and returns sequences of those elements which do and
 do not satisfy the predicate.
filter :: (a -> Bool) -> Seq a -> Seq a #
\( O(n) \).  The filter function takes a predicate p and a sequence
 xs and returns a sequence of those elements which satisfy the
 predicate.
Indexing
lookup :: Int -> Seq a -> Maybe a #
\( O(\log(\min(i,n-i))) \). The element at the specified position,
 counting from 0. If the specified position is negative or at
 least the length of the sequence, lookup returns Nothing.
0 <= i < length xs ==> lookup i xs == Just (toList xs !! i)
i < 0 || i >= length xs ==> lookup i xs = Nothing
Unlike index, this can be used to retrieve an element without
 forcing it. For example, to insert the fifth element of a sequence
 xs into a Map m at key k, you could use
case lookup 5 xs of
  Nothing -> m
  Just x -> insert k x m
Since: containers-0.5.8
(!?) :: Seq a -> Int -> Maybe a #
\( O(\log(\min(i,n-i))) \). A flipped, infix version of lookup.
Since: containers-0.5.8
\( O(\log(\min(i,n-i))) \). The element at the specified position,
 counting from 0.  The argument should thus be a non-negative
 integer less than the size of the sequence.
 If the position is out of range, index fails with an error.
xs `index` i = toList xs !! i
Caution: index necessarily delays retrieving the requested
 element until the result is forced. It can therefore lead to a space
 leak if the result is stored, unforced, in another structure. To retrieve
 an element immediately without forcing it, use lookup or (!?).
adjust :: (a -> a) -> Int -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). Update the element at the specified position.  If
 the position is out of range, the original sequence is returned.  adjust
 can lead to poor performance and even memory leaks, because it does not
 force the new value before installing it in the sequence. adjust' should
 usually be preferred.
Since: containers-0.5.8
adjust' :: forall a. (a -> a) -> Int -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). Update the element at the specified position. If the position is out of range, the original sequence is returned. The new value is forced before it is installed in the sequence.
adjust' f i xs =
 case xs !? i of
   Nothing -> xs
   Just x -> let !x' = f x
             in update i x' xs
Since: containers-0.5.8
update :: Int -> a -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). Replace the element at the specified position. If the position is out of range, the original sequence is returned.
take :: Int -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). The first i elements of a sequence.
 If i is negative, take i si elements, the whole sequence
 is returned.
drop :: Int -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). Elements of a sequence after the first i.
 If i is negative, drop i si elements, the empty sequence
 is returned.
insertAt :: Int -> a -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). insertAt i x xsx into xs
 at the index i, shifting the rest of the sequence over.
insertAt 2 x (fromList [a,b,c,d]) = fromList [a,b,x,c,d]
insertAt 4 x (fromList [a,b,c,d]) = insertAt 10 x (fromList [a,b,c,d])
                                  = fromList [a,b,c,d,x]
insertAt i x xs = take i xs >< singleton x >< drop i xs
Since: containers-0.5.8
deleteAt :: Int -> Seq a -> Seq a #
\( O(\log(\min(i,n-i))) \). Delete the element of a sequence at a given index. Return the original sequence if the index is out of range.
deleteAt 2 [a,b,c,d] = [a,b,d] deleteAt 4 [a,b,c,d] = deleteAt (-1) [a,b,c,d] = [a,b,c,d]
Since: containers-0.5.8
Indexing with predicates
These functions perform sequential searches from the left or right ends of the sequence, returning indices of matching elements.
elemIndexL :: Eq a => a -> Seq a -> Maybe Int #
elemIndexL finds the leftmost index of the specified element,
 if it is present, and otherwise Nothing.
elemIndicesL :: Eq a => a -> Seq a -> [Int] #
elemIndicesL finds the indices of the specified element, from
 left to right (i.e. in ascending order).
elemIndexR :: Eq a => a -> Seq a -> Maybe Int #
elemIndexR finds the rightmost index of the specified element,
 if it is present, and otherwise Nothing.
elemIndicesR :: Eq a => a -> Seq a -> [Int] #
elemIndicesR finds the indices of the specified element, from
 right to left (i.e. in descending order).
findIndexL :: (a -> Bool) -> Seq a -> Maybe Int #
findIndexL p xsp, if any exist.
findIndicesL :: (a -> Bool) -> Seq a -> [Int] #
findIndicesL pp,
 in ascending order.
findIndexR :: (a -> Bool) -> Seq a -> Maybe Int #
findIndexR p xsp, if any exist.
findIndicesR :: (a -> Bool) -> Seq a -> [Int] #
findIndicesR pp,
 in descending order.
Folds
foldMapWithIndex :: Monoid m => (Int -> a -> m) -> Seq a -> m #
foldlWithIndex :: (b -> Int -> a -> b) -> b -> Seq a -> b #
foldlWithIndex is a version of foldl that also provides access
 to the index of each element.
foldrWithIndex :: (Int -> a -> b -> b) -> b -> Seq a -> b #
foldrWithIndex is a version of foldr that also provides access
 to the index of each element.
Transformations
mapWithIndex :: (Int -> a -> b) -> Seq a -> Seq b #
A generalization of fmap, mapWithIndex takes a mapping
 function that also depends on the element's index, and applies it to every
 element in the sequence.
traverseWithIndex :: Applicative f => (Int -> a -> f b) -> Seq a -> f (Seq b) #
traverseWithIndex is a version of traverse that also offers
 access to the index of each element.
Since: containers-0.5.8
intersperse :: a -> Seq a -> Seq a #
\( O(n) \). Intersperse an element between the elements of a sequence.
intersperse a empty = empty intersperse a (singleton x) = singleton x intersperse a (fromList [x,y]) = fromList [x,a,y] intersperse a (fromList [x,y,z]) = fromList [x,a,y,a,z]
Since: containers-0.5.8
Zips and unzips
zip :: Seq a -> Seq b -> Seq (a, b) #
\( O(\min(n_1,n_2)) \).  zip takes two sequences and returns a sequence
 of corresponding pairs.  If one input is short, excess elements are
 discarded from the right end of the longer sequence.
unzipWith :: (a -> (b, c)) -> Seq a -> (Seq b, Seq c) #
\( O(n) \). Unzip a sequence using a function to divide elements.
unzipWith f xs ==unzip(fmapf xs)
Efficiency note:
unzipWith produces its two results in lockstep. If you calculate
  unzipWith f xs  and fully force either of the results, then the
 entire structure of the other one will be built as well. This
 behavior allows the garbage collector to collect each calculated
 pair component as soon as it dies, without having to wait for its mate
 to die. If you do not need this behavior, you may be better off simply
 calculating the sequence of pairs and using fmap to extract each
 component sequence.
Since: containers-0.5.11