diff options
author | Joey Hess <joey@kitenet.net> | 2014-01-26 13:03:25 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2014-01-26 13:03:25 -0400 |
commit | 3a8cf1f4bc7ddd9f063f2e2e7cf74ad093e0ef60 (patch) | |
tree | 09baadacf3ecc243b7104d60da4e0e8efdfc2ed2 /Remote/Git.hs | |
parent | b87811c4b55d66b1edb26c73e6578ca9f2994a65 (diff) |
Optimise non-bare http remotes; no longer does a 404 to the wrong url every time before trying the right url. Needs annex-bare to be set to false, which is done when initially probing the uuid of a http remote.
Diffstat (limited to 'Remote/Git.hs')
-rw-r--r-- | Remote/Git.hs | 47 |
1 files changed, 32 insertions, 15 deletions
diff --git a/Remote/Git.hs b/Remote/Git.hs index e292707e4..832263b43 100644 --- a/Remote/Git.hs +++ b/Remote/Git.hs @@ -111,7 +111,7 @@ gen r u c gc , retrieveKeyFile = copyFromRemote new , retrieveKeyFileCheap = copyFromRemoteCheap new , removeKey = dropKey new - , hasKey = inAnnex r + , hasKey = inAnnex new , hasKeyCheap = repoCheap r , whereisKey = Nothing , remoteFsck = if Git.repoIsUrl r @@ -197,7 +197,12 @@ tryGitConfigRead r Left _ -> do set_ignore "not usable by git-annex" return r - Right r' -> return r' + Right r' -> do + -- Cache when http remote is not bare for + -- optimisation. + unless (Git.Config.isBare r') $ + setremote "annex-bare" (Git.Config.boolConfig False) + return r' store = observe $ \r' -> do g <- gitRepo @@ -222,12 +227,18 @@ tryGitConfigRead r set_ignore "does not have git-annex installed" return r - set_ignore msg = case Git.remoteName r of + set_ignore msg = do + let k = "annex-ignore" + case Git.remoteName r of + Nothing -> noop + Just n -> warning $ "Remote " ++ n ++ " " ++ msg ++ "; setting " ++ k + setremote k (Git.Config.boolConfig True) + + setremote k v = case Git.remoteName r of Nothing -> noop Just n -> do - let k = "remote." ++ n ++ ".annex-ignore" - warning $ "Remote " ++ n ++ " " ++ msg ++ "; setting " ++ k - inRepo $ Git.Command.run [Param "config", Param k, Param "true"] + let k' = "remote." ++ n ++ "." ++ k + inRepo $ Git.Command.run [Param "config", Param k', Param v] handlegcrypt Nothing = return r handlegcrypt (Just _cacheduuid) = do @@ -242,15 +253,16 @@ tryGitConfigRead r - If the remote cannot be accessed, or if it cannot determine - whether it has the content, returns a Left error message. -} -inAnnex :: Git.Repo -> Key -> Annex (Either String Bool) -inAnnex r key +inAnnex :: Remote -> Key -> Annex (Either String Bool) +inAnnex rmt key | Git.repoIsHttp r = checkhttp =<< getHttpHeaders | Git.repoIsUrl r = checkremote | otherwise = checklocal where + r = repo rmt checkhttp headers = do showChecking r - ifM (anyM (\u -> Url.withUserAgent $ Url.checkBoth u headers (keySize key)) (keyUrls r key)) + ifM (anyM (\u -> Url.withUserAgent $ Url.checkBoth u headers (keySize key)) (keyUrls rmt key)) ( return $ Right True , return $ Left "not found" ) @@ -263,14 +275,19 @@ inAnnex r key dispatch (Right (Just b)) = Right b dispatch (Right Nothing) = cantCheck r -keyUrls :: Git.Repo -> Key -> [String] -keyUrls r key = map tourl locs +keyUrls :: Remote -> Key -> [String] +keyUrls r key = map tourl locs' where - tourl l = Git.repoLocation r ++ "/" ++ l + tourl l = Git.repoLocation (repo r) ++ "/" ++ l + -- If the remote is known to not be bare, try the hash locations + -- used for non-bare repos first, as an optimisation. + locs + | remoteAnnexBare (gitconfig r) == Just False = reverse (annexLocations key) + | otherwise = annexLocations key #ifndef mingw32_HOST_OS - locs = annexLocations key + locs' = locs #else - locs = map (replace "\\" "/") (annexLocations key) + locs' = map (replace "\\" "/") (annexLocations key) #endif dropKey :: Remote -> Key -> Annex Bool @@ -309,7 +326,7 @@ copyFromRemote' r key file dest direct <- isDirect Ssh.rsyncHelper (Just feeder) =<< Ssh.rsyncParamsRemote direct r Download key dest file - | Git.repoIsHttp (repo r) = Annex.Content.downloadUrl (keyUrls (repo r) key) dest + | Git.repoIsHttp (repo r) = Annex.Content.downloadUrl (keyUrls r key) dest | otherwise = error "copying from non-ssh, non-http remote not supported" where {- Feed local rsync's progress info back to the remote, |