{- git-annex command - - Copyright 2013 Joey Hess - - Licensed under the GNU GPL version 3 or higher. -} module Command.Forget where import Common.Annex import Command import qualified Annex.Branch as Branch import Logs.Transitions import qualified Annex import Data.Time.Clock.POSIX cmd :: Command cmd = withOptions forgetOptions $ command "forget" SectionMaintenance "prune git-annex branch history" paramNothing (withParams seek) forgetOptions :: [Option] forgetOptions = [dropDeadOption] dropDeadOption :: Option dropDeadOption = flagOption [] "drop-dead" "drop references to dead repositories" seek :: CmdParams -> CommandSeek seek ps = do dropdead <- getOptionFlag dropDeadOption withNothing (start dropdead) ps start :: Bool -> CommandStart start dropdead = do showStart "forget" "git-annex" now <- liftIO getPOSIXTime let basets = addTransition now ForgetGitHistory noTransitions let ts = if dropdead then addTransition now ForgetDeadRemotes basets else basets next $ perform ts =<< Annex.getState Annex.force perform :: Transitions -> Bool -> CommandPerform perform ts True = do recordTransitions Branch.change ts -- get branch committed before contining with the transition Branch.update void $ Branch.performTransitions ts True [] next $ return True perform _ False = do showLongNote "To forget git-annex branch history, you must specify --force. This deletes metadata!" stop