Skip to content

Commit

Permalink
Fix ScriptContext PlutusData serialiser
Browse files Browse the repository at this point in the history
  • Loading branch information
szg251 committed Apr 16, 2024
1 parent 9929f8e commit c977269
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 8 deletions.
8 changes: 4 additions & 4 deletions plutus-ledger-api/src/v1/transaction.rs
Expand Up @@ -442,25 +442,25 @@ impl IsPlutusData for TransactionInfo {
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[cfg_attr(feature = "lbf", derive(Json))]
pub struct ScriptContext {
pub purpose: ScriptPurpose,
pub tx_info: TransactionInfo,
pub purpose: ScriptPurpose,
}

impl IsPlutusData for ScriptContext {
fn to_plutus_data(&self) -> PlutusData {
PlutusData::Constr(
BigInt::from(0),
vec![self.purpose.to_plutus_data(), self.tx_info.to_plutus_data()],
vec![self.tx_info.to_plutus_data(), self.purpose.to_plutus_data()],
)
}

fn from_plutus_data(data: &PlutusData) -> Result<Self, PlutusDataError> {
let fields = parse_constr_with_tag(data, 0)?;
let [purpose, tx_info] = parse_fixed_len_constr_fields(fields)?;
let [tx_info, purpose] = parse_fixed_len_constr_fields(fields)?;

Ok(Self {
purpose: IsPlutusData::from_plutus_data(purpose)?,
tx_info: IsPlutusData::from_plutus_data(tx_info)?,
purpose: IsPlutusData::from_plutus_data(purpose)?,
})
}
}
8 changes: 4 additions & 4 deletions plutus-ledger-api/src/v2/transaction.rs
Expand Up @@ -195,25 +195,25 @@ impl IsPlutusData for TransactionInfo {
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[cfg_attr(feature = "lbf", derive(Json))]
pub struct ScriptContext {
pub purpose: ScriptPurpose,
pub tx_info: TransactionInfo,
pub purpose: ScriptPurpose,
}

impl IsPlutusData for ScriptContext {
fn to_plutus_data(&self) -> PlutusData {
PlutusData::Constr(
BigInt::from(0),
vec![self.purpose.to_plutus_data(), self.tx_info.to_plutus_data()],
vec![self.tx_info.to_plutus_data(), self.purpose.to_plutus_data()],
)
}

fn from_plutus_data(data: &PlutusData) -> Result<Self, PlutusDataError> {
let fields = parse_constr_with_tag(data, 0)?;
let [purpose, tx_info] = parse_fixed_len_constr_fields(fields)?;
let [tx_info, purpose] = parse_fixed_len_constr_fields(fields)?;

Ok(Self {
purpose: IsPlutusData::from_plutus_data(purpose)?,
tx_info: IsPlutusData::from_plutus_data(tx_info)?,
purpose: IsPlutusData::from_plutus_data(purpose)?,
})
}
}

0 comments on commit c977269

Please sign in to comment.