| Copyright | (C) 2012-15 Edward Kmett | 
|---|---|
| License | BSD-style (see the file LICENSE) | 
| Maintainer | Edward Kmett <ekmett@gmail.com> | 
| Stability | experimental | 
| Portability | non-portable | 
| Safe Haskell | Trustworthy | 
| Language | Haskell98 | 
Control.Lens.At
Description
- class Ixed m => At m where
- sans :: At m => Index m -> m -> m
- iat :: At m => Index m -> IndexedLens' (Index m) m (Maybe (IxValue m))
- type family Index s :: *
- type family IxValue m :: *
- class Ixed m where- ix :: Index m -> Traversal' m (IxValue m)
 
- ixAt :: At m => Index m -> Traversal' m (IxValue m)
- iix :: Ixed m => Index m -> IndexedTraversal' (Index m) m (IxValue m)
- class Contains m where
- icontains :: Contains m => Index m -> IndexedLens' (Index m) m Bool
At
class Ixed m => At m where Source
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:
ixk ≡atk.traverse
Methods
iat :: At m => Index m -> IndexedLens' (Index m) m (Maybe (IxValue m)) Source
An indexed version of at.
>>>Map.fromList [(1,"world")] ^@. iat 1(1,Just "world")
>>>iat 1 %@~ (\i x -> if odd i then Just "hello" else Nothing) $ Map.emptyfromList [(1,"hello")]
>>>iat 2 %@~ (\i x -> if odd i then Just "hello" else Nothing) $ Map.emptyfromList []
Ixed
type family Index s :: * Source
Instances
| type Index ByteString = Int | |
| type Index ByteString = Int64 | |
| type Index IntSet = Int | |
| type Index Text = Int64 | |
| type Index Text = Int | |
| type Index [a] = Int | |
| type Index (Complex a) = Int | |
| type Index (Maybe a) = () | |
| type Index (Identity a) = () | |
| type Index (IntMap a) = Int | |
| type Index (Set a) = a | |
| type Index (Tree a) = [Int] | |
| type Index (Seq a) = Int | |
| type Index (NonEmpty a) = Int | |
| type Index (HashSet a) = a | |
| type Index (Vector a) = Int | |
| type Index (Vector a) = Int | |
| type Index (Vector a) = Int | |
| type Index (Vector a) = Int | |
| type Index (e -> a) = e | |
| type Index (a, b) = Int | |
| type Index (UArray i e) = i | |
| type Index (Array i e) = i | |
| type Index (Map k a) = k | |
| type Index (HashMap k a) = k | |
| type Index (a, b, c) = Int | |
| type Index (a, b, c, d) = Int | |
| type Index (a, b, c, d, e) = Int | |
| type Index (a, b, c, d, e, f) = Int | |
| type Index (a, b, c, d, e, f, g) = Int | |
| type Index (a, b, c, d, e, f, g, h) = Int | |
| type Index (a, b, c, d, e, f, g, h, i) = Int | 
type family IxValue m :: * Source
Instances
| type IxValue ByteString = Word8 | |
| type IxValue ByteString = Word8 | |
| type IxValue IntSet = () | |
| type IxValue Text = Char | |
| type IxValue Text = Char | |
| type IxValue [a] = a | |
| type IxValue (Maybe a) = a | |
| type IxValue (Identity a) = a | |
| type IxValue (IntMap a) = a | |
| type IxValue (Set k) = () | |
| type IxValue (Tree a) = a | |
| type IxValue (Seq a) = a | |
| type IxValue (NonEmpty a) = a | |
| type IxValue (HashSet k) = () | |
| type IxValue (Vector a) = a | |
| type IxValue (Vector a) = a | |
| type IxValue (Vector a) = a | |
| type IxValue (Vector a) = a | |
| type IxValue (e -> a) = a | |
| type IxValue (a, a2) = a | 
 | 
| type IxValue (UArray i e) = e | |
| type IxValue (Array i e) = e | |
| type IxValue (Map k a) = a | |
| type IxValue (HashMap k a) = a | |
| type IxValue (a, a2, a3) = a | 
 | 
| type IxValue (a, a2, a3, a4) = a | 
 | 
| type IxValue (a, a2, a3, a4, a5) = a | 
 | 
| type IxValue (a, a2, a3, a4, a5, a6) = a | 
 | 
| type IxValue (a, a2, a3, a4, a5, a6, a7) = a | 
 | 
| type IxValue (a, a2, a3, a4, a5, a6, a7, a8) = a | 
 | 
| type IxValue (a, a2, a3, a4, a5, a6, a7, a8, a9) = a | 
 | 
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.
Methods
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 %~ ffromList [a,b,f c,d]
>>>Seq.fromList [a,b,c,d] & ix 2 .~ efromList [a,b,e,d]
>>>Seq.fromList [a,b,c,d] ^? ix 2Just c
>>>Seq.fromList [] ^? ix 2Nothing
Instances
| Ixed ByteString | |
| Ixed ByteString | |
| Ixed IntSet | |
| Ixed Text | |
| Ixed Text | |
| Ixed [a] | |
| Ixed (Maybe a) | |
| Ixed (Identity a) | |
| Ixed (IntMap a) | |
| Ord k => Ixed (Set k) | |
| Ixed (Tree a) | |
| Ixed (Seq 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) | |
| Eq e => Ixed (e -> a) | |
| (~) * a a2 => Ixed (a, a2) | |
| (IArray UArray e, Ix i) => Ixed (UArray i e) | arr | 
| Ix i => Ixed (Array i e) | arr | 
| Ord k => Ixed (Map k a) | |
| (Eq k, Hashable k) => Ixed (HashMap k a) | |
| ((~) * 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) | 
iix :: Ixed m => Index m -> IndexedTraversal' (Index m) m (IxValue m) Source
An indexed version of ix.
>>>Seq.fromList [a,b,c,d] & iix 2 %@~ f'fromList [a,b,f' 2 c,d]
>>>Seq.fromList [a,b,c,d] & iix 2 .@~ hfromList [a,b,h 2,d]
>>>Seq.fromList [a,b,c,d] ^@? iix 2Just (2,c)
>>>Seq.fromList [] ^@? iix 2Nothing
Contains
This class provides a simple Lens that lets you view (and modify)
 information about whether or not a container contains a given Index.
icontains :: Contains m => Index m -> IndexedLens' (Index m) m Bool Source
An indexed version of contains.
>>>IntSet.fromList [1,2,3,4] ^@. icontains 3(3,True)
>>>IntSet.fromList [1,2,3,4] ^@. icontains 5(5,False)
>>>IntSet.fromList [1,2,3,4] & icontains 3 %@~ \i x -> if odd i then not x else xfromList [1,2,4]
>>>IntSet.fromList [1,2,3,4] & icontains 3 %@~ \i x -> if even i then not x else xfromList [1,2,3,4]