clean up remote list generation to only run once
This commit is contained in:
parent
f30320aa75
commit
3470260a85
1 changed files with 14 additions and 7 deletions
19
Remote.hs
19
Remote.hs
|
@ -6,7 +6,6 @@
|
|||
-}
|
||||
|
||||
module Remote (
|
||||
generate,
|
||||
keyPossibilities,
|
||||
remotesWithUUID,
|
||||
remotesWithoutUUID
|
||||
|
@ -27,11 +26,19 @@ import LocationLog
|
|||
generators :: [Annex [Remote Annex]]
|
||||
generators = [Remote.GitRemote.generate]
|
||||
|
||||
{- generates a list of all available Remotes -}
|
||||
generate :: Annex [Remote Annex]
|
||||
generate = do
|
||||
{- Builds a list of all available Remotes.
|
||||
- Since doing so can be expensive, the list is cached in the Annex. -}
|
||||
genList :: Annex [Remote Annex]
|
||||
genList = do
|
||||
liftIO $ putStrLn "Remote.genList"
|
||||
rs <- Annex.getState Annex.remotes
|
||||
if null rs
|
||||
then do
|
||||
lists <- sequence generators
|
||||
return $ concat lists
|
||||
let rs' = concat lists
|
||||
Annex.changeState $ \s -> s { Annex.remotes = rs' }
|
||||
return rs'
|
||||
else return rs
|
||||
|
||||
{- Filters a list of remotes to ones that have the listed uuids. -}
|
||||
remotesWithUUID :: [Remote Annex] -> [UUID] -> [Remote Annex]
|
||||
|
@ -60,7 +67,7 @@ keyPossibilities key = do
|
|||
let validtrusteduuids = intersect validuuids trusted
|
||||
|
||||
-- remotes that match uuids that have the key
|
||||
allremotes <- generate
|
||||
allremotes <- genList
|
||||
let validremotes = remotesWithUUID allremotes validuuids
|
||||
|
||||
return (sort validremotes, validtrusteduuids)
|
||||
|
|
Loading…
Reference in a new issue