Creating a Balances Pallet
As mentioned earlier, at the heart of a blockchain is a state machine.
We can create a very naive state machine using simple Rust abstractions, and through this help learn about Rust in the context of blockchains.
We want keep our code organized, so we will not really start building in the main.rs
file, but actually in separate Rust modules. We can think of the main.rs
file as glue which brings everything together, and we will see that over the course of this workshop.
"Pallet" is a term specific to the Polkadot SDK, which refers to Rust modules which contain logic specific for your blockchain runtime. We are going to start using this term here because what we build here will closely mirror what you will see with the Polkadot SDK.
Balances
Pretty much every blockchain has logic handles that the balances of users on that blockchain.
This Pallet will tell you: how much balance each user has, provide functions which allow users to transfer those balances, and even some low level functions to allow your blockchain system to manipulate those balances if needed. Think for example if you want to mint new tokens which don't already exist.
This is a great starting point, and the very first Pallet we will build.
Creating a Struct
-
Create a new file in your
src
folder namedbalances.rs
touch src/balances.rs
-
In this file, create a
struct
, which will act as the state and entry point for this module:#![allow(unused)] fn main() { pub struct Pallet {} }
-
Now go back to
src/main.rs
, and import this new module, which will include all the logic inside of it:#![allow(unused)] fn main() { mod balances; }
-
If we run your program now, you will see it still compiles and runs, but might show you some warnings like:
warning: struct `Pallet` is never constructed --> src/balances.rs:1:12 | 1 | pub struct Pallet { } | ^^^^^^ | = note: `#[warn(dead_code)]` on by default warning: `pr` (bin "pr") generated 1 warning
That's fine! We haven't started using our
Pallet
yet, but you can see that the Rust compiler is detecting our new code, and bringing that logic into our main program. This is the start of building our first state machine module.
#![allow(unused)] fn main() { /* TODO: create a new public struct named `Pallet`. */ }
/* TODO: use your new module `balances` */ fn main() { println!("Hello, world!"); }
#![allow(unused)] fn main() { pub struct Pallet {} }
mod balances; fn main() { println!("Hello, world!"); }
diff --git a/src/balances.rs b/src/balances.rs
new file mode 100644
index 00000000..dae1c4f1
--- /dev/null
+++ b/src/balances.rs
@@ -0,0 +1 @@
+/* TODO: create a new public struct named `Pallet`. */
diff --git a/src/main.rs b/src/main.rs
index a30eb952..2b4f7670 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,3 +1,5 @@
+/* TODO: use your new module `balances` */
+
fn main() {
println!("Hello, world!");
}
diff --git a/src/balances.rs b/src/balances.rs
index dae1c4f1..4a1da04e 100644
--- a/src/balances.rs
+++ b/src/balances.rs
@@ -1 +1 @@
-/* TODO: create a new public struct named `Pallet`. */
+pub struct Pallet {}
diff --git a/src/main.rs b/src/main.rs
index 2b4f7670..ea8024e5 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,4 +1,4 @@
-/* TODO: use your new module `balances` */
+mod balances;
fn main() {
println!("Hello, world!");