Skip to content

Latest commit

 

History

History
51 lines (42 loc) · 1.99 KB

README.md

File metadata and controls

51 lines (42 loc) · 1.99 KB

menv

This crate provides a macro (require_envs!) for asserting the presence of a list of environment variables and accessing them as types which implement FromStr.

Generate the following:

  • A function which asserts the presence and well-formedness of a list of env vars
  • A function which returns a bool representing whether any of the required vars are set
  • A function which returns a String representing the collected help messages for the list of vars
  • A list of functions, one for each environment variable required, which parse and return the associated env var

Example

Here we fill an env module with required environment variables, print help and exit if none of them are set, runs the asserts for them if some are set, and proceeds.

Other parts of this program are now free, since the asserts were run at the start of main, to access env::server_port() and env::db_path() as if they are infallible.

The getter function name can be suffixed with ? to make an env var optional. In this example, plugin_dir's return type is Option<String>.

mod env {
    use menv::require_envs;
    require_envs! {
        (assert_env_vars, any_set, gen_help);

        server_port, "FERRISCRAFT_USERS_PORT", u16,
        "FERRISCRAFT_USERS_PORT should be set to the desired server port";

        db_path, "FERRISCRAFT_USERS_DB", String,
        "FERRISCRAFT_USERS_DB should be set to the path to the users database";

        plugin_dir?, "XLANG_PLUGIN_DIR", String,
        "XLANG_PLUGIN_DIR, if set, overrides the directory that lccc looks for xlang plugins";
    }
}
fn main() {
   if env::any_set() {
        env::assert_env_vars();
    } else {
        println!("# Environment Variables Help\n{}", env::gen_help());
        return
    }
}

MSRV

This crate is tested with the latest stable version of Rust. It probably works with many earlier ones, but I do not promise that it will in perpetuity.

I will revisit this policy at 1.0.