1
1
mirror of https://github.com/github/semantic.git synced 2025-01-03 04:51:57 +03:00

🔥 the bogus shortcuts.

This commit is contained in:
Rob Rix 2017-03-10 14:01:51 -05:00
parent eaf898dc4a
commit e74119d3de

View File

@ -98,9 +98,7 @@ decompose myers = let ?callStack = popCallStack callStack in case myers of
forwardEndpoint <- findDPath graph Forward (EditDistance d) (Diagonal k) forwardEndpoint <- findDPath graph Forward (EditDistance d) (Diagonal k)
backwardV <- gets backward backwardV <- gets backward
let reverseEndpoint = backwardV `at` k let reverseEndpoint = backwardV `at` k
if x forwardEndpoint >= n && y forwardEndpoint >= m then if odd delta && k `inInterval` (delta - pred d, delta + pred d) && overlaps forwardEndpoint reverseEndpoint then
return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance 0))
else if odd delta && k `inInterval` (delta - pred d, delta + pred d) && overlaps forwardEndpoint reverseEndpoint then
return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance $ 2 * d - 1)) return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance $ 2 * d - 1))
else else
continue) continue)
@ -108,9 +106,7 @@ decompose myers = let ?callStack = popCallStack callStack in case myers of
reverseEndpoint <- findDPath graph Reverse (EditDistance d) (Diagonal (k + delta)) reverseEndpoint <- findDPath graph Reverse (EditDistance d) (Diagonal (k + delta))
forwardV <- gets forward forwardV <- gets forward
let forwardEndpoint = forwardV `at` (k + delta) let forwardEndpoint = forwardV `at` (k + delta)
if x reverseEndpoint <= 0 && y forwardEndpoint <= 0 then if even delta && (k + delta) `inInterval` (negate d, d) && overlaps forwardEndpoint reverseEndpoint then
return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance $ 2 * d))
else if even delta && (k + delta) `inInterval` (negate d, d) && overlaps forwardEndpoint reverseEndpoint then
return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance $ 2 * d)) return (Just (Snake reverseEndpoint forwardEndpoint, EditDistance $ 2 * d))
else else
continue) continue)