Previously , we mentioned that a contract call might require you to manually specify external contracts or variable outputs.
However, the SDK always automatically estimates these dependencies and double-checks if everything is in order whenever you invoke a contract function or attempt to send a transaction.
The SDK uses the estimateTxDependencies
helper function to set any missing dependencies identified during the estimation process. This requires simulating the transaction a few times in the background.
async sendTransaction(
transactionRequestLike: TransactionRequestLike
): Promise<TransactionResponse> {
const transactionRequest = transactionRequestify(transactionRequestLike);
this.#cacheInputs(transactionRequest.inputs);
await this.estimateTxDependencies(transactionRequest);
While relying on the SDK's automatic estimation is a decent default behavior, we recommend manually specifying the dependencies if they are known in advance to avoid the performance impact of the estimation process.
Was this page helpful?