summaryrefslogtreecommitdiff
path: root/Remote
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2016-09-30 19:51:16 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2016-09-30 19:51:16 -0400
commitd684c2f53135f51872c112732acc4079b2d4693d (patch)
treed7a6895a1b2874d436fb094625174859c325bac8 /Remote
parent0a588575977bc74a61917801477e03da3897507d (diff)
convert TMVars that are never left empty into TVars
This is probably more efficient, and it avoids mistakenly leaving them empty.
Diffstat (limited to 'Remote')
-rw-r--r--Remote/External.hs46
-rw-r--r--Remote/External/Types.hs18
2 files changed, 26 insertions, 38 deletions
diff --git a/Remote/External.hs b/Remote/External.hs
index a2d5670ec..65b05fe62 100644
--- a/Remote/External.hs
+++ b/Remote/External.hs
@@ -127,7 +127,7 @@ externalSetup mu _ c gc = do
INITREMOTE_FAILURE errmsg -> Just $ error errmsg
_ -> Nothing
withExternalState external $
- liftIO . atomically . readTMVar . externalConfig
+ liftIO . atomically . readTVar . externalConfig
gitConfigSpecialRemote u c'' "externaltype" externaltype
return (c'', u)
@@ -234,24 +234,22 @@ handleRequest' st external req mp responsehandler
handleRemoteRequest (DIRHASH_LOWER k) =
send $ VALUE $ hashDirLower def k
handleRemoteRequest (SETCONFIG setting value) =
- liftIO $ atomically $ do
- let v = externalConfig st
- m <- takeTMVar v
- putTMVar v $ M.insert setting value m
+ liftIO $ atomically $ modifyTVar' (externalConfig st) $
+ M.insert setting value
handleRemoteRequest (GETCONFIG setting) = do
value <- fromMaybe "" . M.lookup setting
- <$> liftIO (atomically $ readTMVar $ externalConfig st)
+ <$> liftIO (atomically $ readTVar $ externalConfig st)
send $ VALUE value
handleRemoteRequest (SETCREDS setting login password) = do
let v = externalConfig st
- c <- liftIO $ atomically $ readTMVar v
+ c <- liftIO $ atomically $ readTVar v
let gc = externalGitConfig external
c' <- setRemoteCredPair encryptionAlreadySetup c gc
(credstorage setting)
(Just (login, password))
- void $ liftIO $ atomically $ swapTMVar v c'
+ void $ liftIO $ atomically $ swapTVar v c'
handleRemoteRequest (GETCREDS setting) = do
- c <- liftIO $ atomically $ readTMVar $ externalConfig st
+ c <- liftIO $ atomically $ readTVar $ externalConfig st
let gc = externalGitConfig external
creds <- fromMaybe ("", "") <$>
getRemoteCredPair c gc (credstorage setting)
@@ -356,19 +354,15 @@ withExternalState external = bracket alloc dealloc
alloc = do
ms <- liftIO $ atomically $ do
- l <- takeTMVar v
+ l <- readTVar v
case l of
- [] -> do
- putTMVar v l
- return Nothing
+ [] -> return Nothing
(st:rest) -> do
- putTMVar v rest
+ writeTVar v rest
return (Just st)
maybe (startExternal external) return ms
- dealloc st = liftIO $ atomically $ do
- l <- takeTMVar v
- putTMVar v (st:l)
+ dealloc st = liftIO $ atomically $ modifyTVar' v (st:)
{- Starts an external remote process running, and checks VERSION. -}
startExternal :: External -> Annex ExternalState
@@ -396,11 +390,11 @@ startExternal external = do
fileEncoding herr
stderrelay <- async $ errrelayer herr
checkearlytermination =<< getProcessExitCode ph
- cv <- newTMVarIO $ externalDefaultConfig external
- pv <- newTMVarIO Unprepared
+ cv <- newTVarIO $ externalDefaultConfig external
+ pv <- newTVarIO Unprepared
pid <- atomically $ do
- n <- succ <$> takeTMVar (externalLastPid external)
- putTMVar (externalLastPid external) n
+ n <- succ <$> readTVar (externalLastPid external)
+ writeTVar (externalLastPid external) n
return n
return $ ExternalState
{ externalSend = hin
@@ -431,17 +425,13 @@ startExternal external = do
stopExternal :: External -> Annex ()
stopExternal external = liftIO $ do
- l <- atomically $ do
- l <- takeTMVar v
- putTMVar v []
- return l
+ l <- atomically $ swapTVar (externalState external) []
mapM_ stop l
where
stop st = do
hClose $ externalSend st
hClose $ externalReceive st
externalShutdown st
- v = externalState external
externalRemoteProgram :: ExternalType -> String
externalRemoteProgram externaltype = "git-annex-remote-" ++ externaltype
@@ -459,7 +449,7 @@ checkVersion _ _ _ = Nothing
- the error message. -}
checkPrepared :: ExternalState -> External -> Annex ()
checkPrepared st external = do
- v <- liftIO $ atomically $ readTMVar $ externalPrepared st
+ v <- liftIO $ atomically $ readTVar $ externalPrepared st
case v of
Prepared -> noop
FailedPrepare errmsg -> error errmsg
@@ -474,7 +464,7 @@ checkPrepared st external = do
_ -> Nothing
where
setprepared status = liftIO $ atomically $ void $
- swapTMVar (externalPrepared st) status
+ swapTVar (externalPrepared st) status
{- Caches the cost in the git config to avoid needing to start up an
- external special remote every time time just to ask it what its
diff --git a/Remote/External/Types.hs b/Remote/External/Types.hs
index 33a22aeb1..2306989bb 100644
--- a/Remote/External/Types.hs
+++ b/Remote/External/Types.hs
@@ -45,10 +45,10 @@ import Network.URI
data External = External
{ externalType :: ExternalType
, externalUUID :: UUID
- , externalState :: TMVar [ExternalState]
- -- ^ TMVar is never left empty; list contains states for external
- -- special remote processes that are not currently in use.
- , externalLastPid :: TMVar PID
+ , externalState :: TVar [ExternalState]
+ -- ^ Contains states for external special remote processes
+ -- that are not currently in use.
+ , externalLastPid :: TVar PID
, externalDefaultConfig :: RemoteConfig
, externalGitConfig :: RemoteGitConfig
}
@@ -57,8 +57,8 @@ newExternal :: ExternalType -> UUID -> RemoteConfig -> RemoteGitConfig -> Annex
newExternal externaltype u c gc = liftIO $ External
<$> pure externaltype
<*> pure u
- <*> atomically (newTMVar [])
- <*> atomically (newTMVar 0)
+ <*> atomically (newTVar [])
+ <*> atomically (newTVar 0)
<*> pure c
<*> pure gc
@@ -69,10 +69,8 @@ data ExternalState = ExternalState
, externalReceive :: Handle
, externalShutdown :: IO ()
, externalPid :: PID
- , externalPrepared :: TMVar PrepareStatus
- -- ^ Never left empty.
- , externalConfig :: TMVar RemoteConfig
- -- ^ Never left empty.
+ , externalPrepared :: TVar PrepareStatus
+ , externalConfig :: TVar RemoteConfig
}
type PID = Int