Type of large-scale storage tables. source: https://github.com/move-language/move/blob/1b6b7513dcc1a5c866f178ca5c1e74beb2ce181e/language/extensions/move-table-extension/sources/Table.move#L1
It implements the Table type which supports individual table items to be represented by separate global state items. The number of items and a unique handle are tracked on the table struct itself, while the operations are implemented as native functions. No traversal is provided.
- Resource
TablePlaceholder
- Struct
Table
- Struct
Iterator
- Function
new
- Function
new_with_object_id_by_system
- Function
add
- Function
borrow
- Function
borrow_with_default
- Function
borrow_mut
- Function
borrow_mut_with_default
- Function
upsert
- Function
remove
- Function
contains
- Function
list_field_keys
- Function
field_keys_len
- Function
next
- Function
next_mut
- Function
destroy_empty
- Function
length
- Function
is_empty
- Function
drop
- Function
handle
use 0x1::option;
use 0x2::core_addresses;
use 0x2::object;
struct TablePlaceholder has key
Type of tables
struct Table<K: copy, drop, store, V> has store
struct Iterator<K: copy, drop, store, V> has drop, store
Create a new Table.
public fun new<K: copy, drop, store, V: store>(): table::Table<K, V>
Create a new Table with object id.
public fun new_with_object_id_by_system<K: copy, drop, store, V: store>(system: &signer, id: object::ObjectID): table::Table<K, V>
Add a new entry to the table. Aborts if an entry for this key already exists. The entry itself is not stored in the table, and cannot be discovered from it.
public fun add<K: copy, drop, store, V: store>(table: &mut table::Table<K, V>, key: K, val: V)
Acquire an immutable reference to the value which key
maps to.
Aborts if there is no entry for key
.
public fun borrow<K: copy, drop, store, V: store>(table: &table::Table<K, V>, key: K): &V
Acquire an immutable reference to the value which key
maps to.
Returns specified default value if there is no entry for key
.
public fun borrow_with_default<K: copy, drop, store, V: store>(table: &table::Table<K, V>, key: K, default: &V): &V
Acquire a mutable reference to the value which key
maps to.
Aborts if there is no entry for key
.
public fun borrow_mut<K: copy, drop, store, V: store>(table: &mut table::Table<K, V>, key: K): &mut V
Acquire a mutable reference to the value which key
maps to.
Insert the pair (key
, default
) first if there is no entry for key
.
public fun borrow_mut_with_default<K: copy, drop, store, V: drop, store>(table: &mut table::Table<K, V>, key: K, default: V): &mut V
Insert the pair (key
, value
) if there is no entry for key
.
update the value of the entry for key
to value
otherwise
public fun upsert<K: copy, drop, store, V: drop, store>(table: &mut table::Table<K, V>, key: K, value: V)
Remove from table
and return the value which key
maps to.
Aborts if there is no entry for key
.
public fun remove<K: copy, drop, store, V: store>(table: &mut table::Table<K, V>, key: K): V
Returns true if table
contains an entry for key
.
public fun contains<K: copy, drop, store, V: store>(table: &table::Table<K, V>, key: K): bool
Returns a vector of keys in the table from the given cursor position, up to the specified limit. cursor: Optional address to start listing from. If None, starts from the beginning. limit: Maximum number of keys to return.
public fun list_field_keys<K: copy, drop, store, V: store>(table: &table::Table<K, V>, cursor: option::Option<K>, limit: u64): table::Iterator<K, V>
Returns the number of keys in the table.
public fun field_keys_len<K: copy, drop, store, V: store>(iterator: &table::Iterator<K, V>): u64
Returns a immutable reference to the next key-value pair in the table, starting from the given iterator.
public fun next<K: copy, drop, store, V: store>(iterator: &mut table::Iterator<K, V>): (&K, &V)
Returns a mutable reference to the next key-value pair in the table, starting from the given iterator.
public fun next_mut<K: copy, drop, store, V: store>(iterator: &mut table::Iterator<K, V>): (&K, &mut V)
Destroy a table. Aborts if the table is not empty.
public fun destroy_empty<K: copy, drop, store, V: store>(table: table::Table<K, V>)
Returns the size of the table, the number of key-value pairs
public fun length<K: copy, drop, store, V: store>(table: &table::Table<K, V>): u64
Returns true iff the table is empty (if length
returns 0
)
public fun is_empty<K: copy, drop, store, V: store>(table: &table::Table<K, V>): bool
Drop a possibly non-empty table.
Usable only if the value type V
has the drop
ability
public fun drop<K: copy, drop, store, V: drop>(table: table::Table<K, V>)
Returns table handle of table
.
public fun handle<K: copy, drop, store, V: store>(table: &table::Table<K, V>): object::ObjectID