15

のように機能するレンズ関数が必要でしたoverが、モナド演算を使用します。

overM :: (Monad m) => Lens s t a b -> (a -> m b) -> (s -> m t)

この関数は簡単に定義できますが (実際には単なる恒等法です)、そのような関数はlensWrappedMonadのどこかに定義されているのでしょうか?

{-# LANGUAGE RankNTypes #-}
import Control.Applicative
import Control.Lens

overF :: (Functor f) => Lens s t a b -> (a -> f b) -> (s -> f t)
overF l = l

overM :: (Monad m) => Lens s t a b -> (a -> m b) -> (s -> m t)
overM l = (unwrapMonad .) . l . (WrapMonad .)
4

1 に答える 1

8

Control.Lens.Traversal で:

traverseOf :: Over p f s t a b -> p a (f b) -> s -> f t
traverseOf = id

mapMOf :: Profunctor p =>
     Over p (WrappedMonad m) s t a b -> p a (m b) -> s -> m t
mapMOf l cmd = unwrapMonad #. l (WrapMonad #. cmd)

例:

Prelude Control.Lens> traverseOf _1 (Just . (+2)) (2,2)
Just (4,2)

Prelude Control.Lens> mapMOf _1 (Just . (+2)) (2,2)
Just (4,2)
于 2014-03-05T22:34:09.340 に答える