envparse: Parse environment variables

[ bsd3, library, system ] [ Propose Tags ]
Versions 0.1.0, 0.2.0, 0.2.1, 0.2.2, 0.3.0, 0.3.1, 0.3.2, 0.3.3, 0.4
Change log CHANGELOG.markdown
Dependencies base (>=4.6 && <5), containers [details]
License BSD-3-Clause
Copyright 2015 Matvey Aksenov
Author Matvey Aksenov
Maintainer matvey.aksenov@gmail.com
Category System
Home page https://supki.github.io/envparse
Source repo head: git clone https://github.com/supki/envparse
this: git clone https://github.com/supki/envparse(tag 0.4)
Uploaded by MatveyAksenov at Sat May 28 15:49:18 UTC 2016
Distributions LTSHaskell:0.4, NixOS:0.4, openSUSE:0.4
Downloads 2171 total (33 in the last 30 days)
Rating (no votes yet) [estimated by rule of succession]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2016-05-28 [all 1 reports]
Hackage Matrix CI

Here's a simple example of a program that uses envparse's parser:

module Main (main) where

import Control.Monad (unless)
import Env

data Hello = Hello { name :: String, quiet :: Bool }

hello :: IO Hello
hello = Env.parse (header "envparse example") $
  Hello <$> var (str <=< nonempty) "NAME"  (help "Target for the greeting")
        <*> switch                 "QUIET" (help "Whether to actually print the greeting")
main :: IO ()
main = do
  Hello {name, quiet} <- hello
  unless quiet $
    putStrLn ("Hello, " ++ name ++ "!")

The NAME environment variable is mandatory and contains the name of the person to greet. QUIET, on the other hand, is an optional boolean flag, false by default, that decides whether the greeting should be silent.

If the NAME variable is undefined in the environment then running the program will result in the following help text:

envparse example
Available environment variables:
  NAME                   Target for the greeting
  QUIET                  Whether to actually print the
Parsing errors:
  NAME is unset

[Skip to Readme]




Maintainer's Corner

For package maintainers and hackage trustees

Readme for envparse-0.4

[back to package description]


Hackage Build Status

optparse-applicative, but for environment variables

See example/Main.hs for an executable example