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