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