summaryrefslogtreecommitdiff
path: root/Command/Unannex.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2011-02-09 11:02:21 -0400
committerGravatar Joey Hess <joey@kitenet.net>2011-02-09 11:02:21 -0400
commit35a65068123f0215929e06e98bf4a6a67d2ae7dd (patch)
tree45fe553d4d25f1ea69bf542514351c6dbd7f0a18 /Command/Unannex.hs
parent62ebeb00d9f079f079c38798f8496dd666ae1fd5 (diff)
unannex: Fix recently introduced bug when attempting to unannex more than one file at a time.
Diffstat (limited to 'Command/Unannex.hs')
-rw-r--r--Command/Unannex.hs13
1 files changed, 8 insertions, 5 deletions
diff --git a/Command/Unannex.hs b/Command/Unannex.hs
index c663b29ab..19cb1624e 100644
--- a/Command/Unannex.hs
+++ b/Command/Unannex.hs
@@ -33,10 +33,13 @@ start file = isAnnexed file $ \(key, backend) -> do
ishere <- inAnnex key
if ishere
then do
- g <- Annex.gitRepo
- staged <- liftIO $ Git.stagedFiles g [Git.workTree g]
- unless (null staged) $
- error "This command cannot be run when there are already files staged for commit."
+ force <- Annex.getState Annex.force
+ unless force $ do
+ g <- Annex.gitRepo
+ staged <- liftIO $ Git.stagedFiles g [Git.workTree g]
+ unless (null staged) $
+ error "This command cannot be run when there are already files staged for commit."
+ Annex.changeState $ \s -> s { Annex.force = True }
showStart "unannex" file
return $ Just $ perform file key backend
@@ -65,6 +68,6 @@ cleanup file key = do
-- Commit staged changes at end to avoid confusing the
-- pre-commit hook if this file is later added back to
-- git as a normal, non-annexed file.
- Annex.queue "commit" ["-m", "content removed from git annex"] "--"
+ Annex.queue "commit" ["-m", "content removed from git annex"] "-a"
return True