deal with transferkey crashing

If transferkey crashes or even fails to run, the TransferWatcher will not
see the transfer info file be created, so will not remove the transfer
from the list of active transfers. This causes the list to grow
continually, and all active transfers are displayed in the webapp. So, put
in a guard.

I assume that transferkey will not exit 0 while neglecting to clean up.
This commit is contained in:
Joey Hess 2013-03-18 22:58:14 -04:00
parent 29d603b72a
commit aadb9069b3

View file

@ -88,19 +88,26 @@ startTransfer program t info = case (transferRemote info, associatedFile info) o
- made, in order to queue a push of the git-annex - made, in order to queue a push of the git-annex
- branch out to remotes that did not participate - branch out to remotes that did not participate
- in the transfer. - in the transfer.
-
- If the process failed, it could have crashed,
- so remove the transfer from the list of current
- transfers, just in case it didn't stop
- in a way that lets the TransferWatcher do its
- usual cleanup.
-} -}
whenM (liftIO $ (==) ExitSuccess <$> waitForProcess pid) $ do ifM (liftIO $ (==) ExitSuccess <$> waitForProcess pid)
void $ addAlert $ makeAlertFiller True $ ( do
transferFileAlert direction True file void $ addAlert $ makeAlertFiller True $
unless isdownload $ transferFileAlert direction True file
handleDrops unless isdownload $
("object uploaded to " ++ show remote) handleDrops
True (transferKey t) ("object uploaded to " ++ show remote)
(associatedFile info) True (transferKey t)
(Just remote) (associatedFile info)
recordCommit (Just remote)
recordCommit
void $ removeTransfer t , void $ removeTransfer t
)
where where
params = params =
[ Param "transferkey" [ Param "transferkey"