2022-07-22 15:05:10 +03:00
|
|
|
|
# enve
|
2022-07-18 14:36:24 +03:00
|
|
|
|
|
2022-07-24 19:03:52 +03:00
|
|
|
|
[![GitHub Workflow Status](https://img.shields.io/github/workflow/status/pleshevskiy/enve/CI?label=tests&logo=github&style=flat-square)](https://github.com/pleshevskiy/enve/actions/workflows/ci.yml)
|
|
|
|
|
[![docs.rs](https://img.shields.io/docsrs/enve?style=flat-square)](https://docs.rs/enve)
|
|
|
|
|
[![Crates.io](https://img.shields.io/crates/v/enve?style=flat-square)](https://crates.io/crates/enve)
|
|
|
|
|
[![Crates.io](https://img.shields.io/crates/l/enve?style=flat-square)](https://github.com/pleshevskiy/enve/LICENSE)
|
|
|
|
|
[![unsafe forbidden](https://img.shields.io/badge/unsafe-forbidden-success.svg?style=flat-square)](https://github.com/rust-secure-code/safety-dance/)
|
|
|
|
|
[![Matrix](https://img.shields.io/matrix/enve_team:matrix.org?label=matrix&style=flat-square)](https://matrix.to/#/!yZalHbWfGRWOMaetSn:matrix.org?via=matrix.org)
|
2019-12-24 19:37:55 +03:00
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
`enve` helps you work with environment variables and convert it to **any type**
|
|
|
|
|
using only **type annotations**.
|
2019-12-23 15:24:36 +03:00
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
Look at the [examples](https://github.com/pleshevskiy/enve/tree/main/examples)
|
|
|
|
|
to see the power!
|
2019-12-23 15:24:36 +03:00
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
All standard environment variable types are included, but `enve` under the hood
|
|
|
|
|
uses [estring](https://github.com/pleshevskiy/estring), so you can easily create
|
|
|
|
|
your own type.
|
2020-01-10 08:23:06 +03:00
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
## Getting started
|
|
|
|
|
|
|
|
|
|
```rust
|
|
|
|
|
use enve::SepVec;
|
|
|
|
|
|
|
|
|
|
type MinusVec<T> = SepVec<T, '-'>;
|
|
|
|
|
type PlusVec<T> = SepVec<T, '+'>;
|
|
|
|
|
type MulVec<T> = SepVec<T, '*'>;
|
|
|
|
|
|
|
|
|
|
fn main() -> Result<(), enve::Error> {
|
|
|
|
|
enve::sset("E", "10+5*2-3");
|
|
|
|
|
|
|
|
|
|
let res: f32 = enve::get::<PlusVec<MinusVec<MulVec<f32>>>>("E")
|
|
|
|
|
.unwrap()
|
|
|
|
|
.iter()
|
|
|
|
|
.map(|p| {
|
|
|
|
|
p.iter()
|
|
|
|
|
.map(|m| m.iter().product::<f32>())
|
|
|
|
|
.reduce(|acc, v| acc - v)
|
|
|
|
|
.unwrap_or_default()
|
|
|
|
|
})
|
|
|
|
|
.sum::<f32>();
|
|
|
|
|
|
|
|
|
|
println!("result: {}", res);
|
|
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
```
|
2020-01-10 08:23:06 +03:00
|
|
|
|
|
2020-03-12 23:20:34 +03:00
|
|
|
|
## Installation
|
|
|
|
|
|
2022-07-24 18:56:24 +03:00
|
|
|
|
The MSRV is 1.51.0
|
2020-03-12 23:20:34 +03:00
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
Add `enve = { version = "0.1", features = ["prim", "vec"] }` as a dependency in
|
2022-07-18 14:36:24 +03:00
|
|
|
|
`Cargo.toml`.
|
2020-03-12 23:20:34 +03:00
|
|
|
|
|
|
|
|
|
`Cargo.toml` example:
|
|
|
|
|
|
|
|
|
|
```toml
|
|
|
|
|
[package]
|
|
|
|
|
name = "my-crate"
|
|
|
|
|
version = "0.1.0"
|
|
|
|
|
authors = ["Me <user@rust-lang.org>"]
|
|
|
|
|
|
|
|
|
|
[dependencies]
|
2022-07-24 18:53:04 +03:00
|
|
|
|
enve = { version = "0.1", features = ["prim", "vec"] }
|
2020-03-12 23:20:34 +03:00
|
|
|
|
```
|
|
|
|
|
|
2019-12-24 19:37:55 +03:00
|
|
|
|
## License
|
|
|
|
|
|
2022-07-24 18:53:04 +03:00
|
|
|
|
**MIT**. See [LICENSE](https://github.com/pleshevskiy/estring/LICENSE) to see
|
|
|
|
|
the full text.
|
2019-12-24 19:37:55 +03:00
|
|
|
|
|
|
|
|
|
## Contributors
|
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
[pleshevskiy](https://github.com/pleshevskiy) (Dmitriy Pleshevskiy) – creator,
|
|
|
|
|
maintainer.
|