diff options
-rw-r--r-- | Git/RecoverRepository.hs | 30 | ||||
-rw-r--r-- | Git/RefLog.hs | 23 | ||||
-rw-r--r-- | git-recover-repository.hs | 2 |
3 files changed, 36 insertions, 19 deletions
diff --git a/Git/RecoverRepository.hs b/Git/RecoverRepository.hs index 330063abe..8dce04f1e 100644 --- a/Git/RecoverRepository.hs +++ b/Git/RecoverRepository.hs @@ -23,6 +23,7 @@ import qualified Git.Config import qualified Git.Construct import qualified Git.LsTree as LsTree import qualified Git.Ref as Ref +import qualified Git.RefLog as RefLog import Utility.Tmp import Utility.Rsync @@ -186,16 +187,8 @@ resetLocalBranches missing goodcommits r = reset b c go (b:changed) deleted gcs' bs Nothing -> do - (mc', gcs'') <- findOldBranch missing gcs' b r - case mc' of - Just c - | c == b -> go changed deleted gcs' bs - | otherwise -> do - reset b c - go (b:changed) deleted gcs'' bs - Nothing -> do - nukeBranchRef b r - go changed (b:deleted) gcs'' bs + nukeBranchRef b r + go changed (b:deleted) gcs' bs reset b c = do nukeBranchRef b r void $ runBool @@ -274,7 +267,9 @@ nukeBranchRef b r = void $ usegit <||> byhand {- Finds the most recent commit to a branch that does not need any - of the missing objects. If the input branch is good as-is, returns it. - Otherwise, tries to traverse the commits in the branch to find one - - that is ok (might fail, if one of them is corrupt). + - that is ok. That might fail, if one of them is corrupt, or if an object + - at the root of the branch is missing. Finally, looks for an old version + - of the branch from the reflog. -} findUncorruptedCommit :: MissingObjects -> GoodCommits -> Branch -> Repo -> IO (Maybe Sha, GoodCommits) findUncorruptedCommit missing goodcommits branch r = do @@ -288,7 +283,12 @@ findUncorruptedCommit missing goodcommits branch r = do , Param "--format=%H" , Param (show branch) ] r - cleanup `after` findfirst goodcommits (catMaybes $ map extractSha ls) + let branchshas = catMaybes $ map extractSha ls + reflogshas <- RefLog.get branch r + -- XXX Could try a bit harder here, and look + -- for uncorrupted old commits in branches in the + -- reflog. + cleanup `after` findfirst goodcommits (branchshas ++ reflogshas) where findfirst gcs [] = return (Nothing, gcs) findfirst gcs (c:cs) = do @@ -297,12 +297,6 @@ findUncorruptedCommit missing goodcommits branch r = do then return (Just c, gcs') else findfirst gcs' cs -{- Looks through the reflog to find an old version of a branch that - - does not need any of the missing objects. - -} -findOldBranch :: MissingObjects -> GoodCommits -> Branch -> Repo -> IO (Maybe Sha, GoodCommits) -findOldBranch missing goodcommits branch r = error "TODO" - {- Verifies tha none of the missing objects in the set are used by - the commit. Also adds to a set of commit shas that have been verified to - be good, which can be passed into subsequent calls to avoid diff --git a/Git/RefLog.hs b/Git/RefLog.hs new file mode 100644 index 000000000..7502f14b3 --- /dev/null +++ b/Git/RefLog.hs @@ -0,0 +1,23 @@ +{- git reflog interface + - + - Copyright 2013 Joey Hess <joey@kitenet.net> + - + - Licensed under the GNU GPL version 3 or higher. + -} + +module Git.RefLog where + +import Common +import Git +import Git.Command +import Git.Sha +import Git.CatFile + +{- Gets the reflog for a given branch. -} +get :: Branch -> Repo -> IO [Sha] +get b = mapMaybe extractSha . lines <$$> pipeReadStrict + [ Param "log" + , Param "-g" + , Param "--format=%H" + , Param (show b) + ] diff --git a/git-recover-repository.hs b/git-recover-repository.hs index 3a002e72c..21852e376 100644 --- a/git-recover-repository.hs +++ b/git-recover-repository.hs @@ -35,7 +35,7 @@ parseArgs = do enableDebugOutput :: IO () enableDebugOutput = do s <- setFormatter - <$> streamHandler stderr DEBUG -- NOTICE + <$> streamHandler stderr NOTICE <*> pure (simpleLogFormatter "$msg") updateGlobalLogger rootLoggerName (setLevel DEBUG . setHandlers [s]) |