mirror of
https://github.com/github/semantic.git
synced 2024-12-22 06:11:49 +03:00
Try to implement reverse d-path endpoint finding.
This commit is contained in:
parent
e2b4b65423
commit
28b5a99333
@ -130,7 +130,15 @@ decompose myers = let ?callStack = popCallStack callStack in case myers of
|
||||
FindDPath _ Reverse (EditDistance d) (Diagonal k) -> do
|
||||
v <- gets backward
|
||||
eq <- getEq
|
||||
return (Endpoint 0 0)
|
||||
let prev = v `at` pred k
|
||||
let next = v `at` succ k
|
||||
let xy = if k == negate d || k /= d && x prev < x next
|
||||
then next
|
||||
else let x' = succ (x prev) in Endpoint x' (x' - k)
|
||||
let Endpoint x' y' = slide (negate 1) eq xy
|
||||
setBackward (v Vector.// [(maxD + k, x')])
|
||||
return (Endpoint x' y')
|
||||
where at v k = let x = v ! maxD + delta + k in Endpoint x (x - k)
|
||||
|
||||
where (!) = (Vector.!)
|
||||
EditGraph as bs = editGraph myers
|
||||
|
Loading…
Reference in New Issue
Block a user