我正在尝试使下面的代码正常工作。这是一个有限状态机,我在其中传递一个函数作为下一个状态。该函数被调用r
并返回结果列表+下一个函数作为下一个状态。继续调用直到列表用完,并返回结果的串联。monad 是一个错误 monad,允许我在需要时抛出错误。
fsm f [] = return []
fsm f (r:rs) = do
(xs, f') <- f r
rest <- fsm f' rs
return $ xs ++ rest
错误是:
Occurs check: cannot construct the infinite type: t1 = t0 -> m0 ([a0], t1)
In the first argument of `fsm', namely f'
我以前见过无限类型错误,我理解解决它的方法是用newtype
. 但我无法弄清楚如何完成这项工作。
有人可以指出洞察力吗?