git-annex/git-annex.hs

77 lines
1.8 KiB
Haskell
Raw Normal View History

{- git-annex main program dispatch
2010-10-27 20:53:54 +00:00
-
- Copyright 2010-2014 Joey Hess <joey@kitenet.net>
2010-10-27 20:53:54 +00:00
-
- Licensed under the GNU GPL version 3 or higher.
-}
2010-10-10 04:18:16 +00:00
{-# LANGUAGE CPP #-}
import System.Environment (getArgs, getProgName)
import System.FilePath
2010-10-16 20:20:49 +00:00
2014-01-26 20:25:55 +00:00
import qualified CmdLine.GitAnnex
import qualified CmdLine.GitAnnexShell
2013-02-27 20:33:20 +00:00
#ifdef WITH_TESTSUITE
import qualified Test
#endif
#ifdef mingw32_HOST_OS
import Utility.UserInfo
import Utility.Env
import Config.Files
import System.Process
import System.Exit
#endif
2010-10-31 18:32:18 +00:00
main :: IO ()
2014-02-14 17:39:22 +00:00
main = do
ps <- getArgs
run ps =<< getProgName
2012-11-11 04:51:07 +00:00
where
2014-02-14 17:39:22 +00:00
run ps n
| isshell n = CmdLine.GitAnnexShell.run ps
| otherwise =
#ifdef mingw32_HOST_OS
2014-02-14 18:16:59 +00:00
winEnv gitannex ps
#else
2014-02-14 18:16:59 +00:00
gitannex ps
#endif
2014-02-14 18:16:59 +00:00
gitannex ps =
#ifdef WITH_TESTSUITE
case ps of
("test":ps') -> Test.main ps'
_ -> CmdLine.GitAnnex.run ps
#else
CmdLine.GitAnnex.run ps
#endif
2014-02-14 17:39:22 +00:00
isshell n = takeFileName n == "git-annex-shell"
#ifdef mingw32_HOST_OS
{- On Windows, if HOME is not set, probe it and set it, re-execing
- git-annex with the new environment.
-
- This is a workaround for some Cygwin commands needing HOME to be set,
- and for there being no known way to set environment variables on
- Windows, except by passing an environment in each call to a program.
- While ugly, this workaround is easier than trying to ensure HOME is set
- in all calls to the affected programs.
-}
winEnv :: ([String] -> IO ()) -> [String] -> IO ()
winEnv a ps = go =<< getEnv "HOME"
where
go (Just _) = a ps
go Nothing = do
home <- myHomeDir
2014-02-14 18:16:59 +00:00
putStrLn $ "** Windows hack; overrideing HOME to " ++ home
e <- getEnvironment
let eoverride =
[ ("HOME", home)
, ("CYGWIN", "nodosfilewarning")
]
cmd <- readProgramFile
2014-02-14 18:16:59 +00:00
(_, _, _, pid) <- createProcess (proc cmd ps)
{ env = Just $ e ++ eoverride }
2014-02-14 18:16:59 +00:00
exitWith =<< waitForProcess pid
#endif