From 13118136c07a621ecd1272de3103207ed55b1da7 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Mon, 4 Jun 2012 21:52:36 -0400 Subject: Preserve parent environment when running hooks of the hook special remote. --- Remote/Hook.hs | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) (limited to 'Remote') diff --git a/Remote/Hook.hs b/Remote/Hook.hs index dcac9da88..1202c6087 100644 --- a/Remote/Hook.hs +++ b/Remote/Hook.hs @@ -10,6 +10,7 @@ module Remote.Hook (remote) where import qualified Data.ByteString.Lazy.Char8 as L import qualified Data.Map as M import System.Exit +import System.Environment import Common.Annex import Types.Remote @@ -59,9 +60,12 @@ hookSetup u c = do gitConfigSpecialRemote u c' "hooktype" hooktype return c' -hookEnv :: Key -> Maybe FilePath -> Maybe [(String, String)] -hookEnv k f = Just $ fileenv f ++ keyenv +hookEnv :: Key -> Maybe FilePath -> IO (Maybe [(String, String)]) +hookEnv k f = Just <$> mergeenv (fileenv f ++ keyenv) where + mergeenv l = M.toList . + M.union (M.fromList l) + <$> M.fromList <$> getEnvironment env s v = ("ANNEX_" ++ s, v) keyenv = [ env "KEY" (show k) @@ -88,8 +92,9 @@ runHook hooktype hook k f a = maybe (return False) run =<< lookupHook hooktype h where run command = do showOutput -- make way for hook output - ifM (liftIO $ boolSystemEnv - "sh" [Param "-c", Param command] $ hookEnv k f) + ifM (liftIO $ + boolSystemEnv "sh" [Param "-c", Param command] + =<< hookEnv k f) ( a , do warning $ hook ++ " hook exited nonzero!" @@ -129,14 +134,14 @@ checkPresent r h k = do liftIO $ catchMsgIO $ check v where findkey s = show k `elem` lines s - env = hookEnv k Nothing check Nothing = error "checkpresent hook misconfigured" check (Just hook) = do (frompipe, topipe) <- createPipe pid <- forkProcess $ do _ <- dupTo topipe stdOutput closeFd frompipe - executeFile "sh" True ["-c", hook] env + executeFile "sh" True ["-c", hook] + =<< hookEnv k Nothing closeFd topipe fromh <- fdToHandle frompipe reply <- hGetContentsStrict fromh -- cgit v1.2.3