Managing dependencies
Scarb manages dependencies by cloning packages from their Git repositories. To add a dependency, simply declare it in your Scarb.toml
.
WARNING
Using Git repositories as a foundation for package management is not the recommended approach anymore. Instead, registries are now the primary way to manage dependencies. This guide will be updated to reflect the new approach after official registry is out of beta and considered stable. For details on how to specify dependencies from the official registry, see here.
Adding a dependency
If your Scarb.toml
doesn't already have a [dependencies]
section, add it, then list the package name and the URL to its Git repository. This example adds a dependency on the alexandria
package (note that Alexandria is a collection of multiple packages, and we will use alexandria_math
as an example in this guide):
[dependencies]
alexandria_math = { git = "https://github.com/keep-starknet-strange/alexandria.git" }
You can pin a Git dependency to concrete commit, branch or a tag using one of the following extra fields that can be passed along git
: branch
, tag
and rev
.
Actually this is how the OpenZeppelin Contracts for Cairo library is released, since the main
branch is not stable.
[dependencies]
openzeppelin = { git = "https://github.com/OpenZeppelin/cairo-contracts.git", tag = "v0.7.0-rc.0" }
Note, that if you want to add more dependencies, you do not have to add [dependencies]
for each package separately. For example:
[dependencies]
alexandria_math = { git = "https://github.com/keep-starknet-strange/alexandria.git" }
openzeppelin = { git = "https://github.com/OpenZeppelin/cairo-contracts.git", tag = "v0.7.0-rc.0" }
Now, run scarb build
, and Scarb will fetch new dependencies and all of their dependencies. Then it will compile your package with all of these packages included:
$ scarb build
Updating git repository https://github.com/keep-starknet-strange/alexandria
Updating git repository https://github.com/OpenZeppelin/cairo-contracts
Compiling hello_world v0.1.0 (/path/to/package/hello_world/Scarb.toml)
Finished release target(s) in 4 seconds
You can now use the alexandria_math
package in src/lib.cairo
:
use alexandria_math::fibonacci;
fn main() -> felt252 {
fibonacci::fib(0, 1, 10)
}
Development dependencies
You can add a [dev-dependencies]
section to your Scarb.toml whose format is equivalent to [dependencies]
:
[dev-dependencies]
alexandria_math = { git = "https://github.com/keep-starknet-strange/alexandria.git" }
Adding a dependency via scarb add
If you prefer, you can also ask Scarb to edit Scarb.toml
to add a dependency automagically for you. The scarb add
command accepts many parameters, matching all possibilities of expressing dependencies. It can also automatically keep the list sorted, if it already is. For example, the above example of dependency on alexandria_math
, can be also added like this:
scarb add alexandria_math --git https://github.com/keep-starknet-strange/alexandria.git --rev 27fbf5b
You can add development dependencies similarly by passing --dev
flag:
scarb add --dev alexandria_math --git https://github.com/keep-starknet-strange/alexandria.git --rev 27fbf5b
Removing a dependency
To remove a dependency, simply remove related lines from your Scarb.toml
.
As a quick shortcut, the scarb remove
(also available in short scarb rm
) can clean the manifest automatically:
scarb rm alexandria_math
Removing development dependencies, like in scarb add
, requires passing --dev
flag:
scarb rm --dev alexandria_math