Module

A module is the base unit of code organization in Move. Modules are used to group and isolate code, and all members of the module are private to the module by default. In this section you will learn how to define a module, declare its members, and access it from other modules.

Module declaration

Modules are declared using the module keyword followed by the package address, module name, semicolon, and the module body. The module name should be in snake_case - all lowercase letters with underscores between words. Modules names must be unique in the package.

Usually, a single file in the sources/ folder contains a single module. The file name should match the module name - for example, a donut_shop module should be stored in the donut_shop.move file. You can read more about coding conventions in the Coding Conventions section.

If you need to declare more than one module in a file, you must use Module Block syntax.

// Module label.
module book::my_module;

// module body

Structs, functions, constants and imports all part of the module:

Address / Named address

The module address can be specified as both: an address literal (does not require the @ prefix) or a named address specified in the Package Manifest. In the example below, both are identical because there's a book = "0x0" record in the [addresses] section of the Move.toml.

module 0x0::address_literal { /* ... */ }
module book::named_address { /* ... */ }

Addresses section in the Move.toml:

# Move.toml
[addresses]
book = "0x0"

Module members

Module members are declared inside the module body. To illustrate that, let's define a simple module with a struct, a function and a constant:

module book::my_module_with_members;

// import
use book::my_module;

// a constant
const CONST: u8 = 0;

// a struct
public struct Struct {}

// method alias
public use fun function as Struct.struct_fun;

// function
fun function(_: &Struct) { /* function body */ }

Module block

The pre-2024 edition of Move required the body of the module to be a module block - the contents of the module needed to be surrounded by curly braces {}. The main reason to use block syntax and not label syntax is if you need to define more than one module in a file. However, using module blocks is not recommended practice.

module book::my_block_module_with_members {
    // import
    use book::my_module;

    // a constant
    const CONST: u8 = 0;

    // a struct
    public struct Struct {}

    // method alias
    public use fun function as Struct.struct_fun;

    // function
    fun function(_: &Struct) { /* function body */ }
}

// module block allows multiple module definitions in the
// same file but this is not a recommended practice
module book::another_module_in_the_file {
    // ...
}

Further reading