diff options
-rw-r--r-- | CHANGELOG | 1 | ||||
-rw-r--r-- | Command/EnableRemote.hs | 24 | ||||
-rw-r--r-- | Config.hs | 6 | ||||
-rw-r--r-- | Remote/Git.hs | 17 | ||||
-rw-r--r-- | doc/git-annex-enableremote.mdwn | 3 |
5 files changed, 34 insertions, 17 deletions
@@ -22,6 +22,7 @@ git-annex (6.20160512) UNRELEASED; urgency=medium * enableremote: Can now be used to explicitly enable git-annex to use git remotes. Using the command this way prevents other git-annex commands from probing new git remotes to auto-enable them. + * enableremote: Remove annex-ignore configuration from a remote. * Support building with ghc 8.0.1. * Pass the various gnupg-options configs to gpg in several cases where they were not before. Most notably, gnupg-decrypt-options is now diff --git a/Command/EnableRemote.hs b/Command/EnableRemote.hs index bf0ad37a3..dc3e7bc56 100644 --- a/Command/EnableRemote.hs +++ b/Command/EnableRemote.hs @@ -11,13 +11,14 @@ import Command import qualified Annex import qualified Logs.Remote import qualified Types.Remote as R -import qualified Git.Types as Git +import qualified Git import qualified Annex.SpecialRemote import qualified Remote import qualified Types.Remote as Remote import qualified Remote.Git import Logs.UUID import Annex.UUID +import Config import qualified Data.Map as M @@ -45,9 +46,10 @@ startNormalRemote :: RemoteName -> Git.Repo -> CommandStart startNormalRemote name r = do showStart "enableremote" name next $ next $ do + setRemoteIgnore r False r' <- Remote.Git.configRead False r u <- getRepoUUID r' - return (u /= NoUUID) + return $ u /= NoUUID startSpecialRemote :: RemoteName -> Remote.RemoteConfig -> Maybe (UUID, Remote.RemoteConfig) -> CommandStart startSpecialRemote name config Nothing = do @@ -74,6 +76,10 @@ performSpecialRemote t u c gc = do cleanupSpecialRemote :: UUID -> R.RemoteConfig -> CommandCleanup cleanupSpecialRemote u c = do Logs.Remote.configSet u c + mr <- Remote.byUUID u + case mr of + Nothing -> noop + Just r -> setRemoteIgnore (R.repo r) False return True unknownNameError :: String -> Annex a @@ -85,8 +91,12 @@ unknownNameError prefix = do else Remote.prettyPrintUUIDsDescs "known special remotes" descm (M.keys m) - nouuids <- filterM (\r -> (==) NoUUID <$> getRepoUUID r) - =<< Annex.fromRepo Git.remotes - let nouuidmsg = unlines $ map ("\t" ++) $ - mapMaybe Git.remoteName nouuids - error $ concat $ filter (not . null) [prefix ++ "\n", nouuidmsg, specialmsg] + disabledremotes <- filterM isdisabled =<< Annex.fromRepo Git.remotes + let remotesmsg = unlines $ map ("\t" ++) $ + mapMaybe Git.remoteName disabledremotes + error $ concat $ filter (not . null) [prefix ++ "\n", remotesmsg, specialmsg] + where + isdisabled r = anyM id + [ (==) NoUUID <$> getRepoUUID r + , remoteAnnexIgnore <$> Annex.getRemoteGitConfig r + ] @@ -80,6 +80,12 @@ setRemoteCost r c = setConfig (remoteConfig r "cost") (show c) setRemoteAvailability :: Git.Repo -> Availability -> Annex () setRemoteAvailability r c = setConfig (remoteConfig r "availability") (show c) +setRemoteIgnore :: Git.Repo -> Bool -> Annex () +setRemoteIgnore r b = setConfig (remoteConfig r "ignore") (Git.Config.boolConfig b) + +setRemoteBare :: Git.Repo -> Bool -> Annex () +setRemoteBare r b = setConfig (remoteConfig r "bare") (Git.Config.boolConfig b) + isDirect :: Annex Bool isDirect = annexDirect <$> Annex.getGitConfig diff --git a/Remote/Git.hs b/Remote/Git.hs index 0528f9f88..403c91b4f 100644 --- a/Remote/Git.hs +++ b/Remote/Git.hs @@ -247,7 +247,7 @@ tryGitConfigRead autoinit r -- Cache when http remote is not bare for -- optimisation. unless (Git.Config.isBare r') $ - setremote "annex-bare" (Git.Config.boolConfig False) + setremote setRemoteBare False return r' store = observe $ \r' -> do @@ -274,21 +274,18 @@ tryGitConfigRead autoinit r return r set_ignore msg longmessage = do - let k = "annex-ignore" case Git.remoteName r of Nothing -> noop Just n -> do - warning $ "Remote " ++ n ++ " " ++ msg ++ "; setting " ++ k + warning $ "Remote " ++ n ++ " " ++ msg ++ "; setting annex-ignore" when longmessage $ - warning $ "This could be a problem with the git-annex installation on the remote. Please make sure that git-annex-shell is available in PATH when you ssh into the remote. Once you have fixed the git-annex installation, run: git config remote." ++ n ++ "." ++ k ++ " false" - setremote k (Git.Config.boolConfig True) + warning $ "This could be a problem with the git-annex installation on the remote. Please make sure that git-annex-shell is available in PATH when you ssh into the remote. Once you have fixed the git-annex installation, run: git annex enableremote " ++ n + setremote setRemoteIgnore True - setremote k v = case Git.remoteName r of + setremote setter v = case Git.remoteName r of Nothing -> noop - Just n -> do - let k' = "remote." ++ n ++ "." ++ k - inRepo $ Git.Command.run [Param "config", Param k', Param v] - + Just n -> setter r v + handlegcrypt Nothing = return r handlegcrypt (Just _cacheduuid) = do -- Generate UUID from the gcrypt-id diff --git a/doc/git-annex-enableremote.mdwn b/doc/git-annex-enableremote.mdwn index d63dfaf62..d424f6056 100644 --- a/doc/git-annex-enableremote.mdwn +++ b/doc/git-annex-enableremote.mdwn @@ -59,6 +59,9 @@ a new clone, it will will attempt to enable the special remote. Of course, this works best when the special remote does not need anything special to be done to get it enabled. +(This command also can be used to enable a remote that git-annex has been +prevented from using by the `remote.<name>.annex-ignore` setting.) + # SEE ALSO [[git-annex]](1) |