pub fn encode_burn_with_amount_script_function(
    token: TypeTag,
    sliding_nonce: u64,
    preburn_address: AccountAddress,
    amount: u64
) -> TransactionPayloadExpand description
Summary
Burns the coins held in a preburn resource in the preburn queue at the
specified preburn address, which are equal to the amount specified in the
transaction. Finds the first relevant outstanding preburn request with
matching amount and removes the contained coins from the system. The sending
account must be the Treasury Compliance account.
The account that holds the preburn queue resource will normally be a Designated
Dealer, but there are no enforced requirements that it be one.
Technical Description
This transaction permanently destroys all the coins of Token type
stored in the Diem::Preburn<Token> resource published under the
preburn_address account address.
This transaction will only succeed if the sending account has a
Diem::BurnCapability<Token>, and a Diem::Preburn<Token> resource
exists under preburn_address, with a non-zero to_burn field. After the successful execution
of this transaction the total_value field in the
Diem::CurrencyInfo<Token> resource published under 0xA550C18 will be
decremented by the value of the to_burn field of the preburn resource
under preburn_address immediately before this transaction, and the
to_burn field of the preburn resource will have a zero value.
Events
The successful execution of this transaction will emit a Diem::BurnEvent on the event handle
held in the Diem::CurrencyInfo<Token> resource’s burn_events published under
0xA550C18.
Parameters
| Name | Type | Description | 
|---|---|---|
| Token | Type | The Move type for the Tokencurrency being burned.Tokenmust be an already-registered currency on-chain. | 
| tc_account | signer | The signer of the sending account of this transaction, must have a burn capability for Tokenpublished under it. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| preburn_address | address | The address where the coins to-be-burned are currently held. | 
| amount | u64 | The amount to be burned. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_CAPABILITY | Diem::EBURN_CAPABILITY | The sending accountdoes not have aDiem::BurnCapability<Token>published under it. | 
| Errors::INVALID_STATE | Diem::EPREBURN_NOT_FOUND | The Diem::PreburnQueue<Token>resource underpreburn_addressdoes not contain a preburn request with a value matchingamount. | 
| Errors::NOT_PUBLISHED | Diem::EPREBURN_QUEUE | The account at preburn_addressdoes not have aDiem::PreburnQueue<Token>resource published under it. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The specified Tokenis not a registered currency on-chain. | 
Related Scripts
- TreasuryComplianceScripts::burn_txn_fees
- TreasuryComplianceScripts::cancel_burn_with_amount
- TreasuryComplianceScripts::preburn