Module sui::balance
A storable handler for Balances in general. Is used in the Coin
module to allow balance operations and can be used to implement
custom coins with 
SupplyBalance- Struct Supply
- Struct Balance
- Constants
- Function value
- Function supply_value
- Function create_supply
- Function increase_supply
- Function decrease_supply
- Function zero
- Function join
- Function split
- Function withdraw_all
- Function destroy_zero
- Function send_funds
- Function redeem_funds
- Function withdraw_funds_from_object
- Function create_supply_internal
- Function create_staking_rewards
- Function destroy_storage_rebates
- Function destroy_supply
- Function send_to_account
- Function withdraw_from_account
use std::address;
use std::ascii;
use std::bcs;
use std::option;
use std::string;
use std::type_name;
use std::vector;
use sui::accumulator;
use sui::address;
use sui::dynamic_field;
use sui::funds_accumulator;
use sui::hex;
use sui::object;
use sui::party;
use sui::transfer;
use sui::tx_context;
use sui::vec_map;
Struct Supply
A Supply of T. Used for minting and burning.
Wrapped into a TreasuryCap in the Coin module.
public struct Supply<phantom T> has store
Fields
- 
value: u64
Struct Balance
Storable balance - an inner struct of a Coin type. Can be used to store coins which don't need the key ability.
public struct Balance<phantom T> has store
Fields
- 
value: u64
Constants
For when trying to destroy a non-zero balance.
const ENonZero: u64 = 0;
For when an overflow is happening on Supply operations.
const EOverflow: u64 = 1;
For when trying to withdraw more than there is.
const ENotEnough: u64 = 2;
Sender is not @0x0 the system address.
const ENotSystemAddress: u64 = 3;
System operation performed for a coin other than SUI
const ENotSUI: u64 = 4;
const SUI_TYPE_NAME: vector<u8> = vector[48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 50, 58, 58, 115, 117, 105, 58, 58, 83, 85, 73];
Function value
Get the amount stored in a
Balancepublic fun value<T>(self: &sui::balance::Balance<T>): u64
Function supply_value
Get the
Supplypublic fun supply_value<T>(supply: &sui::balance::Supply<T>): u64
Implementation
public fun supply_value<T>(supply: &Supply<T>): u64 {
    supply.value
}
Function create_supply
Create a new supply for type T.
public fun create_supply<T: drop>(_: T): sui::balance::Supply<T>
Implementation
public fun create_supply<T: drop>(_: T): Supply<T> {
    Supply { value: 0 }
}
Function increase_supply
Increase supply by
valueBalance<T>public fun increase_supply<T>(self: &mut sui::balance::Supply<T>, value: u64): sui::balance::Balance<T>
Function decrease_supply
Burn a Balance
public fun decrease_supply<T>(self: &mut sui::balance::Supply<T>, balance: sui::balance::Balance<T>): u64
Function zero
Create a zero
BalanceT.
public fun zero<T>(): sui::balance::Balance<T>
Function join
Join two balances together.
public fun join<T>(self: &mut sui::balance::Balance<T>, balance: sui::balance::Balance<T>): u64
Function split
Split a
Balancepublic fun split<T>(self: &mut sui::balance::Balance<T>, value: u64): sui::balance::Balance<T>
Function withdraw_all
Withdraw all balance. After this the remaining balance must be 0.
public fun withdraw_all<T>(self: &mut sui::balance::Balance<T>): sui::balance::Balance<T>
Function destroy_zero
Destroy a zero
Balancepublic fun destroy_zero<T>(balance: sui::balance::Balance<T>)
Function send_funds
Send a
Balancepublic(package) fun send_funds<T>(balance: sui::balance::Balance<T>, recipient: address)
Implementation
public(package) fun send_funds<T>(balance: Balance<T>, recipient: address) {
    sui::funds_accumulator::add_impl(balance, recipient);
}
Function redeem_funds
Redeem a
Withdrawal<Balance<T>>Balance<T>public(package) fun redeem_funds<T>(withdrawal: sui::funds_accumulator::Withdrawal<sui::balance::Balance<T>>): sui::balance::Balance<T>
Implementation
public(package) fun redeem_funds<T>(
    withdrawal: sui::funds_accumulator::Withdrawal<Balance<T>>,
): Balance<T> {
    withdrawal.redeem()
}
Function withdraw_funds_from_object
Create a
Withdrawal<Balance<T>>public(package) fun withdraw_funds_from_object<T>(obj: &mut sui::object::UID, value: u64): sui::funds_accumulator::Withdrawal<sui::balance::Balance<T>>
Implementation
public(package) fun withdraw_funds_from_object<T>(
    obj: &mut UID,
    value: u64,
): Withdrawal<Balance<T>> {
    sui::funds_accumulator::withdraw_from_object(obj, value as u256)
}
Function create_supply_internal
public(package) fun create_supply_internal<T>(): sui::balance::Supply<T>
Implementation
public(package) fun create_supply_internal<T>(): Supply<T> {
    Supply { value: 0 }
}
Function create_staking_rewards
CAUTION: this function creates a
Balancefun create_staking_rewards<T>(value: u64, ctx: &sui::tx_context::TxContext): sui::balance::Balance<T>
Implementation
fun create_staking_rewards<T>(value: u64, ctx: &TxContext): Balance<T> {
    assert!(ctx.sender() == @0x0, ENotSystemAddress);
    assert!(
        std::type_name::with_defining_ids<T>().into_string().into_bytes() == SUI_TYPE_NAME,
        ENotSUI,
    );
    Balance { value }
}
Function destroy_storage_rebates
CAUTION: this function destroys a
Balancefun destroy_storage_rebates<T>(self: sui::balance::Balance<T>, ctx: &sui::tx_context::TxContext)
Implementation
fun destroy_storage_rebates<T>(self: Balance<T>, ctx: &TxContext) {
    assert!(ctx.sender() == @0x0, ENotSystemAddress);
    assert!(
        std::type_name::with_defining_ids<T>().into_string().into_bytes() == SUI_TYPE_NAME,
        ENotSUI,
    );
    let Balance { value: _ } = self;
}
Function destroy_supply
Destroy a
Supplypublic(package) fun destroy_supply<T>(self: sui::balance::Supply<T>): u64
Function send_to_account
fun send_to_account<T>(balance: sui::balance::Balance<T>, recipient: address)
Implementation
fun send_to_account<T>(balance: Balance<T>, recipient: address) {
    balance.send_funds(recipient)
}
Function withdraw_from_account
fun withdraw_from_account<T>(amount: u64, ctx: &sui::tx_context::TxContext): sui::balance::Balance<T>
Implementation
fun withdraw_from_account<T>(amount: u64, ctx: &TxContext): Balance<T> {
    let owner = ctx.sender();
    let withdrawal = sui::funds_accumulator::create_withdrawal<Balance<T>>(owner, amount as u256);
    withdrawal.redeem()
}