This directory contains examples of interacting with a Move language smart contract using the Sui Rust SDK. See the introduction to the Rust SDK for additional details.
- Install
sui
binary following the Sui installation docs. - Connect to Sui Devnet.
- Make sure you have two addresses with gas by using the
new-address
command to create new addresses:You must specify the key scheme, one ofsui client new-address ed25519
ed25519
orsecp256k1
orsecp256r1
. You can skip this step if you are going to play with a friend. :) - Request Sui tokens for all addresses that will be used to join the game.
- Download the Sui source code.
- Publish the
games
package using the Sui client:sui client publish --path /path-to-sui-source-code/sui_programmability/examples/games --gas-budget 10000
- Record the package object ID.
- Run the following command in the Sui source code directory to start a new game, replacing the game package objects ID with the one you recorded:
This will create a game for the first two addresses in your keystore by default. If you want to specify the identity of each player, use the following command and replace the variables with the actual player's addresses:
cargo run --example tic-tac-toe -- --game-package-id <<games package object ID>> new-game
cargo run --example tic-tac-toe -- --game-package-id <<games package object ID>> new-game --player-x <<player X address>> --player-o <<player O address>>
- Copy the game ID and pass it to your friend to join the game.
Run the following command in the Sui source code directory to join the game, replacing the game ID and address accordingly:
cargo run --example tic-tac-toe -- --game-package-id <<games package object ID>> join-game --my-identity <<address>> --game-id <<game ID>>