carbon_token_2022_decoder/instructions/
initialize_non_transferable_mint.rs1use carbon_core::account_utils::next_account;
8use carbon_core::borsh;
9use carbon_core::deserialize::ArrangeAccounts;
10use carbon_core::deserialize::CarbonDeserialize;
11use carbon_core::CarbonDeserialize;
12
13#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
17#[derive(Debug, Clone, borsh::BorshSerialize, CarbonDeserialize, PartialEq)]
18pub struct InitializeNonTransferableMint {}
19
20#[derive(Debug, Clone, PartialEq)]
21#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
22pub struct InitializeNonTransferableMintInstructionAccounts {
23 pub mint: solana_pubkey::Pubkey,
24 pub remaining: Vec<solana_instruction::AccountMeta>,
25}
26
27impl InitializeNonTransferableMint {
28 pub fn decode(data: &[u8]) -> Option<Self> {
29 if data.is_empty() {
30 return None;
31 }
32 let discriminator = &data[0..1];
33 if discriminator != [32] {
34 return None;
35 }
36
37 let data_slice = data;
38
39 let data_slice = &data_slice[1..];
40
41 Self::deserialize(data_slice)
42 }
43}
44
45impl ArrangeAccounts for InitializeNonTransferableMint {
46 type ArrangedAccounts = InitializeNonTransferableMintInstructionAccounts;
47
48 fn arrange_accounts(
49 accounts: &[solana_instruction::AccountMeta],
50 ) -> Option<Self::ArrangedAccounts> {
51 let mut iter = accounts.iter();
52
53 let mint = next_account(&mut iter)?;
54
55 let remaining = iter.as_slice();
56
57 Some(InitializeNonTransferableMintInstructionAccounts {
58 mint,
59 remaining: remaining.to_vec(),
60 })
61 }
62}