summaryrefslogtreecommitdiff
path: root/Backend
diff options
context:
space:
mode:
Diffstat (limited to 'Backend')
-rw-r--r--Backend/File.hs22
1 files changed, 15 insertions, 7 deletions
diff --git a/Backend/File.hs b/Backend/File.hs
index 8c39c3f80..ab14b8233 100644
--- a/Backend/File.hs
+++ b/Backend/File.hs
@@ -96,9 +96,10 @@ checkRemoveKey key numcopiesM = do
then return True
else do
(remotes, trusteduuids) <- Remotes.keyPossibilities key
- untrusted <- reposWithoutUUID remotes trusteduuids
+ untrusteduuids <- trustGet UnTrusted
+ tocheck <- reposWithoutUUID remotes (trusteduuids++untrusteduuids)
numcopies <- getNumCopies numcopiesM
- findcopies numcopies trusteduuids untrusted []
+ findcopies numcopies trusteduuids tocheck []
where
findcopies need have [] bad
| length have >= need = return True
@@ -131,11 +132,18 @@ showLocations key exclude = do
g <- Annex.gitRepo
u <- getUUID g
uuids <- liftIO $ keyLocations g key
- let uuidsf = filter (\l -> l /= u && (not $ elem l exclude)) uuids
- ppuuids <- prettyPrintUUIDs uuidsf
- if null uuidsf
- then showLongNote $ "No other repository is known to contain the file."
- else showLongNote $ "Try making some of these repositories available:\n" ++ ppuuids
+ untrusteduuids <- trustGet UnTrusted
+ let uuidswanted = filteruuids uuids (u:exclude++untrusteduuids)
+ let uuidsskipped = filteruuids uuids (u:exclude++uuidswanted)
+ ppuuidswanted <- prettyPrintUUIDs uuidswanted
+ ppuuidsskipped <- prettyPrintUUIDs uuidsskipped
+ showLongNote $ message ppuuidswanted ppuuidsskipped
+ where
+ filteruuids list x = filter (\l -> not $ elem l x) list
+ message [] [] = "No other repository is known to contain the file."
+ message rs [] = "Try making some of these repositories available:\n" ++ rs
+ message [] us = "Also these untrusted repositories may contain the file:\n" ++ us
+ message rs us = message rs [] ++ message [] us
showTriedRemotes :: [Git.Repo] -> Annex ()
showTriedRemotes [] = return ()