fsck -q: When a file has bad content, include the name of the file in the warning message.
This commit was sponsored by Alexander Thompson on Patreon.
This commit is contained in:
parent
bcab98d299
commit
301aff34c4
2 changed files with 40 additions and 33 deletions
|
@ -9,6 +9,8 @@ git-annex (6.20170301.2) UNRELEASED; urgency=medium
|
||||||
in the full transfer scan, to avoid using too much CPU.
|
in the full transfer scan, to avoid using too much CPU.
|
||||||
* get -J: Improve distribution of jobs amoung remotes when there are more
|
* get -J: Improve distribution of jobs amoung remotes when there are more
|
||||||
jobs than remotes.
|
jobs than remotes.
|
||||||
|
* fsck -q: When a file has bad content, include the name of the file
|
||||||
|
in the warning message.
|
||||||
|
|
||||||
-- Joey Hess <id@joeyh.name> Thu, 02 Mar 2017 12:51:40 -0400
|
-- Joey Hess <id@joeyh.name> Thu, 02 Mar 2017 12:51:40 -0400
|
||||||
|
|
||||||
|
|
|
@ -123,7 +123,7 @@ perform key file backend numcopies = do
|
||||||
, verifyLocationLog key keystatus file
|
, verifyLocationLog key keystatus file
|
||||||
, verifyAssociatedFiles key keystatus file
|
, verifyAssociatedFiles key keystatus file
|
||||||
, verifyWorkTree key file
|
, verifyWorkTree key file
|
||||||
, checkKeySize key keystatus
|
, checkKeySize key keystatus (Just file)
|
||||||
, checkBackend backend key keystatus (Just file)
|
, checkBackend backend key keystatus (Just file)
|
||||||
, checkKeyNumCopies key (Just file) numcopies
|
, checkKeyNumCopies key (Just file) numcopies
|
||||||
]
|
]
|
||||||
|
@ -149,8 +149,8 @@ performRemote key afile backend numcopies remote =
|
||||||
dispatch (Right False) = go False Nothing
|
dispatch (Right False) = go False Nothing
|
||||||
go present localcopy = check
|
go present localcopy = check
|
||||||
[ verifyLocationLogRemote key (maybe (key2file key) id afile) remote present
|
[ verifyLocationLogRemote key (maybe (key2file key) id afile) remote present
|
||||||
, checkKeySizeRemote key remote localcopy
|
, checkKeySizeRemote key remote localcopy afile
|
||||||
, checkBackendRemote backend key remote localcopy
|
, checkBackendRemote backend key remote localcopy afile
|
||||||
, checkKeyNumCopies key afile numcopies
|
, checkKeyNumCopies key afile numcopies
|
||||||
]
|
]
|
||||||
withtmp a = do
|
withtmp a = do
|
||||||
|
@ -188,7 +188,7 @@ performKey key backend numcopies = do
|
||||||
keystatus <- getKeyStatus key
|
keystatus <- getKeyStatus key
|
||||||
check
|
check
|
||||||
[ verifyLocationLog key keystatus (key2file key)
|
[ verifyLocationLog key keystatus (key2file key)
|
||||||
, checkKeySize key keystatus
|
, checkKeySize key keystatus Nothing
|
||||||
, checkBackend backend key keystatus Nothing
|
, checkBackend backend key keystatus Nothing
|
||||||
, checkKeyNumCopies key Nothing numcopies
|
, checkKeyNumCopies key Nothing numcopies
|
||||||
]
|
]
|
||||||
|
@ -338,22 +338,22 @@ verifyWorkTree key file = do
|
||||||
-
|
-
|
||||||
- Not checked when a file is unlocked, or in direct mode.
|
- Not checked when a file is unlocked, or in direct mode.
|
||||||
-}
|
-}
|
||||||
checkKeySize :: Key -> KeyStatus -> Annex Bool
|
checkKeySize :: Key -> KeyStatus -> AssociatedFile -> Annex Bool
|
||||||
checkKeySize _ KeyUnlocked = return True
|
checkKeySize _ KeyUnlocked _ = return True
|
||||||
checkKeySize key _ = do
|
checkKeySize key _ afile = do
|
||||||
file <- calcRepo $ gitAnnexLocation key
|
file <- calcRepo $ gitAnnexLocation key
|
||||||
ifM (liftIO $ doesFileExist file)
|
ifM (liftIO $ doesFileExist file)
|
||||||
( checkKeySizeOr badContent key file
|
( checkKeySizeOr badContent key file afile
|
||||||
, return True
|
, return True
|
||||||
)
|
)
|
||||||
|
|
||||||
checkKeySizeRemote :: Key -> Remote -> Maybe FilePath -> Annex Bool
|
checkKeySizeRemote :: Key -> Remote -> Maybe FilePath -> AssociatedFile -> Annex Bool
|
||||||
checkKeySizeRemote _ _ Nothing = return True
|
checkKeySizeRemote _ _ Nothing _ = return True
|
||||||
checkKeySizeRemote key remote (Just file) =
|
checkKeySizeRemote key remote (Just file) afile =
|
||||||
checkKeySizeOr (badContentRemote remote file) key file
|
checkKeySizeOr (badContentRemote remote file) key file afile
|
||||||
|
|
||||||
checkKeySizeOr :: (Key -> Annex String) -> Key -> FilePath -> Annex Bool
|
checkKeySizeOr :: (Key -> Annex String) -> Key -> FilePath -> AssociatedFile -> Annex Bool
|
||||||
checkKeySizeOr bad key file = case keySize key of
|
checkKeySizeOr bad key file afile = case keySize key of
|
||||||
Nothing -> return True
|
Nothing -> return True
|
||||||
Just size -> do
|
Just size -> do
|
||||||
size' <- liftIO $ getFileSize file
|
size' <- liftIO $ getFileSize file
|
||||||
|
@ -365,11 +365,12 @@ checkKeySizeOr bad key file = case keySize key of
|
||||||
return same
|
return same
|
||||||
badsize a b = do
|
badsize a b = do
|
||||||
msg <- bad key
|
msg <- bad key
|
||||||
warning $ concat
|
warning $ concat $ catMaybes
|
||||||
[ "Bad file size ("
|
[ afile <> Just ": "
|
||||||
, compareSizes storageUnits True a b
|
, Just "Bad file size ("
|
||||||
, "); "
|
, Just $ compareSizes storageUnits True a b
|
||||||
, msg
|
, Just "); "
|
||||||
|
, Just msg
|
||||||
]
|
]
|
||||||
|
|
||||||
{- Runs the backend specific check on a key's content object.
|
{- Runs the backend specific check on a key's content object.
|
||||||
|
@ -383,37 +384,37 @@ checkKeySizeOr bad key file = case keySize key of
|
||||||
- because modification of direct mode files is allowed. It's still done
|
- because modification of direct mode files is allowed. It's still done
|
||||||
- if the file does not appear modified, to catch disk corruption, etc.
|
- if the file does not appear modified, to catch disk corruption, etc.
|
||||||
-}
|
-}
|
||||||
checkBackend :: Backend -> Key -> KeyStatus -> Maybe FilePath -> Annex Bool
|
checkBackend :: Backend -> Key -> KeyStatus -> AssociatedFile -> Annex Bool
|
||||||
checkBackend backend key keystatus mfile = go =<< isDirect
|
checkBackend backend key keystatus afile = go =<< isDirect
|
||||||
where
|
where
|
||||||
go False = do
|
go False = do
|
||||||
content <- calcRepo $ gitAnnexLocation key
|
content <- calcRepo $ gitAnnexLocation key
|
||||||
ifM (pure (isKeyUnlocked keystatus) <&&> (not <$> isUnmodified key content))
|
ifM (pure (isKeyUnlocked keystatus) <&&> (not <$> isUnmodified key content))
|
||||||
( nocheck
|
( nocheck
|
||||||
, checkBackendOr badContent backend key content
|
, checkBackendOr badContent backend key content afile
|
||||||
)
|
)
|
||||||
go True = maybe nocheck checkdirect mfile
|
go True = maybe nocheck checkdirect afile
|
||||||
checkdirect file = ifM (Direct.goodContent key file)
|
checkdirect file = ifM (Direct.goodContent key file)
|
||||||
( checkBackendOr' (badContentDirect file) backend key file
|
( checkBackendOr' (badContentDirect file) backend key file afile
|
||||||
(Direct.goodContent key file)
|
(Direct.goodContent key file)
|
||||||
, nocheck
|
, nocheck
|
||||||
)
|
)
|
||||||
nocheck = return True
|
nocheck = return True
|
||||||
|
|
||||||
checkBackendRemote :: Backend -> Key -> Remote -> Maybe FilePath -> Annex Bool
|
checkBackendRemote :: Backend -> Key -> Remote -> Maybe FilePath -> AssociatedFile -> Annex Bool
|
||||||
checkBackendRemote backend key remote = maybe (return True) go
|
checkBackendRemote backend key remote afile = maybe (return True) go
|
||||||
where
|
where
|
||||||
go file = checkBackendOr (badContentRemote remote file) backend key file
|
go file = checkBackendOr (badContentRemote remote file) backend key file afile
|
||||||
|
|
||||||
checkBackendOr :: (Key -> Annex String) -> Backend -> Key -> FilePath -> Annex Bool
|
checkBackendOr :: (Key -> Annex String) -> Backend -> Key -> FilePath -> AssociatedFile -> Annex Bool
|
||||||
checkBackendOr bad backend key file =
|
checkBackendOr bad backend key file afile =
|
||||||
checkBackendOr' bad backend key file (return True)
|
checkBackendOr' bad backend key file afile (return True)
|
||||||
|
|
||||||
-- The postcheck action is run after the content is verified,
|
-- The postcheck action is run after the content is verified,
|
||||||
-- in order to detect situations where the file is changed while being
|
-- in order to detect situations where the file is changed while being
|
||||||
-- verified (particularly in direct mode).
|
-- verified (particularly in direct mode).
|
||||||
checkBackendOr' :: (Key -> Annex String) -> Backend -> Key -> FilePath -> Annex Bool -> Annex Bool
|
checkBackendOr' :: (Key -> Annex String) -> Backend -> Key -> FilePath -> AssociatedFile -> Annex Bool -> Annex Bool
|
||||||
checkBackendOr' bad backend key file postcheck =
|
checkBackendOr' bad backend key file afile postcheck =
|
||||||
case Types.Backend.verifyKeyContent backend of
|
case Types.Backend.verifyKeyContent backend of
|
||||||
Nothing -> return True
|
Nothing -> return True
|
||||||
Just verifier -> do
|
Just verifier -> do
|
||||||
|
@ -422,7 +423,11 @@ checkBackendOr' bad backend key file postcheck =
|
||||||
( do
|
( do
|
||||||
unless ok $ do
|
unless ok $ do
|
||||||
msg <- bad key
|
msg <- bad key
|
||||||
warning $ "Bad file content; " ++ msg
|
warning $ concat $ catMaybes
|
||||||
|
[ afile <> Just ": "
|
||||||
|
, Just "Bad file content; "
|
||||||
|
, Just msg
|
||||||
|
]
|
||||||
return ok
|
return ok
|
||||||
, return True
|
, return True
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue