summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Command/Fsck.hs20
-rw-r--r--doc/git-annex.mdwn4
-rw-r--r--doc/walkthrough.mdwn12
3 files changed, 20 insertions, 16 deletions
diff --git a/Command/Fsck.hs b/Command/Fsck.hs
index a72d753fa..07621ad4e 100644
--- a/Command/Fsck.hs
+++ b/Command/Fsck.hs
@@ -8,8 +8,22 @@
module Command.Fsck where
import Command
-import qualified Command.FsckFile
-import qualified Command.Unused
+import qualified Backend
+import Types
+import Messages
seek :: [SubCmdSeek]
-seek = [withNothing Command.Unused.start, withAll withFilesInGit Command.FsckFile.start]
+seek = [withFilesInGit start]
+
+{- Checks a file's backend data for problems. -}
+start :: SubCmdStartString
+start file = isAnnexed file $ \(key, backend) -> do
+ showStart "fsck" file
+ return $ Just $ perform key backend
+
+perform :: Key -> Backend -> SubCmdPerform
+perform key backend = do
+ success <- Backend.fsckKey backend key
+ if (success)
+ then return $ Just $ return True
+ else return Nothing
diff --git a/doc/git-annex.mdwn b/doc/git-annex.mdwn
index 42f80a3dc..3df835eac 100644
--- a/doc/git-annex.mdwn
+++ b/doc/git-annex.mdwn
@@ -124,12 +124,10 @@ Many git-annex subcommands will stage changes for later `git commit` by you.
Checks the annex for data that is not used by any files currently
in the annex, and prints a numbered list of the data.
- (This is run as part of `git annex fsck`.)
-
* dropunused [number ...]
Drops the data corresponding to the numbers, as listed by the last
- `git annex unused` or `git annex fsck`
+ `git annex unused`
* find [path ...]
diff --git a/doc/walkthrough.mdwn b/doc/walkthrough.mdwn
index b6f322c49..a1a888242 100644
--- a/doc/walkthrough.mdwn
+++ b/doc/walkthrough.mdwn
@@ -311,8 +311,7 @@ You can use the fsck subcommand to check for problems in your data.
What can be checked depends on the [[backend|backends]] you've used to store
the data. For example, when you use the SHA1 backend, fsck will verify that
the checksums of your files are good. Fsck also checks that the annex.numcopies
-setting is satisfied for all files, and it warns about any dangling values
-in `.git/annex/objects/`.
+setting is satisfied for all files.
# git annex fsck
unused (checking for unused data...) ok
@@ -332,13 +331,6 @@ Fsck never deletes possibly bad data; instead it will be moved to
might say about a badly messed up annex:
# git annex fsck
- unused (checking for unused data...)
- Some annexed data is no longer pointed to by any files in the repository.
- NUMBER KEY
- 1 WORM:1289672605:3:file
- (To see where data was previously used, try: git log --stat -S'KEY')
- (To remove unwanted data: git-annex dropunused NUMBER)
- failed
fsck my_cool_big_file (checksum...)
Bad file content; moved to .git/annex/bad/SHA1:7da006579dd64330eb2456001fd01948430572f2
** No known copies of the file exist!
@@ -346,4 +338,4 @@ might say about a badly messed up annex:
fsck important_file
Only 1 of 2 copies exist. Run git annex get somewhere else to back it up.
failed
- git-annex: 3 failed
+ git-annex: 2 failed