git-annex/Utility/Env/Set.hs

50 lines
1 KiB
Haskell
Raw Normal View History

{- portable environment variables
-
- Copyright 2013 Joey Hess <id@joeyh.name>
-
- License: BSD-2-clause
-}
{-# LANGUAGE CPP #-}
module Utility.Env.Set (
setEnv,
unsetEnv,
legalInEnvVar,
) where
#ifdef mingw32_HOST_OS
import qualified System.SetEnv
2018-01-04 18:23:11 +00:00
import Utility.Env
#else
import qualified System.Posix.Env as PE
#endif
import Data.Char
{- Sets an environment variable. To overwrite an existing variable,
- overwrite must be True.
-
- On Windows, setting a variable to "" unsets it. -}
setEnv :: String -> String -> Bool -> IO ()
#ifndef mingw32_HOST_OS
setEnv var val overwrite = PE.setEnv var val overwrite
#else
setEnv var val True = System.SetEnv.setEnv var val
setEnv var val False = do
r <- getEnv var
case r of
Nothing -> setEnv var val True
Just _ -> return ()
#endif
unsetEnv :: String -> IO ()
#ifndef mingw32_HOST_OS
unsetEnv = PE.unsetEnv
#else
unsetEnv = System.SetEnv.unsetEnv
#endif
legalInEnvVar :: Char -> Bool
legalInEnvVar '_' = True
legalInEnvVar c = isAsciiLower c || isAsciiUpper c || (isNumber c && isAscii c)