101 releases (46 breaking)

new 0.52.0 Mar 27, 2024
0.50.0 Feb 7, 2024
0.48.1 Dec 6, 2023
0.47.0 Nov 6, 2023
0.9.2 Mar 30, 2022

#2520 in Magic Beans

Download history 133/week @ 2023-12-04 61/week @ 2023-12-11 7/week @ 2023-12-18 2/week @ 2023-12-25 8/week @ 2024-01-08 40/week @ 2024-01-15 47/week @ 2024-01-29 38/week @ 2024-02-05 15/week @ 2024-02-12 297/week @ 2024-02-19 160/week @ 2024-02-26 102/week @ 2024-03-04 112/week @ 2024-03-11 25/week @ 2024-03-18

407 downloads per month
Used in 13 crates (9 directly)

Apache-2.0

3MB
67K SLoC

Sway

build crates.io docs discord

Sway is a language developed for the Fuel blockchain. It is heavily inspired by Rust and aims to bring modern language development and performance to the blockchain ecosystem.

Documentation

For user documentation, including installing release builds, see the Sway Book: https://fuellabs.github.io/sway/latest/.

For Sway Standard library documentation, see: https://fuellabs.github.io/sway/master/std/

Also view the technical reference for the Sway programming language: https://fuellabs.github.io/sway/master/reference/

Building from Source

This section is for developing the Sway compiler and toolchain. For developing contracts and using Sway, see the above documentation section.

Dependencies

Sway is built in Rust. To begin, install the Rust toolchain following instructions at https://www.rust-lang.org/tools/install. Then configure your Rust toolchain to use Rust stable:

rustup default stable

If not already done, add the Cargo bin directory to your PATH by adding the following line to ~/.profile and restarting the shell session.

export PATH="${HOME}/.cargo/bin:${PATH}"

Building Forc

Clone the repository and build the Sway toolchain:

git clone git@github.com:FuelLabs/sway.git
cd sway
cargo build

Confirm the Sway toolchain built successfully:

cargo run --bin forc -- --help

Contributing to Sway

We welcome contributions to Sway!

Please see the Contributing To Sway section of the Sway book for guidelines and instructions to help you get started.


lib.rs:

Utility items shared between forc crates.

Dependencies

~64MB
~1M SLoC