use carbon_core::{account_utils::next_account, deserialize::ArrangeAccounts};
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
#[derive(Debug, Clone, borsh::BorshSerialize, borsh::BorshDeserialize, PartialEq)]
pub struct Create {}
#[derive(Debug, Clone, PartialEq)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct CreateInstructionAccounts {
pub funder: solana_pubkey::Pubkey,
pub associated_token_account: solana_pubkey::Pubkey,
pub wallet: solana_pubkey::Pubkey,
pub mint: solana_pubkey::Pubkey,
pub system_program: solana_pubkey::Pubkey,
pub token_program: solana_pubkey::Pubkey,
pub remaining: Vec<solana_instruction::AccountMeta>,
}
impl Create {
pub fn decode(data: &[u8]) -> Option<Self> {
if data.is_empty() {
return None;
}
let discriminator = &data[0..1];
if discriminator != [0] {
return None;
}
let mut data_slice = data;
data_slice = &data_slice[1..];
borsh::BorshDeserialize::deserialize(&mut data_slice).ok()
}
}
impl ArrangeAccounts for Create {
type ArrangedAccounts = CreateInstructionAccounts;
fn arrange_accounts(
accounts: &[solana_instruction::AccountMeta],
) -> Option<Self::ArrangedAccounts> {
let mut iter = accounts.iter();
let funder = next_account(&mut iter)?;
let associated_token_account = next_account(&mut iter)?;
let wallet = next_account(&mut iter)?;
let mint = next_account(&mut iter)?;
let system_program = next_account(&mut iter)?;
let token_program = next_account(&mut iter)?;
let remaining = iter.as_slice();
Some(CreateInstructionAccounts {
funder,
associated_token_account,
wallet,
mint,
system_program,
token_program,
remaining: remaining.to_vec(),
})
}
}