conjure-codegen 0.3.5

Rust code generation for Conjure definitions
Documentation
use conjure_object::serde::ser::SerializeStruct as SerializeStruct_;
use conjure_object::serde::{de, ser};
use std::fmt;
#[derive(Debug, Clone, PartialEq, PartialOrd, Eq, Ord, Hash)]
pub struct TypeName {
    name: String,
    package: String,
}
impl TypeName {
    #[doc = r" Constructs a new instance of the type."]
    #[inline]
    pub fn new<T, U>(name: T, package: U) -> TypeName
    where
        T: Into<String>,
        U: Into<String>,
    {
        TypeName {
            name: name.into(),
            package: package.into(),
        }
    }
    #[doc = r" Returns a new builder."]
    #[inline]
    pub fn builder() -> Builder {
        Default::default()
    }
    #[doc = "The name of the custom Conjure type or service. It must be in UpperCamelCase. Numbers are permitted, but not at the beginning of a word. Allowed names: \"FooBar\", \"XYCoordinate\", \"Build2Request\". Disallowed names: \"fooBar\", \"2BuildRequest\"."]
    #[inline]
    pub fn name(&self) -> &str {
        &*self.name
    }
    #[doc = "A period-delimited string of package names. The package names must be lowercase. Numbers are permitted, but not at the beginning of a package name. Allowed packages: \"foo\", \"com.palantir.bar\", \"com.palantir.foo.thing2\". Disallowed packages: \"Foo\", \"com.palantir.foo.2thing\"."]
    #[inline]
    pub fn package(&self) -> &str {
        &*self.package
    }
}
#[doc = "A builder for the `TypeName` type."]
#[derive(Debug, Clone, Default)]
pub struct Builder {
    name: Option<String>,
    package: Option<String>,
}
impl Builder {
    #[doc = "The name of the custom Conjure type or service. It must be in UpperCamelCase. Numbers are permitted, but not at the beginning of a word. Allowed names: \"FooBar\", \"XYCoordinate\", \"Build2Request\". Disallowed names: \"fooBar\", \"2BuildRequest\"."]
    #[doc = r""]
    #[doc = r" Required."]
    pub fn name<T>(&mut self, name: T) -> &mut Self
    where
        T: Into<String>,
    {
        self.name = Some(name.into());
        self
    }
    #[doc = "A period-delimited string of package names. The package names must be lowercase. Numbers are permitted, but not at the beginning of a package name. Allowed packages: \"foo\", \"com.palantir.bar\", \"com.palantir.foo.thing2\". Disallowed packages: \"Foo\", \"com.palantir.foo.2thing\"."]
    #[doc = r""]
    #[doc = r" Required."]
    pub fn package<T>(&mut self, package: T) -> &mut Self
    where
        T: Into<String>,
    {
        self.package = Some(package.into());
        self
    }
    #[doc = r" Constructs a new instance of the type."]
    #[doc = r""]
    #[doc = r" # Panics"]
    #[doc = r""]
    #[doc = r" Panics if a required field was not set."]
    #[inline]
    pub fn build(&self) -> TypeName {
        TypeName {
            name: self.name.clone().expect("field name was not set"),
            package: self.package.clone().expect("field package was not set"),
        }
    }
}
impl From<TypeName> for Builder {
    #[inline]
    fn from(_v: TypeName) -> Builder {
        Builder {
            name: Some(_v.name),
            package: Some(_v.package),
        }
    }
}
impl ser::Serialize for TypeName {
    fn serialize<S>(&self, s: S) -> Result<S::Ok, S::Error>
    where
        S: ser::Serializer,
    {
        let size = 2usize;
        let mut s = s.serialize_struct("TypeName", size)?;
        s.serialize_field("name", &self.name)?;
        s.serialize_field("package", &self.package)?;
        s.end()
    }
}
impl<'de> de::Deserialize<'de> for TypeName {
    fn deserialize<D>(d: D) -> Result<TypeName, D::Error>
    where
        D: de::Deserializer<'de>,
    {
        d.deserialize_struct("TypeName", &["name", "package"], Visitor_)
    }
}
struct Visitor_;
impl<'de> de::Visitor<'de> for Visitor_ {
    type Value = TypeName;
    fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
        fmt.write_str("map")
    }
    fn visit_map<A>(self, mut map_: A) -> Result<TypeName, A::Error>
    where
        A: de::MapAccess<'de>,
    {
        let mut name = None;
        let mut package = None;
        while let Some(field_) = map_.next_key()? {
            match field_ {
                Field_::Name => name = Some(map_.next_value()?),
                Field_::Package => package = Some(map_.next_value()?),
                Field_::Unknown_ => {
                    map_.next_value::<de::IgnoredAny>()?;
                }
            }
        }
        let name = match name {
            Some(v) => v,
            None => return Err(de::Error::missing_field("name")),
        };
        let package = match package {
            Some(v) => v,
            None => return Err(de::Error::missing_field("package")),
        };
        Ok(TypeName { name, package })
    }
}
enum Field_ {
    Name,
    Package,
    Unknown_,
}
impl<'de> de::Deserialize<'de> for Field_ {
    fn deserialize<D>(d: D) -> Result<Field_, D::Error>
    where
        D: de::Deserializer<'de>,
    {
        d.deserialize_str(FieldVisitor_)
    }
}
struct FieldVisitor_;
impl<'de> de::Visitor<'de> for FieldVisitor_ {
    type Value = Field_;
    fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
        fmt.write_str("string")
    }
    fn visit_str<E>(self, value: &str) -> Result<Field_, E>
    where
        E: de::Error,
    {
        let v = match value {
            "name" => Field_::Name,
            "package" => Field_::Package,
            _ => Field_::Unknown_,
        };
        Ok(v)
    }
}