add filename to progress bar, and display ok/failed at end

This needed plumbing an AssociatedFile through retrieveKeyFileCheap.
This commit is contained in:
Joey Hess 2015-04-14 16:35:10 -04:00
parent dc4de7faf7
commit a2902cdaaf
21 changed files with 85 additions and 74 deletions

View file

@ -84,7 +84,7 @@ buildFlags = filter (not . null)
#ifdef WITH_TORRENTPARSER #ifdef WITH_TORRENTPARSER
, "TorrentParser" , "TorrentParser"
#else #else
#warning Building without haskell torrent library; will instead use btshowmetainfo to parse torrent files.
#endif #endif
#ifdef WITH_EKG #ifdef WITH_EKG
, "EKG" , "EKG"

View file

@ -135,11 +135,11 @@ performRemote key file backend numcopies remote =
cleanup cleanup
cleanup `after` a tmp cleanup `after` a tmp
getfile tmp = getfile tmp =
ifM (Remote.retrieveKeyFileCheap remote key tmp) ifM (Remote.retrieveKeyFileCheap remote key (Just file) tmp)
( return True ( return True
, ifM (Annex.getState Annex.fast) , ifM (Annex.getState Annex.fast)
( return False ( return False
, Remote.retrieveKeyFile remote key Nothing tmp dummymeter , Remote.retrieveKeyFile remote key (Just file) tmp dummymeter
) )
) )
dummymeter _ = noop dummymeter _ = noop

View file

@ -171,7 +171,7 @@ testUnavailable st r k =
Remote.retrieveKeyFile r k Nothing dest nullMeterUpdate Remote.retrieveKeyFile r k Nothing dest nullMeterUpdate
, check (== Right False) "retrieveKeyFileCheap" $ , check (== Right False) "retrieveKeyFileCheap" $
getViaTmp k $ \dest -> getViaTmp k $ \dest ->
Remote.retrieveKeyFileCheap r k dest Remote.retrieveKeyFileCheap r k Nothing dest
] ]
where where
check checkval desc a = testCase desc $ do check checkval desc a = testCase desc $ do

View file

