casper_types/execution/
transform.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
use alloc::vec::Vec;

#[cfg(feature = "datasize")]
use datasize::DataSize;
#[cfg(feature = "json-schema")]
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
use tracing::error;

use super::TransformKindV2;
use crate::{
    bytesrepr::{self, FromBytes, ToBytes},
    Key,
};

/// A transformation performed while executing a deploy.
#[derive(Clone, Eq, PartialEq, Serialize, Deserialize, Debug)]
#[cfg_attr(feature = "datasize", derive(DataSize))]
#[cfg_attr(feature = "json-schema", derive(JsonSchema))]
#[serde(deny_unknown_fields)]
pub struct TransformV2 {
    key: Key,
    kind: TransformKindV2,
}

impl TransformV2 {
    /// Constructs a new `Transform`.
    pub fn new(key: Key, kind: TransformKindV2) -> Self {
        TransformV2 { key, kind }
    }

    /// Returns the key whose value was transformed.
    pub fn key(&self) -> &Key {
        &self.key
    }

    /// Returns the transformation kind.
    pub fn kind(&self) -> &TransformKindV2 {
        &self.kind
    }

    /// Consumes `self`, returning its constituent parts.
    pub fn destructure(self) -> (Key, TransformKindV2) {
        (self.key, self.kind)
    }
}

impl ToBytes for TransformV2 {
    fn to_bytes(&self) -> Result<Vec<u8>, bytesrepr::Error> {
        let mut buffer = bytesrepr::allocate_buffer(self)?;
        self.write_bytes(&mut buffer)?;
        Ok(buffer)
    }

    fn serialized_length(&self) -> usize {
        self.key.serialized_length() + self.kind.serialized_length()
    }

    fn write_bytes(&self, writer: &mut Vec<u8>) -> Result<(), bytesrepr::Error> {
        self.key.write_bytes(writer)?;
        if let Err(err) = self.kind.write_bytes(writer) {
            error!(%err, "ToBytes for TransformV2");
            Err(err)
        } else {
            Ok(())
        }
    }
}

impl FromBytes for TransformV2 {
    fn from_bytes(bytes: &[u8]) -> Result<(Self, &[u8]), bytesrepr::Error> {
        let (key, remainder) = match Key::from_bytes(bytes) {
            Ok((k, rem)) => (k, rem),
            Err(err) => {
                error!(%err, "FromBytes for TransformV2: key");
                return Err(err);
            }
        };
        let (transform, remainder) = match TransformKindV2::from_bytes(remainder) {
            Ok((tk, rem)) => (tk, rem),
            Err(err) => {
                error!(%err, "FromBytes for TransformV2: transform");
                return Err(err);
            }
        };
        let transform_entry = TransformV2 {
            key,
            kind: transform,
        };
        Ok((transform_entry, remainder))
    }
}