git-annex/git-annex.hs

65 lines
1.6 KiB
Haskell
Raw Normal View History

{- git-annex main program dispatch
2010-10-27 20:53:54 +00:00
-
- Copyright 2010-2024 Joey Hess <id@joeyh.name>
2010-10-27 20:53:54 +00:00
-
- Licensed under the GNU AGPL version 3 or higher.
2010-10-27 20:53:54 +00:00
-}
2010-10-10 04:18:16 +00:00
{-# LANGUAGE CPP #-}
import System.Environment (getArgs, getProgName)
import System.FilePath
import Network.Socket (withSocketsDo)
import qualified Data.Map as M
2010-10-16 20:20:49 +00:00
import CmdLine.Multicall
2014-01-26 20:25:55 +00:00
import qualified CmdLine.GitAnnex
import qualified CmdLine.GitAnnexShell
import qualified CmdLine.GitRemoteAnnex
import qualified CmdLine.GitRemoteTorAnnex
import qualified Test
import qualified Benchmark
import Messages
import Utility.FileSystemEncoding
#ifdef mingw32_HOST_OS
import Utility.UserInfo
2018-01-09 15:51:17 +00:00
import Utility.Env.Set
#endif
2010-10-31 18:32:18 +00:00
main :: IO ()
main = sanitizeTopLevelExceptionMessages $ withSocketsDo $ do
useFileSystemEncoding
2014-02-14 17:39:22 +00:00
ps <- getArgs
#ifdef mingw32_HOST_OS
winEnv
#endif
run ps =<< getProgName
where
run ps n = case M.lookup (takeFileName n) otherMulticallCommands of
Just GitAnnexShell -> CmdLine.GitAnnexShell.run ps
Just GitRemoteAnnex -> CmdLine.GitRemoteAnnex.run ps
Just GitRemoteTorAnnex -> CmdLine.GitRemoteTorAnnex.run ps
Nothing -> CmdLine.GitAnnex.run
Test.optParser
Test.runner
Benchmark.mkGenerator
ps
#ifdef mingw32_HOST_OS
{- On Windows, if HOME is not set, probe it and set it.
- This is a workaround for some Cygwin commands needing HOME to be set.
-
- If TZ is set, unset it.
- TZ being set can interfere with workarounds for Windows timezone
- horribleness, and prevents getCurrentTimeZone from seeing the system
- time zone.
-}
winEnv :: IO ()
winEnv = do
home <- myHomeDir
setEnv "HOME" home False
setEnv "CYGWIN" "nodosfilewarning" True
unsetEnv "TZ"
#endif