utf8-env-0.1: UTF-8 aware substitutes for functions in System.Environment

PortabilityGHC, Unix
Stabilityexperimental
Maintainergolubovsky@gmail.com

System.Environment.UTF8

Description

Miscellaneous information about the system environment, assuming it was encoded in UTF-8. To be used as a drop-in replacement for System.Environment

Synopsis

Documentation

getArgs :: IO [String]Source

Computation getArgs returns a list of the program's command line arguments (not including the program name).

getProgName :: IO StringSource

Computation getProgName returns the name of the program as it was invoked.

However, this is hard-to-impossible to implement on some non-Unix OSes, so instead, for maximum portability, we just return the leafname of the program as invoked. Even then there are some differences between platforms: on Windows, for example, a program invoked as foo is probably really FOO.EXE, and that is what getProgName will return.

getEnv :: String -> IO StringSource

Computation getEnv var returns the value of the environment variable var.

This computation may fail with:

  • System.IO.Error.isDoesNotExistError if the environment variable does not exist.

withArgs :: [String] -> IO a -> IO aSource

withArgs args act - while executing action act, have getArgs return args.

withProgName :: String -> IO a -> IO aSource

withProgName name act - while executing action act, have getProgName return name.

getEnvironment :: IO [(String, String)]Source

getEnvironment retrieves the entire environment as a list of (key,value) pairs.

If an environment entry does not contain an '=' character, the key is the whole entry and the value is the empty string.