summaryrefslogtreecommitdiff
path: root/Command/Sync.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2011-12-31 03:38:58 -0400
committerGravatar Joey Hess <joey@kitenet.net>2011-12-31 03:38:58 -0400
commita2ec2d3760f5ae17836ade3b0238dde7f9de5bd2 (patch)
treed15b531723ca09eb4060dd9c6ae03e4ad39da4cb /Command/Sync.hs
parent8a33573caff38b557fdf60c9547a78a5cc8c4ddc (diff)
refactor and check for a detached HEAD
Diffstat (limited to 'Command/Sync.hs')
-rw-r--r--Command/Sync.hs9
1 files changed, 3 insertions, 6 deletions
diff --git a/Command/Sync.hs b/Command/Sync.hs
index 6e78543ef..9426b1c00 100644
--- a/Command/Sync.hs
+++ b/Command/Sync.hs
@@ -22,7 +22,6 @@ import qualified Git
import qualified Types.Remote
import qualified Remote.Git
-import qualified Data.ByteString.Lazy.Char8 as L
import qualified Data.Map as M
def :: [Command]
@@ -32,7 +31,7 @@ def = [command "sync" (paramOptional (paramRepeating paramRemote))
-- syncing involves several operations, any of which can independently fail
seek :: CommandSeek
seek rs = do
- !branch <- currentBranch
+ !branch <- fromMaybe nobranch <$> inRepo (Git.Branch.current)
remotes <- syncRemotes rs
return $ concat $
[ [ commit ]
@@ -42,6 +41,8 @@ seek rs = do
, [ pushLocal branch ]
, [ pushRemote remote branch | remote <- remotes ]
]
+ where
+ nobranch = error "no branch is checked out"
syncBranch :: Git.Ref -> Git.Ref
syncBranch = Git.Ref.under "refs/heads/synced/"
@@ -148,10 +149,6 @@ mergeAnnex = do
Annex.Branch.forceUpdate
stop
-currentBranch :: Annex Git.Ref
-currentBranch = Git.Ref . firstLine . L.unpack <$>
- inRepo (Git.Command.pipeRead [Param "symbolic-ref", Param "HEAD"])
-
mergeFrom :: Git.Ref -> CommandCleanup
mergeFrom branch = do
showOutput