Skip to content

Latest commit

 

History

History
75 lines (52 loc) · 3.36 KB

index.md

File metadata and controls

75 lines (52 loc) · 3.36 KB
title
Contributing to Sui

This page describes how to add to Sui. If you merely need to get the Sui binaries, follow Install Sui.

Find answers to common questions in our FAQ. Read other sub-pages in this section for ways to contribute to Sui.

See our roadmap

Sui is evolving quickly. See our roadmap for the overall status of Sui, including timelines for launching devnet, testnet, and mainnet.

Join the community

To connect with the Sui community, join our Discord.

File issues

Report bugs and make feature requests in the Sui GitHub repository using the Template for Reporting Issues.

Provide docs feedback

Send us documentation fixes or requests for improvement at: [email protected]

You may also suggest changes to the docs directly in GitHub right here using the Source Code link below.

Simply edit the file in question and generate a pull request. We will get back to you shortly.

Download and learn Sui

In order to obtain the Sui source code, clone the Sui repository:

git clone https://github.com/MystenLabs/sui.git

You can start exploring Sui's source code by looking into the following primary directories:

  • sui - the Sui binaries (wallet, sui-move, and more)
  • sui_programmability - Sui's Move language integration also including games and other Move code examples for testing and reuse
  • sui_core - authority server and Sui Gateway
  • sui_types - coins, gas, and other object types
  • explorer - object explorer for the Sui network
  • network_utils - networking utilities and related unit tests

Send pull requests

Start by creating your own fork of the repo:

gh fork https://github.com/mystenlabs/sui.git # or alternatively, clone your fork
cargo install --path sui/sui # put Sui CLI's in your PATH
cd sui
cargo build --all --all-targets # check that build works
cargo test # check that tests pass

To submit your pull request:

  1. Make your changes in a descriptively named branch.
  2. If you have added code that should be tested, add unit tests.
  3. Ensure your code builds and passes the tests: cargo test
  4. Make sure your code passes the linters and autoformatter: cargo clippy --all --all-targets && cargo fmt --all
  5. If you have made changes to APIs, update the relevant documentation, and build and test the developer site.
  6. Run git push -f origin <branch_name>, then open a pull request from the Sui GitHub site.

Further reading