我需要一个可以像 一样工作的镜头功能over
,但具有单子操作:
overM :: (Monad m) => Lens s t a b -> (a -> m b) -> (s -> m t)
虽然这个函数很容易定义(它实际上只是一个恒等模WrappedMonad
),但我想知道这些函数是否定义在lens的某个地方?
{-# 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 .)