2022-12-06 22:58:51 +00:00
|
|
|
use serde::{Deserialize, Serialize, Serializer};
|
2021-08-17 08:55:08 +00:00
|
|
|
|
|
|
|
/// A utility type that can represent the presence of either a single associated
|
|
|
|
/// value or a list of those. Adding absence can be achieved by wrapping the type
|
|
|
|
/// in an [Option]
|
|
|
|
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
|
|
|
|
#[serde(untagged)]
|
|
|
|
pub enum OneOrMany<T> {
|
|
|
|
#[serde(serialize_with = "list")]
|
|
|
|
One(T),
|
|
|
|
Many(Vec<T>),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> OneOrMany<T> {
|
|
|
|
pub fn into_list(self) -> Vec<T> {
|
|
|
|
match self {
|
|
|
|
OneOrMany::One(one) => vec![one],
|
|
|
|
OneOrMany::Many(many) => many,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// A utility type that flattens lists of lists as seen with `maintainers` and `platforms` on selected packages
|
|
|
|
/// in an [Option]
|
|
|
|
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
|
|
|
|
#[serde(untagged)]
|
|
|
|
pub enum Flatten<T> {
|
|
|
|
#[serde(serialize_with = "list")]
|
|
|
|
Single(T),
|
|
|
|
Deep(Vec<Flatten<T>>),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T: Clone> Flatten<T> {
|
|
|
|
pub fn flatten(self) -> Vec<T> {
|
|
|
|
match self {
|
|
|
|
Flatten::Single(s) => vec![s],
|
|
|
|
Flatten::Deep(v) => v.into_iter().map(Flatten::flatten).flatten().collect(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-27 17:37:52 +00:00
|
|
|
impl<T> Default for Flatten<T> {
|
|
|
|
fn default() -> Self {
|
|
|
|
Flatten::Deep(Vec::new())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-17 08:55:08 +00:00
|
|
|
// TODO: use this or a to_ist function?
|
|
|
|
/// Serialization helper that serializes single elements as a list with a single
|
|
|
|
/// item
|
|
|
|
pub fn list<T, S>(item: &T, s: S) -> Result<S::Ok, S::Error>
|
|
|
|
where
|
|
|
|
T: Serialize,
|
|
|
|
S: Serializer,
|
|
|
|
{
|
|
|
|
s.collect_seq(vec![item].iter())
|
|
|
|
}
|