ink! Environment

Overview

This guide will help you set up your environment for ink! and Wasm smart contract development in UOMI.

ℹ️ Note Before proceeding, make sure your system meets the requirements for Rust development.

What is ink!?

ink! is a Rust-based eDSL (embedded Domain Specific Language) developed by Parity Technologies. It's specifically designed for creating smart contracts that work with Substrate's pallet-contracts.

Rather than creating a new programming language, ink! adapts Rust's capabilities for smart contract development.

💡 Tip Want to learn more about why ink! is a great choice for smart contract development? Check out the detailed benefits here.

Why WebAssembly?

Curious about the choice of WebAssembly for smart contracts? Find comprehensive explanations here.

Setting Up Your Environment

1. Installing Rust and Cargo

Rust and Cargo are essential prerequisites for Wasm smart contract development.

Linux and macOS

# Download and install
curl https://sh.rustup.rs -sSf | sh

# Configure environment
source ~/.cargo/env

Windows

Visit the Rust website and follow the Windows installation instructions.

2. Configuring Rust

Set up your Rust environment with these commands:

rustup default stable
rustup update
rustup update nightly
rustup component add rust-src
rustup component add rust-src --toolchain nightly
rustup target add wasm32-unknown-unknown --toolchain nightly

⚠️ Warning

Due to a bug in cargo-contract, building contracts with rust nightly 1.70.0 or higher will fail. It is advised to use rustc v1.69.0 or older until the issue is resolved from cargo-contract side. For better dev experience it is advised to create a rust-toolchain file in the root of your project directory with following values.

[toolchain]
channel = "1.69.0"
components = [ "rustfmt", "rust-src" ]
targets = [ "wasm32-unknown-unknown" ]
profile = "minimal"

See more here

3. Installing ink! CLI

The primary tool you'll need is cargo-contract, a CLI tool for managing WebAssembly smart contracts.

Prerequisites

First, install binaryen for WebAssembly bytecode optimization:

Debian/Ubuntu
apt-get update
apt-get -y install binaryen
ArchLinux
pacman -S binaryen
macOS
brew install binaryen
Windows
Find binary releases at https://github.com/WebAssembly/binaryen/releases

Additional Dependencies

Install required linking tools:

cargo install cargo-dylint dylint-link

Installing cargo-contract

cargo install cargo-contract --force --locked

💡 Tip Use --force to ensure you get the latest version. For a specific version, add --version X.X.X

Example for specific version:

cargo install cargo-contract --force --version 1.5.1

Explore available commands with:

cargo contract --help

Development Container

🔧 Alternative Setup Skip manual installation by using our pre-configured development container.

Find detailed instructions for using our dev container in the swanky-dev-container Github repository.

Additional Resources

Last updated