k8s_openapi/v1_34/apimachinery/pkg/apis/meta/v1/
fields_v1.rs1#[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 core::fmt::Formatter<'_>) -> core::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() -> std::borrow::Cow<'static, str> {
46 "io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1".into()
47 }
48
49 fn json_schema(__gen: &mut crate::schemars::SchemaGenerator) -> crate::schemars::Schema {
50 crate::schemars::json_schema!({
51 "description": "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",
52 "type": "object",
53 })
54 }
55}