安全地概括ST返回值

时间:2018-03-19 05:07:01

标签: haskell

对于某些具体的foo :: (forall s . ST s a) -> ba,我有一个ST提取器b。我可以安全地创建另一个函数fooC :: (forall s . ST s (a, c)) -> (b, c),这将允许我从ST计算中返回一些额外的值吗?是否可以安全使用通用转换addC :: ((forall s . ST s a) -> b) -> (forall s1 . ST s1 (a,c)) -> (b,c)

1 个答案:

答案 0 :(得分:3)

我不确定我是否理解您要完成的任务,但这种类型正确:

addC :: ((forall s . ST s a) -> b)
     -> (forall s1 . ST s1 (a,c)) -> (b,c)
addC f m = runST $ (\(a,c) -> (f (pure a), c)) <$> m

请注意,(forall s. ST s a)a同构(由purerunST见证),所以也许您应该只使用函数a -> b和价值(a, c)