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:
parent
8998884e51
commit
95a800660e
@ -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
|
||||||
|
where go state step = let ?callStack = popCallStack callStack in (state, step) : case runMyersStep eq state step of
|
||||||
Left result -> [ (state, return result) ]
|
Left result -> [ (state, return result) ]
|
||||||
Right next -> uncurry (runMyersSteps eq) next
|
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
|
||||||
|
Loading…
Reference in New Issue
Block a user