carbon_cargo_decoder/instructions/
update_definition.rs1use crate::types::UpdateDefinitionInput;
3use carbon_core::CarbonDeserialize;
4use carbon_core::account_utils::next_account;
5use carbon_core::borsh;
6use carbon_core::deserialize::ArrangeAccounts;
7use carbon_core::deserialize::CarbonDeserialize;
8
9#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
13#[derive(Debug, Clone, borsh::BorshSerialize, CarbonDeserialize, PartialEq, Eq, Hash)]
14pub struct UpdateDefinition {
15 pub input: UpdateDefinitionInput,
16}
17
18#[derive(Debug, Clone, PartialEq)]
19#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
20pub struct UpdateDefinitionInstructionAccounts {
21 pub key: solana_pubkey::Pubkey,
22 pub profile: solana_pubkey::Pubkey,
23 pub stats_definition: solana_pubkey::Pubkey,
24 pub remaining: Vec<solana_instruction::AccountMeta>,
25}
26
27impl UpdateDefinition {
28 pub fn decode(data: &[u8]) -> Option<Self> {
29 if data.len() < 8 {
30 return None;
31 }
32 let discriminator = &data[0..8];
33 if discriminator != &[153, 186, 206, 218, 233, 87, 179, 150] {
34 return None;
35 }
36
37 let data_slice = data;
38
39 let data_slice = &data_slice[8..];
40
41 Self::deserialize(data_slice)
42 }
43}
44
45impl ArrangeAccounts for UpdateDefinition {
46 type ArrangedAccounts = UpdateDefinitionInstructionAccounts;
47
48 fn arrange_accounts(
49 accounts: &[solana_instruction::AccountMeta],
50 ) -> Option<Self::ArrangedAccounts> {
51 let mut iter = accounts.iter();
52
53 let key = next_account(&mut iter)?;
54 let profile = next_account(&mut iter)?;
55 let stats_definition = next_account(&mut iter)?;
56
57 let remaining = iter.as_slice();
58
59 Some(UpdateDefinitionInstructionAccounts {
60 key,
61 profile,
62 stats_definition,
63 remaining: remaining.to_vec(),
64 })
65 }
66}