@ -20,40 +20,38 @@ import Control.Concurrent
{- Shows a progress meter while performing a transfer of a key. {- Shows a progress meter while performing a transfer of a key.
- The action is passed a callback to use to update the meter. -} - The action is passed a callback to use to update the meter. -}
metered :: Maybe MeterUpdate -> Key -> (MeterUpdate -> Annex a) -> Annex a metered :: Maybe MeterUpdate -> Key -> AssociatedFile -> (MeterUpdate -> Annex a) -> Annex a
metered combinemeterupdate key a = go (keySize key) metered combinemeterupdate key af a = case keySize key of
Nothing -> nometer
Just size -> withOutputType (go $ fromInteger size)
where where
go (Just size) = meteredBytes combinemeterupdate size a go _ QuietOutput = nometer
go _ = a (const noop) go _ JSONOutput = nometer
go size _ = do
{- Use when the progress meter is only desired for parallel
- mode; as when a command's own progress output is preferred. -}
parallelMetered :: Maybe MeterUpdate -> Key -> (MeterUpdate -> Annex a) -> Annex a
parallelMetered combinemeterupdate key a = withOutputType go
where
go (ParallelOutput _) = metered combinemeterupdate key a
go _ = a (fromMaybe (const noop) combinemeterupdate)
{- Shows a progress meter while performing an action on a given number
- of bytes. -}
meteredBytes :: Maybe MeterUpdate -> Integer -> (MeterUpdate -> Annex a) -> Annex a
meteredBytes combinemeterupdate size a = withOutputType go
where
go QuietOutput = nometer
go JSONOutput = nometer
go _ = do
showOutput showOutput
liftIO $ putStrLn "" liftIO $ putStrLn ""
let desc = truncatepretty 79 $ fromMaybe (key2file key) af
result <- liftIO newEmptyMVar
pg <- liftIO $ newProgressBar def pg <- liftIO $ newProgressBar def
{ pgWidth = 79 { pgWidth = 79
, pgFormat = ":percent :bar ETA :eta" , pgFormat = desc ++ " :percent :bar ETA :eta"
, pgTotal = fromInteger size , pgTotal = size
, pgOnCompletion = do
ok <- takeMVar result
putStrLn $ desc ++ " " ++
if ok then "ok" else "failed"
} }
r <- a $ liftIO . pupdate pg r <- a $ liftIO . pupdate pg
-- may not be actually complete if the action failed, liftIO $ do
-- but this just clears the progress bar -- See if the progress bar is complete or not.
liftIO $ complete pg sofar <- stCompleted <$> getProgressStats pg
putMVar result (sofar >= size)
-- May not be actually complete if the action failed,
-- but this just clears the progress bar.
complete pg
return r return r
@ -67,6 +65,18 @@ meteredBytes combinemeterupdate size a = withOutputType go
nometer = a (const noop) nometer = a (const noop)
truncatepretty n s
| length s > n = take (n-2) s ++ ".."
| otherwise = s
{- Use when the progress meter is only desired for parallel
- mode; as when a command's own progress output is preferred. -}
parallelMetered :: Maybe MeterUpdate -> Key -> AssociatedFile -> (MeterUpdate -> Annex a) -> Annex a
parallelMetered combinemeterupdate key af a = withOutputType go
where
go (ParallelOutput _) = metered combinemeterupdate key af a
go _ = a (fromMaybe (const noop) combinemeterupdate)
{- Progress dots. -} {- Progress dots. -}
showProgressDots :: Annex () showProgressDots :: Annex ()
showProgressDots = handleMessage q $ showProgressDots = handleMessage q $

View file

@ -93,8 +93,8 @@ downloadKey key _file dest p =
, return False , return False
) )
downloadKeyCheap :: Key -> FilePath -> Annex Bool downloadKeyCheap :: Key -> AssociatedFile -> FilePath -> Annex Bool
downloadKeyCheap _ _ = return False downloadKeyCheap _ _ _ = return False
uploadKey :: Key -> AssociatedFile -> MeterUpdate -> Annex Bool uploadKey :: Key -> AssociatedFile -> MeterUpdate -> Annex Bool
uploadKey _ _ _ = do uploadKey _ _ _ = do

View file

