sync: Fix committing when in a direct mode repo that has no HEAD ref.
Seen for example, a newly checked out git submodule. In this case, .git/HEAD is a raw sha, rather than the usual reference to a ref. Removed currentSha in passing, since it was a more roundabout way of doing what headSha does, and headSha is more robust.
This commit is contained in:
		
					parent
					
						
							
								79b6500111
							
						
					
				
			
			
				commit
				
					
						a6db10d565
					
				
			
		
					 5 changed files with 16 additions and 14 deletions
				
			
		|  | @ -13,8 +13,8 @@ import Config | |||
| import Utility.Tmp | ||||
| import Utility.Env | ||||
| import Annex.Direct | ||||
| import qualified Git.Branch | ||||
| import qualified Git.Sha | ||||
| import qualified Git.Ref | ||||
| 
 | ||||
| cmd :: [Command] | ||||
| cmd = [notBareRepo $ | ||||
|  | @ -35,7 +35,7 @@ start (c:ps) = liftIO . exitWith =<< ifM isDirect | |||
|   where | ||||
| 	go tmp = do | ||||
| 		oldref <- fromMaybe Git.Sha.emptyTree | ||||
| 			<$> inRepo Git.Branch.currentSha | ||||
| 			<$> inRepo Git.Ref.headSha | ||||
| 		exitcode <- liftIO $ proxy tmp | ||||
| 		mergeDirectCleanup tmp oldref | ||||
| 		return exitcode | ||||
|  |  | |||
|  | @ -174,15 +174,15 @@ commitMsg = do | |||
| 	return $ "git-annex in " ++ fromMaybe "unknown" (M.lookup u m) | ||||
| 
 | ||||
| commitStaged :: Git.Branch.CommitMode -> String -> Annex Bool | ||||
| commitStaged commitmode commitmessage = go =<< inRepo Git.Branch.currentUnsafe | ||||
|   where | ||||
| 	go Nothing = return False | ||||
| 	go (Just branch) = do | ||||
| 		runAnnexHook preCommitAnnexHook | ||||
| 		parent <- inRepo $ Git.Ref.sha branch | ||||
| 		void $ inRepo $ Git.Branch.commit commitmode False commitmessage branch | ||||
| 			(maybeToList parent) | ||||
| 		return True | ||||
| commitStaged commitmode commitmessage = do | ||||
| 	runAnnexHook preCommitAnnexHook | ||||
| 	mb <- inRepo Git.Branch.currentUnsafe | ||||
| 	let (getparent, branch) = case mb of | ||||
| 		Just b -> (Git.Ref.sha b, b) | ||||
| 		Nothing -> (Git.Ref.headSha, Git.Ref.headRef) | ||||
| 	parents <- maybeToList <$> inRepo getparent | ||||
| 	void $ inRepo $ Git.Branch.commit commitmode False commitmessage branch parents | ||||
| 	return True | ||||
| 
 | ||||
| mergeLocal :: Maybe Git.Ref -> CommandStart | ||||
| mergeLocal Nothing = stop | ||||
|  |  | |||
|  | @ -43,9 +43,6 @@ currentUnsafe r = parse . firstLine | |||
| 		| null l = Nothing | ||||
| 		| otherwise = Just $ Git.Ref l | ||||
| 
 | ||||
| currentSha :: Repo -> IO (Maybe Git.Sha) | ||||
| currentSha r = maybe (pure Nothing) (`Git.Ref.sha` r) =<< current r | ||||
| 
 | ||||
| {- Checks if the second branch has any commits not present on the first | ||||
|  - branch. -} | ||||
| changed :: Branch -> Branch -> Repo -> IO Bool | ||||
|  |  | |||
|  | @ -88,6 +88,9 @@ sha branch repo = process <$> showref repo | |||
| 	process [] = Nothing | ||||
| 	process s = Just $ Ref $ firstLine s | ||||
| 
 | ||||
| headSha :: Repo -> IO (Maybe Sha) | ||||
| headSha = sha headRef | ||||
| 
 | ||||
| {- List of (shas, branches) matching a given ref or refs. -} | ||||
| matching :: [Ref] -> Repo -> IO [(Sha, Branch)] | ||||
| matching refs repo =  matching' (map fromRef refs) repo | ||||
|  |  | |||
							
								
								
									
										2
									
								
								debian/changelog
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								debian/changelog
									
										
									
									
										vendored
									
									
								
							|  | @ -27,6 +27,8 @@ git-annex (5.2015022) UNRELEASED; urgency=medium | |||
|     (or '!') character. | ||||
|   * Also potentially fixes encoding problem when embedding credentials | ||||
|     that contain unicode characters. | ||||
|   * sync: Fix committing when in a direct mode repo that has no HEAD ref. | ||||
|     (For example, a newly checked out git submodule.) | ||||
| 
 | ||||
|  -- Joey Hess <id@joeyh.name>  Thu, 19 Feb 2015 14:16:03 -0400 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Joey Hess
				Joey Hess