#dusk #smart-contracts #blockchain

nightly macro dusk-forge

A smart contract development framework for Dusk

1 unstable release

new 0.1.0 Jan 18, 2025

#329 in Magic Beans

Download history 82/week @ 2025-01-13

82 downloads per month

MPL-2.0 license

260KB
234 lines

Dusk Forge

Dusk Forge Illustration

Repository Documentation

Dusk Forge is a framework designed to simplify the development of smart contracts for the Dusk blockchain. It provides macros to reduce boilerplate, allow developers to focus on implementing core business logic.

⚠️ This crate requires the nightly Rust compiler.

Usage

The main feature of Dusk Forge is the #[contract] attribute macro, which automates boilerplate generation. Here's how to get started:

Installation

Add dusk_forge as a dependency to your project:

cargo add dusk_forge

Basic Example: Counter Contract

#![no_std]

use dusk_forge::contract;

#[contract]
pub mod counter {
    pub struct Counter {
        value: i64,
    }

    impl Counter {
        pub fn new() -> Self {
            Self { value: 0 }
        }

        pub fn read_value(&self) -> i64 {
            self.value
        }

        pub fn increment(&mut self) {
            let value = self.value + 1;
            self.value = value;
        }
    }
}

What Happes Under the Hood?

The #[contract] macro transforms the module into a contract-ready state by:

  1. Generating a static mut STATE for the contract's state:
pub(crate) static mut STATE: Counter = Counter { value: 0 };
  1. Wrapping public methods with no_mangle functions for Dusk VM compatibility:
#[no_mangle]
pub unsafe fn read_value(arg_len: u32) -> u32 {
    dusk_core::abi::wrap_call(arg_len, |(): ()| counter::STATE.read_value())
}

#[no_mangle]
pub unsafe fn increment(arg_len: u32) -> u32 {
    dusk_core::abi::wrap_call(arg_len, |(): ()| counter::STATE.increment())
}

Advanced Example: Struct with Complex State

#![no_std]

use dusk_forge::contract;

#[contract]
pub mod complex_contract {
    pub struct AccountManager {
        accounts: core::collections::BTreeMap<u64, i64>,
    }

    impl AccountManager {
        pub fn new() -> Self {
            Self {
                accounts: core::collections::BTreeMap::new(),
            }
        }

        pub fn add_account(&mut self, id: u64, balance: i64) {
            self.accounts.insert(id, balance);
        }

        pub fn get_balance(&self, id: u64) -> Option<i64> {
            self.accounts.get(&id).cloned()
        }
    }
}

Testing

Dusk Force includes tests for macro transformations and tests for individual components. Run tests using:

cargo test

Release History

To see the release history for this crate, please see the CHANGELOG file.

License

This code is licensed under the Mozilla Public License Version 2.0 (MPL-2.0). Please see the LICENSE for further details.

The included illustration is created by Regisha Dauven and is used with exclusive permission. Redistribution, modification, or reuse of the illustration by third parties is prohibited without explicit permission from the creator.

Contribute

If you want to contribute to this project, feel free to open an issue, fork the repository and open a pull request.

Dependencies

~7MB
~147K SLoC