Setup
Stellar smart contracts are small programs written in the Rust programming language.
To build and develop contracts you need the following prerequisites:
- A Rust toolchain
- An editor that supports Rust
- Stellar CLI
Install Rust
- macOS/Linux
- Windows
- Other
If you use macOS, Linux, or another Unix-like OS, the simplest method to install a Rust toolchain is to install rustup. Install rustup with the following command.
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
Then restart the terminal.
On Windows, download and run rustup-init.exe. You can continue with the default settings by pressing Enter.
The Stellar CLI uses emojis in its output. To properly render them on Windows, it is recommended to use the Windows Terminal. See how to install Windows Terminal on Microsoft Learn. If the CLI is used in the built in Windows Command Prompt or Windows PowerShell the CLI will function as expected but the emojis will appear as question marks.
If you're already using WSL, you can also follow the instructions for Linux.
For other methods of installing Rust, see: https://www.rust-lang.org/tools/install
Install the target
You'll need a "target" for which your smart contract will be compiled. For Rust v1.84.0 or higher, install the wasm32v1-none target.
rustup target add wasm32v1-none
You can learn more about the finer points of what this target brings to the table, in our page all about the Stellar Rust dialect. This page describes the subset of Rust functionality that is available to you within Stellar smart contract environment.
Configure an editor
Many editors have support for Rust. Visit the following link to find out how to configure your editor: https://www.rust-lang.org/tools
Here are the tools to you need to configure your editor:
- Visual Studio Code as code editor (or another code editor that supports Rust)
- Rust Analyzer for Rust language support
- CodeLLDB for step-through-debugging
Install the Stellar CLI
The Stellar CLI can execute smart contracts on futurenet, testnet, mainnet, as well as in a local sandbox.
The latest stable release is v23.1.4.
Install
There are a few ways to install the latest release of Stellar CLI.
- macOS
- Linux
- Windows
Install with Homebrew (macOS, Linux):
brew install stellar-cli
Install with cargo from source:
cargo install --locked [email protected]
Install with Homebrew (macOS, Linux):
brew install stellar-cli
Install with cargo from source:
cargo install --locked [email protected]
Installing from source requires a C build system. To install a C build system on Debian/Ubuntu, use:
sudo apt update && sudo apt install -y build-essential
Using the installer:
- Download the installer from the latest release.
- Go to your Downloads folder, double click the installer and follow the wizard instructions.
- Restart your terminal to use the
stellarcommand.
Using winget:
winget install --id Stellar.StellarCLI --version 23.1.4
Install with cargo from source:
cargo install --locked [email protected]
Report issues and share feedback about the Stellar CLI here.
Documentation
The auto-generated comprehensive reference documentation is available here.
Autocompletion
You can use stellar completion to generate shell completion for different shells. You should absolutely try it out. It will feel like a super power!
- Bash
- ZSH
- fish
- PowerShell
- Elvish
To enable autocomplete on the current shell session:
source <(stellar completion --shell bash)
To enable autocomplete permanently, run the following command, then restart your terminal:
echo "source <(stellar completion --shell bash)" >> ~/.bashrc
To enable autocomplete on the current shell session:
source <(stellar completion --shell zsh)
To enable autocomplete permanently, run the following commands, then restart your terminal:
echo "source <(stellar completion --shell zsh)" >> ~/.zshrc
To enable autocomplete on the current shell session:
stellar completion --shell fish | source
To enable autocomplete permanently, run the following command, then restart your terminal:
echo "stellar completion --shell fish | source" >> ~/.config/fish/config.fish
To enable autocomplete on the current shell session:
stellar completion --shell powershell | Out-String | Invoke-Expression
To enable autocomplete permanently, run the following commands, then restart your terminal:
New-Item -ItemType Directory -Path $(Split-Path $PROFILE) -Force
if (-Not (Test-Path $PROFILE)) { New-Item -ItemType File -Path $PROFILE | Out-Null }
Add-Content $PROFILE 'Set-PSReadlineKeyHandler -Key Tab -Function MenuComplete'
Add-Content $PROFILE 'stellar completion --shell powershell | Out-String | Invoke-Expression'
If you get an error like cannot be loaded because running scripts is disabled on this system, you may need to change your Execution Policy with Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope CurrentUser. Before running this command, be sure you understand the implications of doing so.
To enable autocomplete on the current shell session:
source (stellar completion --shell elvish)
To enable autocomplete permanently, run the following commands, then restart your terminal:
echo "source (stellar completion --shell elvish)" >> ~/.elvish/rc.elv