Portability | non-portable |
---|---|
Stability | experimental |
Maintainer | Edward Kmett <ekmett@gmail.com> |
Safe Haskell | Trustworthy |
At
class Ixed m => At m whereSource
At
provides a Lens
that can be used to read,
write or delete the value associated with a key in a Map
-like
container on an ad hoc basis.
An instance of At
should satisfy:
ix
k ≡at
k.
traverse
Ixed
This simple Traversal
lets you traverse
the value at a given
key in a Map
or element at an ordinal position in a list or Seq
.
ix :: Index m -> Traversal' m (IxValue m)Source
This simple Traversal
lets you traverse
the value at a given
key in a Map
or element at an ordinal position in a list or Seq
.
NB: Setting the value of this Traversal
will only set the value in
at
if it is already present.
If you want to be able to insert missing values, you want at
.
>>>
Seq.fromList [a,b,c,d] & ix 2 %~ f
fromList [a,b,f c,d]
>>>
Seq.fromList [a,b,c,d] & ix 2 .~ e
fromList [a,b,e,d]
>>>
Seq.fromList [a,b,c,d] ^? ix 2
Just c
>>>
Seq.fromList [] ^? ix 2
Nothing
Ixed ByteString | |
Ixed ByteString | |
Ixed Text | |
Ixed Text | |
Ixed IntSet | |
Ixed [a] | |
Ixed (Identity a) | |
Ixed (Maybe a) | |
Ixed (IntMap a) | |
Ixed (NonEmpty a) | |
(Eq k, Hashable k) => Ixed (HashSet k) | |
Ixed (Vector a) | |
Unbox a => Ixed (Vector a) | |
Storable a => Ixed (Vector a) | |
Prim a => Ixed (Vector a) | |
Ord k => Ixed (Set k) | |
Ixed (Seq a) | |
Ixed (Tree a) | |
Eq e => Ixed (e -> a) | |
~ * a a2 => Ixed (a, a2) | |
Ord k => Ixed (Map k a) | |
(Eq k, Hashable k) => Ixed (HashMap k a) | |
Ix i => Ixed (Array i e) | arr |
(IArray UArray e, Ix i) => Ixed (UArray i e) | arr |
(~ * a a2, ~ * a a3) => Ixed (a, a2, a3) | |
(~ * a a2, ~ * a a3, ~ * a a4) => Ixed (a, a2, a3, a4) | |
(~ * a a2, ~ * a a3, ~ * a a4, ~ * a a5) => Ixed (a, a2, a3, a4, a5) | |
(~ * a a2, ~ * a a3, ~ * a a4, ~ * a a5, ~ * a a6) => Ixed (a, a2, a3, a4, a5, a6) | |
(~ * a a2, ~ * a a3, ~ * a a4, ~ * a a5, ~ * a a6, ~ * a a7) => Ixed (a, a2, a3, a4, a5, a6, a7) | |
(~ * a a2, ~ * a a3, ~ * a a4, ~ * a a5, ~ * a a6, ~ * a a7, ~ * a a8) => Ixed (a, a2, a3, a4, a5, a6, a7, a8) | |
(~ * a a2, ~ * a a3, ~ * a a4, ~ * a a5, ~ * a a6, ~ * a a7, ~ * a a8, ~ * a a9) => Ixed (a, a2, a3, a4, a5, a6, a7, a8, a9) |
Contains
This class provides a simple IndexedFold
(or IndexedTraversal
) that lets you view (and modify)
information about whether or not a container contains a given Index
.