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 InitializeLpPosition {}
#[derive(Debug, Clone, PartialEq)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct InitializeLpPositionInstructionAccounts {
pub plasma_program: solana_pubkey::Pubkey,
pub log_authority: solana_pubkey::Pubkey,
pub pool: solana_pubkey::Pubkey,
pub payer: solana_pubkey::Pubkey,
pub lp_position_owner: solana_pubkey::Pubkey,
pub lp_position: solana_pubkey::Pubkey,
pub system_program: solana_pubkey::Pubkey,
pub remaining: Vec<solana_instruction::AccountMeta>,
}
impl InitializeLpPosition {
pub fn decode(data: &[u8]) -> Option<Self> {
if data.is_empty() {
return None;
}
let discriminator = &data[0..1];
if discriminator != [5] {
return None;
}
let mut data_slice = data;
data_slice = &data_slice[1..];
borsh::BorshDeserialize::deserialize(&mut data_slice).ok()
}
}
impl ArrangeAccounts for InitializeLpPosition {
type ArrangedAccounts = InitializeLpPositionInstructionAccounts;
fn arrange_accounts(
accounts: &[solana_instruction::AccountMeta],
) -> Option<Self::ArrangedAccounts> {
let mut iter = accounts.iter();
let plasma_program = next_account(&mut iter)?;
let log_authority = next_account(&mut iter)?;
let pool = next_account(&mut iter)?;
let payer = next_account(&mut iter)?;
let lp_position_owner = next_account(&mut iter)?;
let lp_position = next_account(&mut iter)?;
let system_program = next_account(&mut iter)?;
let remaining = iter.as_slice();
Some(InitializeLpPositionInstructionAccounts {
plasma_program,
log_authority,
pool,
payer,
lp_position_owner,
lp_position,
system_program,
remaining: remaining.to_vec(),
})
}
}