Forge manages dependencies using git submodules by default, which means that it works with any GitHub repository that contains smart contracts.
To add a dependency, run forge install
:
$ forge install Rari-Capital/solmate
Installing solmate in "lib/solmate", (url: https://github.com/rari-capital/solmate, tag: None)
Cloning into 'lib/solmate'...
# Snip...
[master a492c5d] forge install: solmate
2 files changed, 4 insertions(+)
create mode 160000 lib/solmate
If we now check the lib
folder:
$ tree lib -L 1
lib
├── ds-test
└── solmate
2 directories, 0 files
We can see that Forge installed solmate
!
By default, forge install
installs the latest master branch version. If you want to install a specific tag or commit,you can do it like so:
$ forge install Rari-Capital/solmate@v6
Forge can remap dependencies to make them easier to import. Forge will automatically try to deduce some remappings for you:
$ forge remappings
solmate/=lib/solmate/src/
weird-erc20/=lib/solmate/lib/weird-erc20/src/
ds-test/=lib/ds-test/src/
These remappings mean:
- To import from
solmate
we would write:import "solmate/Contract.sol";
- To import from
weird-erc20
we would write:import "weird-erc20/Contract.sol";
- To import from
ds-test
we would write:import "ds-test/Contract.sol";
You can customize these remappings by creating a remappings.txt
file in the root of your project.
Let's create a remapping called solmate-utils
that points to the utils
folder in the solmate repository!
solmate-utils/=lib/solmate/src/utils/
Now we can import any of the contracts in src/utils
of the solmate repository like so:
import "solmate-utils/Contract.sol";
You can update a specific dependency to the latest commit on the version you have specified using forge update <dep>
. For example, if we wanted to pull the latest commit from our previously installed master-version of solmate
, we would run:
$ forge update lib/solmate
Alternatively, you can do this for all dependencies at once by just running forge update
.
You can remove dependencies using forge remove <deps>...
, where <deps>
is either the full path to the dependency or just the name. For example, to remove ds-test
both of these commands are equivalent:
forge remove ds-test
# ... is equivalent to ...
forge remove lib/ds-test
Forge also supports Hardhat-style projects where dependencies are npm packages (stored in node_modules
) and contracts are stored in contracts
as opposed to source.
To enable Hardhat compatibility mode pass the --hh
flag.