I currently have code that looks like this:
do
x <- use foo
foo <~ runFoo x
where foo
is a Lens
to a Foo
field and runFoo :: MonadState m => Foo -> m Foo
I think there should be a way to do this operation in one line, but I cannot find it. I think it ought to have a comment like:
(????) :: MonadState s m => Lens' s a -> (a -> m a) -> m a
Questions:
- Does such a combinator exist? if so what is it?
- When I run into another question like this, what is the best way to search for it (i.e. Usually I would just type this into Hoogle but I've not had good luck doing that with the lens library)
- Is this actually a primitive combinator found in Control.Monad? (I will be slightly embarrassed if this is yet another job for the kleisli arrow)
lens doesn't offer such a combinator in a ready-made form. If instead of
runFoo
you had someg :: a -> a
function, you would be able to use(%=)
, which is toover
whatuse
is toview
, and write simplyfoo %= g
. Your desired functionality, though, involves interleaving them
effects introduced byrunFoo
in between the getting and setting, which precludes a solution this straightforward.