1
1
mirror of https://github.com/github/semantic.git synced 2025-01-05 05:58:34 +03:00

runMyersSteps constructs the initial state itself.

This commit is contained in:
Rob Rix 2017-03-13 11:35:11 -04:00
parent 8998884e51
commit 95a800660e

View File

@ -48,10 +48,11 @@ runMyers eq step = runAll (emptyStateForStep step) step
Left a -> a Left a -> a
Right next -> uncurry runAll next Right next -> uncurry runAll next
runMyersSteps :: HasCallStack => (a -> a -> Bool) -> MyersState -> Myers a b -> [(MyersState, Myers a b)] runMyersSteps :: HasCallStack => (a -> a -> Bool) -> Myers a b -> [(MyersState, Myers a b)]
runMyersSteps eq state step = let ?callStack = popCallStack callStack in (state, step) : case runMyersStep eq state step of runMyersSteps eq step = go (emptyStateForStep step) step
Left result -> [ (state, return result) ] where go state step = let ?callStack = popCallStack callStack in (state, step) : case runMyersStep eq state step of
Right next -> uncurry (runMyersSteps eq) next Left result -> [ (state, return result) ]
Right next -> uncurry go next
runMyersStep :: HasCallStack => (a -> a -> Bool) -> MyersState -> Myers a b -> Either b (MyersState, Myers a b) runMyersStep :: HasCallStack => (a -> a -> Bool) -> MyersState -> Myers a b -> Either b (MyersState, Myers a b)
runMyersStep eq state step = let ?callStack = popCallStack callStack in case step of runMyersStep eq state step = let ?callStack = popCallStack callStack in case step of