Skip to content

Toolchain

rustup

rustup is an installer for the systems programming language Rust.

rustup Commands

SUBCOMMANDS:
    show           Show the active and installed toolchains or profiles
    update         Update Rust toolchains and rustup
    check          Check for updates to Rust toolchains and rustup
    default        Set the default toolchain
    toolchain      Modify or query the installed toolchains
    target         Modify a toolchain's supported targets
    component      Modify a toolchain's installed components
    override       Modify directory toolchain overrides
    run            Run a command with an environment configured for a given toolchain
    which          Display which binary will be run for a given command
    doc            Open the documentation for the current toolchain
    man            View the man page for a given command
    self           Modify the rustup installation
    set            Alter rustup settings
    completions    Generate tab-completion scripts for your shell

Common rustup commands

rustup show                                     # shows installed toolchain
rustup target add riscv32imac-unknown-none-elf  # adds riscv target
rustup update                                   # updates the toolschain
rustup toolchain list                           # lists the toolchain
rustup doc                                      # opens the local documentation

rustc

rustc is the compiler for Rust.

# Compile rust file
rustc <ifname>.rs -o <ofname> -v

# Compile with different outputname and verbose flag
rustc <ifname>.rs -o <ofname> -v

# Compile rust to a library
rustc --crate-type lib rustc <ifname>.rs

# Compile rust file for a specifiy target
rustc --target target_arch <ifname>.rs

# Create documentation for a Rust library
rustc --document <ifname>.rs
Target Explanation
x86_64-unknown-linux-gnu x86 64bit Linux
x86_64-apple-darwin x86 64bit MacOS
x86_64-pc-windows-gnu x86 64bit MinGW on Windows
aarch64-unknown-linux-gnu Arm 64bit Linux
aarch64-apple-darwin Arm 64bit MacOS (Apple Silicon)
riscv32imac-unknown-none-elf RISC-V rv32i

Example

rustc hello.rs
rustc --target riscv32imac-unknown-none-elf -o hello main.rs

Cargo

Cargo Commands

Some common cargo commands are (see all commands with --list):
  build, b    Compile the current package
  check, c    Analyze the current package and report errors, but don't build object files
  clean       Remove the target directory
  doc, d      Build this package's and its dependencies' documentation
  new         Create a new cargo package
  init        Create a new cargo package in an existing directory
  add         Add dependencies to a manifest file
  remove      Remove dependencies from a manifest file
  run, r      Run a binary or example of the local package
  test, t     Run the tests
  bench       Run the benchmarks
  update      Update dependencies listed in Cargo.lock
  search      Search registry for crates
  publish     Package and upload this package to the registry
  install     Install a Rust binary. Default location is $HOME/.cargo/bin
  uninstall   Uninstall a Rust binary

Install a package

cargo search <searchstring>
cargo install <packagename>

Create project

cargo new <projectname>       # creates package folder and initialises it
cargo new --lib <projectname> # creates library package folder and initialises it
cargo init                    # creates project in current folder

Hello World project

cargo new hello         # create new hello world project in folder hello
cd hello                # move into folder
cargo run               # build and run project

Compile

# Build debug verions of the project with its dependencies
cargo build

# Build release version of the project with its dependencies
cargo build --release

# Build and generate also assember file
# need to be assembler with tools like gas
cargo rustc -- -- emit asm

# Build and generate also assember file for another target
cargo rustc --target riscv32i-unknown-none-elf -- --emit asm

Common cargo commands

# Build debug verions of the project with its dependencies
cargo build

# Build release version of the project with its dependencies
cargo build --release

# Builds debug version if necessary and runs the generated executable
cargo run

# Check project of errors without building a binary
cargo check

# Updates dependencies of a project with the latest version (patch version)
cargo update

# Cleans build artifacts
cargo clean

# Build html documentation for the code and its dependencies
cargo doc
cargo doc --open

# Add package to current project
# only works if ``cargo install cargo-edit`` is installed
cargo add rand

Cargo Profiles

Release Profiles configure the code compilation for cargo.

Two main profiles are available ba default: dev and release

cargo build           # dev build
cargo build --release # release build

Customise

Cargo.toml
# ...

[profile.dev]
opt-level = 0  # default

[profile.release]
opt-level = 3  # default

# ...

Publishing Crate at crates.io

Unter crates.io generate a accesstoken for your device and enter it via the command line

cargo login <api token>

Verify crates metadata:

Cargo.toml
[package]
name = "crates_name" # must be unique within crates.io
version = "1.0.0"
authors = ["tschinz"]
edition = "2023"
description = "library description"
license = "MIT"

# ...

Publish the crate to crates.io

cargo publish

Disallow the download of a specific crate version in crates.io

cargo yank --vers 1.0.0