Skip to content

Commit

Permalink
Fix 'Env::raw()' doc example comments.
Browse files Browse the repository at this point in the history
Resolves #118.
  • Loading branch information
SergioBenitez committed Aug 17, 2024
1 parent c730bdf commit d76dc92
Showing 1 changed file with 33 additions and 9 deletions.
42 changes: 33 additions & 9 deletions src/providers/env.rs
Original file line number Diff line number Diff line change
Expand Up @@ -238,30 +238,54 @@ impl Env {
/// considered.
///
/// ```rust
/// # use std::collections::BTreeMap;
/// # use figment::util::map;
/// use figment::{Jail, providers::Env};
///
/// Jail::expect_with(|jail| {
/// jail.set_env("FOO_FOO", 100);
/// jail.set_env("BAR_FOO", "hi");
/// jail.set_env("foobar", "hi");
/// jail.set_env("foo_bar", "hey");
///
/// // This is like `prefixed("foo_")` without the filtering.
/// let env = Env::raw().map(|k| match k.starts_with("foo_") {
/// true => k["foo_".len()..].into(),
/// false => k.into()
/// let env = Env::raw()
/// .map(|k| match k.starts_with("foo_") {
/// true => k["foo_".len()..].into(),
/// false => k.into()
/// });
///
/// // We now have `FOO=100`, `BAR_FOO=hi`, and `bar=hey`.
/// # /* Don't actually do this as it'll include lots of other values.
/// let values = env.iter().collect::<BTreeMap<_, _>>();
/// # */
/// # let values = env.iter()
/// # .filter(|(k, _)| k.starts_with("foo") || k.starts_with("bar"))
/// # .collect::<BTreeMap<_, _>>();
/// assert_eq!(values, map! {
/// "FOO".into() => "100".into(),
/// "BAR_FOO".into() => "hi".into(),
/// "bar".into() => "hey".into(),
/// });
///
/// // We now have `FOO=100`, `BAR_FOO=hi`, and `bar=hi`.
/// assert_eq!(env.clone().filter(|k| k == "foo").iter().count(), 1);
///
/// // Mappings chain, like iterator adapters.
/// let env = env.map(|k| match k.starts_with("bar_") {
/// true => k["bar_".len()..].into(),
/// false => k.into()
/// });
///
/// // We now have `FOO=100`, `FOO=hi`, and `bar=hi`.
/// assert_eq!(env.filter(|k| k == "foo").iter().count(), 2);
/// // We now have `FOO=100`, `FOO=hi`, and `bar=hey`.
/// # /* Don't actually do this as it'll include lots of other values.
/// let values = env.iter().collect::<BTreeMap<_, _>>();
/// # */
/// # let values = env.iter()
/// # .filter(|(k, _)| k.starts_with("foo") || k.starts_with("bar"))
/// # .collect::<BTreeMap<_, _>>();
/// assert_eq!(values, map! {
/// "FOO".into() => "100".into(),
/// "FOO".into() => "hi".into(),
/// "bar".into() => "hey".into(),
/// });
///
/// Ok(())
/// });
/// ```
Expand Down

0 comments on commit d76dc92

Please sign in to comment.