Standard Library
The Move Standard Library provides functionality for native types and operations. It is a standard collection of modules that do not interact with storage, but provide basic tools for working with and manipulating data. It is the only dependency of the Sui Framework, and is imported together with it.
Most Common Modules
In this book we go into detail about most of the modules in the Standard Library, however, it is also helpful to give an overview of the features, so that you can get a sense of what is available and which module implements it.
Module | Description | Chapter |
---|---|---|
std::string | Provides basic string operations | String |
std::ascii | Provides basic ASCII operations | - |
std::option | Implements Option<T> | Option |
std::vector | Native operations on the vector type | Vector |
std::bcs | Contains the bcs::to_bytes() function | BCS |
std::address | Contains a single address::length function | Address |
std::type_name | Allows runtime type reflection | Type Reflection |
std::hash | Hashing functions: sha2_256 and sha3_256 | - |
std::debug | Contains debugging functions, which are available in only in test mode | - |
std::bit_vector | Provides operations on bit vectors | - |
std::fixed_point32 | Provides the FixedPoint32 type | - |
Integer Modules
The Move Standard Library provides a set of functions associated with integer types. These functions are split into multiple modules, each associated with a specific integer type. The modules should not be imported directly, as their functions are available on every integer value.
All of the modules provide the same set of functions. Namely,
max
,diff
,divide_and_round_up
,sqrt
andpow
.
Exported Addresses
The Standard Library exports a single named address - std = 0x1
. Note the alias std
is defined here.
[addresses]
std = "0x1"
Implicit Imports
Some modules are imported implicitly and are available in the module without the explicit use
import. For the Standard Library, these modules and types include:
- std::vector
- std::option
- std::option::Option
Importing std without Sui Framework
The Move Standard Library can be imported to the package directly. However, std
alone is not
enough to build a meaningful application, as it does not provide any storage capabilities and can't
interact with the on-chain state.
MoveStdlib = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/move-stdlib", rev = "framework/mainnet" }
Source Code
The source code of the Move Standard Library is available in the Sui repository.