From 72e110ce5d361b5b2621c972d6fe317c38e8cfca Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Fri, 24 Aug 2012 13:04:28 -0400 Subject: [PATCH] avoid requeueing a download from a remote that no longer has a key --- Assistant/DaemonStatus.hs | 1 - Assistant/Threads/TransferScanner.hs | 42 ++++++++++++++++++++-------- 2 files changed, 30 insertions(+), 13 deletions(-) diff --git a/Assistant/DaemonStatus.hs b/Assistant/DaemonStatus.hs index 44789290c3..4a9dfb4e25 100644 --- a/Assistant/DaemonStatus.hs +++ b/Assistant/DaemonStatus.hs @@ -22,7 +22,6 @@ import Data.Time.Clock.POSIX import Data.Time import System.Locale import qualified Data.Map as M -import Control.Exception data DaemonStatus = DaemonStatus -- False when the daemon is performing its startup scan diff --git a/Assistant/Threads/TransferScanner.hs b/Assistant/Threads/TransferScanner.hs index 8dc3a6a981..d1d27e4802 100644 --- a/Assistant/Threads/TransferScanner.hs +++ b/Assistant/Threads/TransferScanner.hs @@ -49,12 +49,30 @@ failedTransferScan st dstatus transferqueue r = do go ts where go [] = noop - go ((t, info):ts) = do + go ((t, info):ts) + | transferDirection t == Download = do + {- Check if the remote still has the key. + - If not, relies on the expensiveScan to + - get it queued from some other remote. -} + ifM (runThreadState st $ remoteHas r $ transferKey t) + ( requeue t info + , dequeue t + ) + go ts + | otherwise = do + {- The Transferrer checks when uploading + - that the remote doesn't already have the + - key, so it's not redundantly checked + - here. -} + requeue t info + go ts + + requeue t info = do queueTransferWhenSmall transferqueue dstatus (associatedFile info) t r - void $ runThreadState st $ inRepo $ - liftIO . tryIO . removeFile . failedTransferFile t - go ts + dequeue t + dequeue t = void $ runThreadState st $ inRepo $ + liftIO . tryIO . removeFile . failedTransferFile t {- This is a expensive scan through the full git work tree. - @@ -79,17 +97,17 @@ expensiveScan st dstatus transferqueue r = do go fs where check _ (key, _) = ifM (inAnnex key) - ( helper key Upload False =<< remotehas key - , helper key Download True =<< remotehas key + ( helper key Upload False =<< remoteHas r key + , helper key Download True =<< remoteHas r key ) helper key direction x y - | x == y = return $ - Just $ Transfer direction u key + | x == y = return $ Just $ + Transfer direction (Remote.uuid r) key | otherwise = return Nothing - u = Remote.uuid r enqueue f t = queueTransferWhenSmall transferqueue dstatus (Just f) t r - remotehas key = elem - <$> pure u - <*> loggedLocations key +remoteHas :: Remote -> Key -> Annex Bool +remoteHas r key = elem + <$> pure (Remote.uuid r) + <*> loggedLocations key