#[derive(
Clone,
Default,
PartialEq,
serde::Deserialize,
serde::Serialize,
std::fmt::Debug
)]
#[serde(rename_all = "camelCase", deny_unknown_fields)]
pub struct BasicDeviceAc {
#[serde(skip_serializing_if = "Option::is_none")]
pub all_nodes: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
pub attributes: Option<
std::collections::BTreeMap<
std::string::String,
<::k8s_openapi027::api::resource::v1alpha3::DeviceAttribute as crate::Optionable>::Optioned,
>,
>,
#[serde(skip_serializing_if = "Option::is_none")]
pub capacity: Option<
std::collections::BTreeMap<
std::string::String,
<::k8s_openapi027::apimachinery::pkg::api::resource::Quantity as crate::Optionable>::Optioned,
>,
>,
#[serde(skip_serializing_if = "Option::is_none")]
pub consumes_counters: Option<
std::vec::Vec<
<::k8s_openapi027::api::resource::v1alpha3::DeviceCounterConsumption as crate::Optionable>::Optioned,
>,
>,
#[serde(skip_serializing_if = "Option::is_none")]
pub node_name: Option<std::string::String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub node_selector: Option<
<::k8s_openapi027::api::core::v1::NodeSelector as crate::Optionable>::Optioned,
>,
#[serde(skip_serializing_if = "Option::is_none")]
pub taints: Option<
std::vec::Vec<
<::k8s_openapi027::api::resource::v1alpha3::DeviceTaint as crate::Optionable>::Optioned,
>,
>,
}
#[automatically_derived]
impl crate::Optionable for k8s_openapi027::api::resource::v1alpha3::BasicDevice {
type Optioned = BasicDeviceAc;
}
#[automatically_derived]
impl crate::Optionable for BasicDeviceAc {
type Optioned = BasicDeviceAc;
}
#[automatically_derived]
#[cfg(feature = "k8s_openapi_convert")]
impl crate::OptionableConvert for k8s_openapi027::api::resource::v1alpha3::BasicDevice {
fn into_optioned(self) -> BasicDeviceAc {
BasicDeviceAc {
all_nodes: self.all_nodes,
attributes: crate::OptionableConvert::into_optioned(self.attributes),
capacity: crate::OptionableConvert::into_optioned(self.capacity),
consumes_counters: crate::OptionableConvert::into_optioned(
self.consumes_counters,
),
node_name: self.node_name,
node_selector: crate::OptionableConvert::into_optioned(self.node_selector),
taints: crate::OptionableConvert::into_optioned(self.taints),
}
}
fn try_from_optioned(value: BasicDeviceAc) -> Result<Self, crate::Error> {
Ok(Self {
all_nodes: value.all_nodes,
attributes: crate::OptionableConvert::try_from_optioned(value.attributes)?,
capacity: crate::OptionableConvert::try_from_optioned(value.capacity)?,
consumes_counters: crate::OptionableConvert::try_from_optioned(
value.consumes_counters,
)?,
node_name: value.node_name,
node_selector: crate::OptionableConvert::try_from_optioned(
value.node_selector,
)?,
taints: crate::OptionableConvert::try_from_optioned(value.taints)?,
})
}
fn merge(&mut self, other: BasicDeviceAc) -> Result<(), crate::Error> {
if self.all_nodes.is_none() {
self.all_nodes = crate::OptionableConvert::try_from_optioned(
other.all_nodes,
)?;
} else if let Some(self_value) = self.all_nodes.as_mut()
&& let Some(other_value) = other.all_nodes
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.attributes.is_none() {
self.attributes = crate::OptionableConvert::try_from_optioned(
other.attributes,
)?;
} else if let Some(self_value) = self.attributes.as_mut()
&& let Some(other_value) = other.attributes
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.capacity.is_none() {
self.capacity = crate::OptionableConvert::try_from_optioned(other.capacity)?;
} else if let Some(self_value) = self.capacity.as_mut()
&& let Some(other_value) = other.capacity
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.consumes_counters.is_none() {
self.consumes_counters = crate::OptionableConvert::try_from_optioned(
other.consumes_counters,
)?;
} else if let Some(self_value) = self.consumes_counters.as_mut()
&& let Some(other_value) = other.consumes_counters
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.node_name.is_none() {
self.node_name = crate::OptionableConvert::try_from_optioned(
other.node_name,
)?;
} else if let Some(self_value) = self.node_name.as_mut()
&& let Some(other_value) = other.node_name
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.node_selector.is_none() {
self.node_selector = crate::OptionableConvert::try_from_optioned(
other.node_selector,
)?;
} else if let Some(self_value) = self.node_selector.as_mut()
&& let Some(other_value) = other.node_selector
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
if self.taints.is_none() {
self.taints = crate::OptionableConvert::try_from_optioned(other.taints)?;
} else if let Some(self_value) = self.taints.as_mut()
&& let Some(other_value) = other.taints
{
crate::OptionableConvert::merge(self_value, other_value)?;
}
Ok(())
}
}
#[automatically_derived]
#[cfg(feature = "k8s_openapi_convert")]
impl crate::OptionedConvert<k8s_openapi027::api::resource::v1alpha3::BasicDevice>
for BasicDeviceAc {
fn from_optionable(
value: k8s_openapi027::api::resource::v1alpha3::BasicDevice,
) -> Self {
crate::OptionableConvert::into_optioned(value)
}
fn try_into_optionable(
self,
) -> Result<k8s_openapi027::api::resource::v1alpha3::BasicDevice, crate::Error> {
crate::OptionableConvert::try_from_optioned(self)
}
fn merge_into(
self,
other: &mut k8s_openapi027::api::resource::v1alpha3::BasicDevice,
) -> Result<(), crate::Error> {
crate::OptionableConvert::merge(other, self)
}
}