1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
use anyhow::Result;
use serde::de::DeserializeOwned;
use serde::Serialize;
use serde_bridge::Value;

/// Collector will collect a value which take `V` as template.
///
/// Implementor SHOULD deserialize into `V` directly and then serialize
/// into a [`serde_bridge::Value`] to make value merge possible.
///
/// Take `serde-env` as an example:
///
/// ```ignore
/// #[derive(Debug)]
/// pub struct Environment<V: DeserializeOwned + Serialize + Debug> {
///     phantom: PhantomData<V>,
/// }
///
/// impl<V> Collector<V> for Environment<V>
/// where
///     V: DeserializeOwned + Serialize + Debug,
/// {
///     fn collect(&mut self) -> Result<Value> {
///         let v: V = serde_env::from_env()?;
///         Ok(v.into_value()?)
///     }
/// }
/// ```
pub trait Collector<V: DeserializeOwned + Serialize> {
    fn collect(&mut self) -> Result<Value>;
}

/// It's recommended to implement `IntoCollector` so that it can be used
/// in [`Builder::collect()`][`crate::Builder::collect()`] directly.
pub trait IntoCollector<V: DeserializeOwned + Serialize> {
    fn into_collector(self) -> Box<dyn Collector<V>>;
}