| Copyright | (C) 2012-16 Edward Kmett | 
|---|---|
| License | BSD-style (see the file LICENSE) | 
| Maintainer | Edward Kmett <ekmett@gmail.com> | 
| Stability | provisional | 
| Portability | Rank2Types | 
| Safe Haskell | Safe | 
| Language | Haskell98 | 
Control.Lens.Unsound
Description
One commonly asked question is: can we combine two lenses,
 Lens' a bLens' a cLens' a (b, c)lensProduct.
Documentation
lensProduct :: ALens' s a -> ALens' s b -> Lens' s (a, b) Source #
A lens product. There is no law-abiding way to do this in general.
 Result is only a valid Lens if the input lenses project disjoint parts of 
 the structure s. Otherwise "you get what you put in" law
viewl (setl v s) ≡ v
is violated by
>>>let badLens :: Lens' (Int, Char) (Int, Int); badLens = lensProduct _1 _1>>>view badLens (set badLens (1,2) (3,'x'))(2,2)
but we should get (1,2).
Are you looking for alongside?
prismSum :: APrism s t a b -> APrism s t c d -> Prism s t (Either a c) (Either b d) Source #
A dual of lensProduct: a prism sum.
The law
previewl (reviewl b) ≡Justb
breaks with
>>>let badPrism :: Prism' (Maybe Char) (Either Char Char); badPrism = prismSum _Just _Just>>>preview badPrism (review badPrism (Right 'x'))Just (Left 'x')
We put in Right value, but get back Left.
Are you looking for without?