k8s_openapi/v1_30/apimachinery/pkg/apis/meta/v1/
fields_v1.rs

1// Generated from definition io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1
2
3/// FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format.
4///
5/// Each key is either a '.' representing the field itself, and will always map to an empty set, or a string representing a sub-field or item. The string will follow one of these four formats: 'f:\<name\>', where \<name\> is the name of a field in a struct, or key in a map 'v:\<value\>', where \<value\> is the exact json formatted value of a list item 'i:\<index\>', where \<index\> is position of a item in a list 'k:\<keys\>', where \<keys\> is a map of  a list item's key fields to their unique values If a key maps to an empty Fields value, the field that key represents is part of the set.
6///
7/// The exact format is defined in sigs.k8s.io/structured-merge-diff
8#[derive(Clone, Debug, Default, PartialEq)]
9pub struct FieldsV1(pub crate::serde_json::Value);
10
11impl crate::DeepMerge for FieldsV1 {
12    fn merge_from(&mut self, other: Self) {
13        crate::DeepMerge::merge_from(&mut self.0, other.0);
14    }
15}
16
17impl<'de> crate::serde::Deserialize<'de> for FieldsV1 {
18    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
19        struct Visitor;
20
21        impl<'de> crate::serde::de::Visitor<'de> for Visitor {
22            type Value = FieldsV1;
23
24            fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
25                f.write_str("FieldsV1")
26            }
27
28            fn visit_newtype_struct<D>(self, deserializer: D) -> Result<Self::Value, D::Error> where D: crate::serde::Deserializer<'de> {
29                Ok(FieldsV1(crate::serde::Deserialize::deserialize(deserializer)?))
30            }
31        }
32
33        deserializer.deserialize_newtype_struct("FieldsV1", Visitor)
34    }
35}
36
37impl crate::serde::Serialize for FieldsV1 {
38    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
39        serializer.serialize_newtype_struct("FieldsV1", &self.0)
40    }
41}
42
43#[cfg(feature = "schemars")]
44impl crate::schemars::JsonSchema for FieldsV1 {
45    fn schema_name() -> String {
46        "io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1".to_owned()
47    }
48
49    fn json_schema(__gen: &mut crate::schemars::gen::SchemaGenerator) -> crate::schemars::schema::Schema {
50        crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
51            metadata: Some(Box::new(crate::schemars::schema::Metadata {
52                description: Some("FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format.\n\nEach key is either a '.' representing the field itself, and will always map to an empty set, or a string representing a sub-field or item. The string will follow one of these four formats: 'f:<name>', where <name> is the name of a field in a struct, or key in a map 'v:<value>', where <value> is the exact json formatted value of a list item 'i:<index>', where <index> is position of a item in a list 'k:<keys>', where <keys> is a map of  a list item's key fields to their unique values If a key maps to an empty Fields value, the field that key represents is part of the set.\n\nThe exact format is defined in sigs.k8s.io/structured-merge-diff".to_owned()),
53                ..Default::default()
54            })),
55            instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Object))),
56            ..Default::default()
57        })
58    }
59}