@ -148,8 +148,8 @@ retrieve buprepo = byteRetriever $ \k sink -> do
liftIO (hClose h >> forceSuccessProcess p pid) liftIO (hClose h >> forceSuccessProcess p pid)
`after` (sink =<< liftIO (L.hGetContents h)) `after` (sink =<< liftIO (L.hGetContents h))
retrieveCheap :: BupRepo -> Key -> FilePath -> Annex Bool retrieveCheap :: BupRepo -> Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ _ = return False retrieveCheap _ _ _ _ = return False
{- Cannot revert having stored a key in bup, but at least the data for the {- Cannot revert having stored a key in bup, but at least the data for the
- key will be used for deltaing data of other keys stored later. - key will be used for deltaing data of other keys stored later.

View file

@ -142,8 +142,8 @@ retrieve ddarrepo = byteRetriever $ \k sink -> do
liftIO (hClose h >> forceSuccessProcess p pid) liftIO (hClose h >> forceSuccessProcess p pid)
`after` (sink =<< liftIO (L.hGetContents h)) `after` (sink =<< liftIO (L.hGetContents h))
retrieveCheap :: Key -> FilePath -> Annex Bool retrieveCheap :: Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ = return False retrieveCheap _ _ _ = return False
remove :: DdarRepo -> Remover remove :: DdarRepo -> Remover
remove ddarrepo key = do remove ddarrepo key = do

View file

@ -156,17 +156,17 @@ retrieve d (LegacyChunks _) = Legacy.retrieve locations d
retrieve d _ = simplyPrepare $ byteRetriever $ \k sink -> retrieve d _ = simplyPrepare $ byteRetriever $ \k sink ->
sink =<< liftIO (L.readFile =<< getLocation d k) sink =<< liftIO (L.readFile =<< getLocation d k)
retrieveCheap :: FilePath -> ChunkConfig -> Key -> FilePath -> Annex Bool retrieveCheap :: FilePath -> ChunkConfig -> Key -> AssociatedFile -> FilePath -> Annex Bool
-- no cheap retrieval possible for chunks -- no cheap retrieval possible for chunks
retrieveCheap _ (UnpaddedChunks _) _ _ = return False retrieveCheap _ (UnpaddedChunks _) _ _ _ = return False
retrieveCheap _ (LegacyChunks _) _ _ = return False retrieveCheap _ (LegacyChunks _) _ _ _ = return False
#ifndef mingw32_HOST_OS #ifndef mingw32_HOST_OS
retrieveCheap d NoChunks k f = liftIO $ catchBoolIO $ do retrieveCheap d NoChunks k _af f = liftIO $ catchBoolIO $ do
file <- getLocation d k file <- getLocation d k
createSymbolicLink file f createSymbolicLink file f
return True return True
#else #else
retrieveCheap _ _ _ _ = return False retrieveCheap _ _ _ _ _ = return False
#endif #endif
remove :: FilePath -> Remover remove :: FilePath -> Remover

View file

@ -56,7 +56,7 @@ gen r u c gc = do
, name = Git.repoDescribe r , name = Git.repoDescribe r
, storeKey = storeKeyDummy , storeKey = storeKeyDummy
, retrieveKeyFile = retreiveKeyFileDummy , retrieveKeyFile = retreiveKeyFileDummy
, retrieveKeyFileCheap = \_ _ -> return False , retrieveKeyFileCheap = \_ _ _ -> return False
, removeKey = removeKeyDummy , removeKey = removeKeyDummy
, checkPresent = checkPresentDummy , checkPresent = checkPresentDummy
, checkPresentCheap = False , checkPresentCheap = False

View file

@ -108,7 +108,7 @@ gen' r u c gc = do
, name = Git.repoDescribe r , name = Git.repoDescribe r
, storeKey = storeKeyDummy , storeKey = storeKeyDummy
, retrieveKeyFile = retreiveKeyFileDummy , retrieveKeyFile = retreiveKeyFileDummy
, retrieveKeyFileCheap = \_ _ -> return False , retrieveKeyFileCheap = \_ _ _ -> return False
, removeKey = removeKeyDummy , removeKey = removeKeyDummy
, checkPresent = checkPresentDummy , checkPresent = checkPresentDummy
, checkPresentCheap = repoCheap r , checkPresentCheap = repoCheap r

View file

@ -355,7 +355,7 @@ dropKey r key
{- Tries to copy a key's content from a remote's annex to a file. -} {- Tries to copy a key's content from a remote's annex to a file. -}
copyFromRemote :: Remote -> Key -> AssociatedFile -> FilePath -> MeterUpdate -> Annex Bool copyFromRemote :: Remote -> Key -> AssociatedFile -> FilePath -> MeterUpdate -> Annex Bool
copyFromRemote r key file dest p = parallelMetered (Just p) key $ copyFromRemote r key file dest p = parallelMetered (Just p) key file $
copyFromRemote' r key file dest copyFromRemote' r key file dest
copyFromRemote' :: Remote -> Key -> AssociatedFile -> FilePath -> MeterUpdate -> Annex Bool copyFromRemote' :: Remote -> Key -> AssociatedFile -> FilePath -> MeterUpdate -> Annex Bool
@ -447,26 +447,27 @@ copyFromRemote' r key file dest meterupdate
=<< tryTakeMVar pidv =<< tryTakeMVar pidv
bracketIO noop (const cleanup) (const $ a feeder) bracketIO noop (const cleanup) (const $ a feeder)
copyFromRemoteCheap :: Remote -> Key -> FilePath -> Annex Bool copyFromRemoteCheap :: Remote -> Key -> AssociatedFile -> FilePath -> Annex Bool
#ifndef mingw32_HOST_OS #ifndef mingw32_HOST_OS
copyFromRemoteCheap r key file copyFromRemoteCheap r key af file
| not $ Git.repoIsUrl (repo r) = guardUsable (repo r) (return False) $ do | not $ Git.repoIsUrl (repo r) = guardUsable (repo r) (return False) $ do
loc <- liftIO $ gitAnnexLocation key (repo r) $ loc <- liftIO $ gitAnnexLocation key (repo r) $
fromJust $ remoteGitConfig $ gitconfig r fromJust $ remoteGitConfig $ gitconfig r
liftIO $ catchBoolIO $ createSymbolicLink loc file >> return True liftIO $ catchBoolIO $ createSymbolicLink loc file >> return True
| Git.repoIsSsh (repo r) = | Git.repoIsSsh (repo r) =
ifM (Annex.Content.preseedTmp key file) ifM (Annex.Content.preseedTmp key file)
( parallelMetered Nothing key $ copyFromRemote' r key Nothing file ( parallelMetered Nothing key af $
copyFromRemote' r key af file
, return False , return False
) )
| otherwise = return False | otherwise = return False
#else #else
copyFromRemoteCheap _ _ _ = return False copyFromRemoteCheap _ _ _ _ = return False
#endif #endif
{- Tries to copy a key's content to a remote's annex. -} {- Tries to copy a key's content to a remote's annex. -}
copyToRemote :: Remote -> Key -> AssociatedFile -> MeterUpdate -> Annex Bool copyToRemote :: Remote -> Key -> AssociatedFile -> MeterUpdate -> Annex Bool
copyToRemote r key file p = parallelMetered (Just p) key $ copyToRemote' r key file copyToRemote r key file p = parallelMetered (Just p) key file $ copyToRemote' r key file
copyToRemote' :: Remote -> Key -> AssociatedFile -> MeterUpdate -> Annex Bool copyToRemote' :: Remote -> Key -> AssociatedFile -> MeterUpdate -> Annex Bool
copyToRemote' r key file p copyToRemote' r key file p

View file

@ -162,8 +162,8 @@ retrieve r k sink = go =<< glacierEnv c u
showLongNote "Recommend you wait up to 4 hours, and then run this command again." showLongNote "Recommend you wait up to 4 hours, and then run this command again."
return ok return ok
retrieveCheap :: Remote -> Key -> FilePath -> Annex Bool retrieveCheap :: Remote -> Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ _ = return False retrieveCheap _ _ _ _ = return False
remove :: Remote -> Remover remove :: Remote -> Remover
remove r k = glacierAction r remove r k = glacierAction r

View file

@ -36,7 +36,7 @@ addHooks' r starthook stophook = r'
r' = r r' = r
{ storeKey = \k f p -> wrapper $ storeKey r k f p { storeKey = \k f p -> wrapper $ storeKey r k f p
, retrieveKeyFile = \k f d p -> wrapper $ retrieveKeyFile r k f d p , retrieveKeyFile = \k f d p -> wrapper $ retrieveKeyFile r k f d p
, retrieveKeyFileCheap = \k f -> wrapper $ retrieveKeyFileCheap r k f , retrieveKeyFileCheap = \k af f -> wrapper $ retrieveKeyFileCheap r k af f
, removeKey = wrapper . removeKey r , removeKey = wrapper . removeKey r
, checkPresent = wrapper . checkPresent r , checkPresent = wrapper . checkPresent r
} }

View file

@ -157,10 +157,10 @@ specialRemote' :: SpecialRemoteCfg -> RemoteModifier
specialRemote' cfg c preparestorer prepareretriever prepareremover preparecheckpresent baser = encr specialRemote' cfg c preparestorer prepareretriever prepareremover preparecheckpresent baser = encr
where where
encr = baser encr = baser
{ storeKey = \k _f p -> cip >>= storeKeyGen k p { storeKey = \k f p -> cip >>= storeKeyGen k f p
, retrieveKeyFile = \k _f d p -> cip >>= retrieveKeyFileGen k d p , retrieveKeyFile = \k f d p -> cip >>= retrieveKeyFileGen k f d p
, retrieveKeyFileCheap = \k d -> cip >>= maybe , retrieveKeyFileCheap = \k f d -> cip >>= maybe
(retrieveKeyFileCheap baser k d) (retrieveKeyFileCheap baser k f d)
-- retrieval of encrypted keys is never cheap -- retrieval of encrypted keys is never cheap
(\_ -> return False) (\_ -> return False)
, removeKey = \k -> cip >>= removeKeyGen k , removeKey = \k -> cip >>= removeKeyGen k
@ -182,10 +182,10 @@ specialRemote' cfg c preparestorer prepareretriever prepareremover preparecheckp
safely a = catchNonAsync a (\e -> warning (show e) >> return False) safely a = catchNonAsync a (\e -> warning (show e) >> return False)
-- chunk, then encrypt, then feed to the storer -- chunk, then encrypt, then feed to the storer
storeKeyGen k p enc = safely $ preparestorer k $ safely . go storeKeyGen k f p enc = safely $ preparestorer k $ safely . go
where where
go (Just storer) = sendAnnex k rollback $ \src -> go (Just storer) = sendAnnex k rollback $ \src ->
displayprogress p k $ \p' -> displayprogress p k f $ \p' ->
storeChunks (uuid baser) chunkconfig k src p' storeChunks (uuid baser) chunkconfig k src p'
(storechunk enc storer) (storechunk enc storer)
(checkPresent baser) (checkPresent baser)
@ -200,10 +200,10 @@ specialRemote' cfg c preparestorer prepareretriever prepareremover preparecheckp
storer (enck k) (ByteContent encb) p storer (enck k) (ByteContent encb) p
-- call retrieve-r to get chunks; decrypt them; stream to dest file -- call retrieve-r to get chunks; decrypt them; stream to dest file
retrieveKeyFileGen k dest p enc = retrieveKeyFileGen k f dest p enc =
safely $ prepareretriever k $ safely . go safely $ prepareretriever k $ safely . go
where where
go (Just retriever) = displayprogress p k $ \p' -> go (Just retriever) = displayprogress p k f $ \p' ->
retrieveChunks retriever (uuid baser) chunkconfig retrieveChunks retriever (uuid baser) chunkconfig
enck k dest p' (sink dest enc) enck k dest p' (sink dest enc)
go Nothing = return False go Nothing = return False
@ -223,8 +223,8 @@ specialRemote' cfg c preparestorer prepareretriever prepareremover preparecheckp
chunkconfig = chunkConfig cfg chunkconfig = chunkConfig cfg
displayprogress p k a displayprogress p k f a
| displayProgress cfg = metered (Just p) k a | displayProgress cfg = metered (Just p) k f a
| otherwise = a p | otherwise = a p
{- Sink callback for retrieveChunks. Stores the file content into the {- Sink callback for retrieveChunks. Stores the file content into the

View file

@ -130,8 +130,8 @@ retrieve h = fileRetriever $ \d k _p ->
unlessM (runHook h "retrieve" k (Just d) $ return True) $ unlessM (runHook h "retrieve" k (Just d) $ return True) $
error "failed to retrieve content" error "failed to retrieve content"
retrieveCheap :: HookName -> Key -> FilePath -> Annex Bool retrieveCheap :: HookName -> Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ _ = return False retrieveCheap _ _ _ _ = return False
remove :: HookName -> Remover remove :: HookName -> Remover
remove h k = runHook h "remove" k Nothing $ return True remove h k = runHook h "remove" k Nothing $ return True

View file

@ -191,8 +191,8 @@ retrieve o f k p =
unlessM (rsyncRetrieve o k f (Just p)) $ unlessM (rsyncRetrieve o k f (Just p)) $
error "rsync failed" error "rsync failed"
retrieveCheap :: RsyncOpts -> Key -> FilePath -> Annex Bool retrieveCheap :: RsyncOpts -> Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap o k f = ifM (preseedTmp k f) ( rsyncRetrieve o k f Nothing , return False ) retrieveCheap o k _af f = ifM (preseedTmp k f) ( rsyncRetrieve o k f Nothing , return False )
remove :: RsyncOpts -> Remover remove :: RsyncOpts -> Remover
remove o k = do remove o k = do

View file

@ -241,8 +241,8 @@ retrieve h = fileRetriever $ \f k p -> liftIO $ runResourceT $ do
S.hPut fh bs S.hPut fh bs
sinkprogressfile fh meterupdate sofar' sinkprogressfile fh meterupdate sofar'
retrieveCheap :: Key -> FilePath -> Annex Bool retrieveCheap :: Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ = return False retrieveCheap _ _ _ = return False
{- Internet Archive doesn't easily allow removing content. {- Internet Archive doesn't easily allow removing content.
- While it may remove the file, there are generally other files - While it may remove the file, there are generally other files

View file

@ -70,7 +70,7 @@ gen r u c gc = do
, name = Git.repoDescribe r , name = Git.repoDescribe r
, storeKey = store u hdl , storeKey = store u hdl
, retrieveKeyFile = retrieve u hdl , retrieveKeyFile = retrieve u hdl
, retrieveKeyFileCheap = \_ _ -> return False , retrieveKeyFileCheap = \_ _ _ -> return False
, removeKey = remove , removeKey = remove
, checkPresent = checkKey u hdl , checkPresent = checkKey u hdl
, checkPresentCheap = False , checkPresentCheap = False

View file

@ -90,8 +90,8 @@ downloadKey key _file dest _p = get =<< getWebUrls key
#endif #endif
_ -> downloadUrl [u'] dest _ -> downloadUrl [u'] dest
downloadKeyCheap :: Key -> FilePath -> Annex Bool downloadKeyCheap :: Key -> AssociatedFile -> FilePath -> Annex Bool
downloadKeyCheap _ _ = return False downloadKeyCheap _ _ _ = return False
uploadKey :: Key -> AssociatedFile -> MeterUpdate -> Annex Bool uploadKey :: Key -> AssociatedFile -> MeterUpdate -> Annex Bool
uploadKey _ _ _ = do uploadKey _ _ _ = do

View file

@ -116,8 +116,8 @@ finalizeStore baseurl tmp dest = do
maybe noop (void . mkColRecursive) (locationParent dest) maybe noop (void . mkColRecursive) (locationParent dest)
moveDAV baseurl tmp dest moveDAV baseurl tmp dest
retrieveCheap :: Key -> FilePath -> Annex Bool retrieveCheap :: Key -> AssociatedFile -> FilePath -> Annex Bool
retrieveCheap _ _ = return False retrieveCheap _ _ _ = return False
retrieve :: ChunkConfig -> Maybe DavHandle -> Retriever retrieve :: ChunkConfig -> Maybe DavHandle -> Retriever
retrieve _ Nothing = error "unable to connect" retrieve _ Nothing = error "unable to connect"

View file

@ -67,7 +67,7 @@ data RemoteA a = Remote {
-- directly to the file, and not to an intermediate file.) -- directly to the file, and not to an intermediate file.)
retrieveKeyFile :: Key -> AssociatedFile -> FilePath -> MeterUpdate -> a Bool, retrieveKeyFile :: Key -> AssociatedFile -> FilePath -> MeterUpdate -> a Bool,
-- retrieves a key's contents to a tmp file, if it can be done cheaply -- retrieves a key's contents to a tmp file, if it can be done cheaply
retrieveKeyFileCheap :: Key -> FilePath -> a Bool, retrieveKeyFileCheap :: Key -> AssociatedFile -> FilePath -> a Bool,
-- removes a key's contents (succeeds if the contents are not present) -- removes a key's contents (succeeds if the contents are not present)
removeKey :: Key -> a Bool, removeKey :: Key -> a Bool,
-- Checks if a key is present in the remote. -- Checks if a key is present in the remote.