StateT's catchError doesn't take into account that the state can change in the call to is first parameter:
instance monadErrorStateT :: MonadError e m => MonadError e (StateT s m) where
catchError (StateT m) h =
StateT \s -> catchError (m s) (\e -> case h e of StateT f -> f s)
StateT's function m COULD change state and if it does, that state change is lost, i.e. it's neither captured nor is it passed to f.
This is ONLY noticeable when you have a Stack where StateT is ABOVE ExceptT otherwise StateT's catchError will NOT be called.
After many tests, I've come to the conclusion that this CANNOT be fixed. Here was my initial attempt to fix it:
instance monadErrorStateT :: MonadError e m => MonadError e (StateT s m) where
catchError (StateT m) h =
StateT \s -> m s >>= \t@(Tuple _ s') -> catchError (pure t) (\e -> case h e of StateT f -> f s')
The problem is that ExceptT is BELOW StateT in the Stack. That means that m s >>= ... will Short-circuit, which is NOT the desired behavior here.
I cannot see any way to capture the changes made to the state by the first call that won't Short-circuit.
So, the only question that remains is how to communicate this information in the docs. The only place that makes sense in the StateT docs.
StateT'scatchErrordoesn't take into account that the state can change in the call to is first parameter:StateT'sfunctionmCOULD change state and if it does, that state change is lost, i.e. it's neither captured nor is it passed tof.This is ONLY noticeable when you have a Stack where
StateTis ABOVEExceptTotherwiseStateT'scatchErrorwill NOT be called.After many tests, I've come to the conclusion that this CANNOT be fixed. Here was my initial attempt to fix it:
The problem is that
ExceptTis BELOWStateTin the Stack. That means thatm s >>= ...will Short-circuit, which is NOT the desired behavior here.I cannot see any way to capture the changes made to the state by the first call that won't Short-circuit.
So, the only question that remains is how to communicate this information in the docs. The only place that makes sense in the
StateTdocs.