git-annex/Command/Uninit.hs

61 lines
1.5 KiB
Haskell
Raw Normal View History

2010-12-03 04:33:41 +00:00
{- git-annex command
-
- Copyright 2010 Joey Hess <joey@kitenet.net>
-
- Licensed under the GNU GPL version 3 or higher.
-}
module Command.Uninit where
import Control.Monad.State (liftIO)
import System.Directory
import Command
import Messages
import Types
import Utility
import qualified GitRepo as Git
import qualified Annex
import qualified Command.Unannex
import qualified Command.Init
command :: [Command]
command = [repoCommand "uninit" paramPath seek
"de-initialize git-annex and clean out repository"]
seek :: [CommandSeek]
seek = [withFilesInGit Command.Unannex.start, withNothing start]
2010-12-03 04:33:41 +00:00
start :: CommandStartNothing
2010-12-03 04:33:41 +00:00
start = do
showStart "uninit" ""
2011-05-15 06:02:46 +00:00
next perform
2010-12-03 04:33:41 +00:00
perform :: CommandPerform
2010-12-03 04:33:41 +00:00
perform = do
g <- Annex.gitRepo
gitPreCommitHookUnWrite g
liftIO $ gitAttributesUnWrite g
2011-05-15 06:02:46 +00:00
next $ return True
2010-12-03 04:33:41 +00:00
gitPreCommitHookUnWrite :: Git.Repo -> Annex ()
gitPreCommitHookUnWrite repo = do
let hook = Command.Init.preCommitHook repo
whenM (liftIO $ doesFileExist hook) $ do
2010-12-03 04:33:41 +00:00
c <- liftIO $ readFile hook
if c == Command.Init.preCommitScript
then liftIO $ removeFile hook
else warning $ "pre-commit hook (" ++ hook ++
") contents modified; not deleting." ++
" Edit it to remove call to git annex."
gitAttributesUnWrite :: Git.Repo -> IO ()
gitAttributesUnWrite repo = do
let attributes = Git.attributes repo
whenM (doesFileExist attributes) $ do
2010-12-03 04:33:41 +00:00
c <- readFileStrict attributes
2011-01-28 16:35:51 +00:00
safeWriteFile attributes $ unlines $
2011-03-16 15:53:46 +00:00
filter (\l -> not $ l `elem` Command.Init.attrLines) $ lines c