Skip to content

Commit

Permalink
chore(blockifier): remove duplicacy tip() and resource_bounds() in Ac…
Browse files Browse the repository at this point in the history
…countTransaction
  • Loading branch information
avivg-starkware committed Nov 17, 2024
1 parent 3ff0dcf commit ca92528
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 41 deletions.
15 changes: 13 additions & 2 deletions crates/blockifier/src/transaction/account_transaction.rs
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,14 @@ pub struct AccountTransaction {
only_query: bool,
}

macro_rules! implement_tx_getter_calls {
($(($field:ident, $field_type:ty)),*) => {
$(pub fn $field(&self) -> $field_type {
self.tx.$field()
})*
};
}

macro_rules! implement_account_tx_inner_getters {
($(($field:ident, $field_type:ty)),*) => {
$(pub fn $field(&self) -> $field_type {
Expand Down Expand Up @@ -147,13 +155,16 @@ impl AccountTransaction {
implement_account_tx_inner_getters!(
(signature, TransactionSignature),
(nonce, Nonce),
(resource_bounds, ValidResourceBounds),
(tip, Tip),
(nonce_data_availability_mode, DataAvailabilityMode),
(fee_data_availability_mode, DataAvailabilityMode),
(paymaster_data, PaymasterData)
);

implement_tx_getter_calls!(
(resource_bounds, ValidResourceBounds),
(tip, Tip)
);

pub fn new(tx: starknet_api::executable_transaction::AccountTransaction) -> Self {
AccountTransaction { tx, only_query: false }
}
Expand Down
54 changes: 17 additions & 37 deletions crates/starknet_api/src/executable_transaction.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,18 @@ macro_rules! implement_getter_calls {
};
}

macro_rules! implement_account_tx_inner_getters {
($(($field:ident, $field_type:ty)),*) => {
$(pub fn $field(&self) -> $field_type {
match self {
AccountTransaction::Declare(tx) => tx.tx.$field().clone(),
AccountTransaction::DeployAccount(tx) => tx.tx.$field().clone(),
AccountTransaction::Invoke(tx) => tx.tx.$field().clone(),
}
})*
};
}

/// Represents a paid Starknet transaction.
#[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)]
pub enum AccountTransaction {
Expand All @@ -48,6 +60,11 @@ pub enum AccountTransaction {
}

impl AccountTransaction {
implement_account_tx_inner_getters!(
(resource_bounds, ValidResourceBounds),
(tip, Tip)
);

pub fn contract_address(&self) -> ContractAddress {
match self {
AccountTransaction::Declare(tx_data) => tx_data.tx.sender_address(),
Expand Down Expand Up @@ -75,43 +92,6 @@ impl AccountTransaction {
AccountTransaction::Invoke(tx_data) => tx_data.tx_hash,
}
}

// TODO(Mohammad): add a getter macro.
pub fn tip(&self) -> Option<Tip> {
match self {
AccountTransaction::Declare(declare_tx) => match &declare_tx.tx {
crate::transaction::DeclareTransaction::V3(tx_v3) => Some(tx_v3.tip),
_ => None,
},
AccountTransaction::DeployAccount(deploy_account_tx) => match &deploy_account_tx.tx {
crate::transaction::DeployAccountTransaction::V3(tx_v3) => Some(tx_v3.tip),
_ => None,
},
AccountTransaction::Invoke(invoke_tx) => match &invoke_tx.tx {
crate::transaction::InvokeTransaction::V3(tx_v3) => Some(tx_v3.tip),
_ => None,
},
}
}

pub fn resource_bounds(&self) -> Option<&ValidResourceBounds> {
match self {
AccountTransaction::Declare(declare_tx) => match &declare_tx.tx {
crate::transaction::DeclareTransaction::V3(tx_v3) => Some(&tx_v3.resource_bounds),
_ => None,
},
AccountTransaction::DeployAccount(deploy_account_tx) => match &deploy_account_tx.tx {
crate::transaction::DeployAccountTransaction::V3(tx_v3) => {
Some(&tx_v3.resource_bounds)
}
_ => None,
},
AccountTransaction::Invoke(invoke_tx) => match &invoke_tx.tx {
crate::transaction::InvokeTransaction::V3(tx_v3) => Some(&tx_v3.resource_bounds),
_ => None,
},
}
}
}

// TODO: add a converter for Declare transactions as well.
Expand Down
3 changes: 1 addition & 2 deletions crates/starknet_mempool/src/mempool.rs
Original file line number Diff line number Diff line change
Expand Up @@ -320,12 +320,11 @@ impl Mempool {

// TODO(Elin): move to a shared location with other next-gen node crates.
fn tip(tx: &AccountTransaction) -> Tip {
tx.tip().expect("Expected a valid tip value.")
tx.tip()
}

fn max_l2_gas_price(tx: &AccountTransaction) -> GasPrice {
tx.resource_bounds()
.expect("Expected a valid resource bounds value.")
.get_l2_bounds()
.max_price_per_unit
}
Expand Down

0 comments on commit ca92528

Please sign in to comment.