450ee53ab6
Most of the time, there will be no discreprancy between programPath and readProgramFile. But, the programFile might have been written by an old version of git-annex that is still installed, while a newer one is currently running. In this case, we want to run the same one that's currently running. This is especially important for things like the GIT_SSH=git-annex used for ssh connection caching. The only code that still uses readProgramFile directly is the upgrade code, which needs to know where the standalone git-annex was installed, in order to upgrade it.
91 lines
2.5 KiB
Haskell
91 lines
2.5 KiB
Haskell
{- git-annex assistant
|
|
-
|
|
- Copyright 2012 Joey Hess <id@joeyh.name>
|
|
-
|
|
- Licensed under the GNU GPL version 3 or higher.
|
|
-}
|
|
|
|
module Command.Assistant where
|
|
|
|
import Common.Annex
|
|
import Command
|
|
import qualified Command.Watch
|
|
import Annex.Init
|
|
import Annex.Path
|
|
import Config.Files
|
|
import qualified Build.SysConfig
|
|
import Utility.HumanTime
|
|
import Assistant.Install
|
|
|
|
import System.Environment
|
|
|
|
cmd :: [Command]
|
|
cmd = [noRepo checkAutoStart $ dontCheck repoExists $ withOptions options $
|
|
notBareRepo $ command "assistant" paramNothing seek SectionCommon
|
|
"automatically handle changes"]
|
|
|
|
options :: [Option]
|
|
options =
|
|
[ Command.Watch.foregroundOption
|
|
, Command.Watch.stopOption
|
|
, autoStartOption
|
|
, startDelayOption
|
|
]
|
|
|
|
autoStartOption :: Option
|
|
autoStartOption = flagOption [] "autostart" "start in known repositories"
|
|
|
|
startDelayOption :: Option
|
|
startDelayOption = fieldOption [] "startdelay" paramNumber "delay before running startup scan"
|
|
|
|
seek :: CommandSeek
|
|
seek ps = do
|
|
stopdaemon <- getOptionFlag Command.Watch.stopOption
|
|
foreground <- getOptionFlag Command.Watch.foregroundOption
|
|
autostart <- getOptionFlag autoStartOption
|
|
startdelay <- getOptionField startDelayOption (pure . maybe Nothing parseDuration)
|
|
withNothing (start foreground stopdaemon autostart startdelay) ps
|
|
|
|
start :: Bool -> Bool -> Bool -> Maybe Duration -> CommandStart
|
|
start foreground stopdaemon autostart startdelay
|
|
| autostart = do
|
|
liftIO $ autoStart startdelay
|
|
stop
|
|
| otherwise = do
|
|
liftIO ensureInstalled
|
|
ensureInitialized
|
|
Command.Watch.start True foreground stopdaemon startdelay
|
|
|
|
{- Run outside a git repository. Check to see if any parameter is
|
|
- --autostart and enter autostart mode. -}
|
|
checkAutoStart :: CmdParams -> IO ()
|
|
checkAutoStart _ = ifM (elem "--autostart" <$> getArgs)
|
|
( autoStart Nothing
|
|
, error "Not in a git repository."
|
|
)
|
|
|
|
autoStart :: Maybe Duration -> IO ()
|
|
autoStart startdelay = do
|
|
dirs <- liftIO readAutoStartFile
|
|
when (null dirs) $ do
|
|
f <- autoStartFile
|
|
error $ "Nothing listed in " ++ f
|
|
program <- programPath
|
|
haveionice <- pure Build.SysConfig.ionice <&&> inPath "ionice"
|
|
forM_ dirs $ \d -> do
|
|
putStrLn $ "git-annex autostart in " ++ d
|
|
ifM (catchBoolIO $ go haveionice program d)
|
|
( putStrLn "ok"
|
|
, putStrLn "failed"
|
|
)
|
|
where
|
|
go haveionice program dir = do
|
|
setCurrentDirectory dir
|
|
if haveionice
|
|
then boolSystem "ionice" (Param "-c3" : Param program : baseparams)
|
|
else boolSystem program baseparams
|
|
where
|
|
baseparams =
|
|
[ Param "assistant"
|
|
, Param $ "--startdelay=" ++ fromDuration (fromMaybe (Duration 5) startdelay)
|
|
]
|