Skip to main content

Writing and Calling a Rust Contract

One of the benefits of using PolkaVM vs EVM is that you can write contracts in any language that compile down to RISC-V. In this chapter we learn how to use Rust to write a contract and how to call it from Solidity.

Use the Rust Template

Here you can find our Rust contract template. You can make use of githubs template feature in order to make it the starting point of your own repository.

Compile the template

Simply follow the README inside the template to learn how to compile the project into a contract.polkavm. The repository also contains a example Solidity file that demonstrates how to call this contract.

Deploy the template

You can use ether.js to deploy the Rust contract. Pass the raw contract.polkavm as bytecode:

import { ContractFactory } from 'ethers'
import { readFileSync } from 'fs'

/// We specify the abi manually since the Rust compiler won't generate one for us
const abi = ["constructor()", "function fibonacci(uint) view returns(uint)"];
const bytecode = readFileSync('contract.polkavm');

// Instantiate a contract factory.
const contractFactory = new ContractFactory(abi, bytecode, signer)

try {
const contract = await contractFactory.deploy(/* args */)
await contract.waitForDeployment()

// Get the contract's address.
const address = await contract.getAddress()
console.log(`Contract deployed: ${address}`)
} catch (e) {
console.error('Failed to deploy contract', e)
}

// Try calling the fibonacci function directly
// ...

Deploy and Use the Caller Contract

You can now deploy the Solidity contract from the template repository using ether.js or REMIX. It is setup to call the Rust contract via the fibonacciRust function. You need to pass the address from the previous step.