From 294ada53aa924a660da67079e5019b23f5f052f8 Mon Sep 17 00:00:00 2001 From: dk1a Date: Mon, 22 Apr 2024 16:47:54 +0300 Subject: [PATCH 1/2] feat(cli): add user-specified PostDeploy forge options --- packages/cli/src/commands/dev-contracts.ts | 1 + packages/cli/src/runDeploy.ts | 3 ++- packages/cli/src/utils/postDeploy.ts | 15 ++++++++++++++- 3 files changed, 17 insertions(+), 2 deletions(-) diff --git a/packages/cli/src/commands/dev-contracts.ts b/packages/cli/src/commands/dev-contracts.ts index 53c5572693..025622aaa4 100644 --- a/packages/cli/src/commands/dev-contracts.ts +++ b/packages/cli/src/commands/dev-contracts.ts @@ -16,6 +16,7 @@ const devOptions = { rpc: deployOptions.rpc, configPath: deployOptions.configPath, alwaysRunPostDeploy: deployOptions.alwaysRunPostDeploy, + forgeScriptOptions: deployOptions.forgeScriptOptions, worldAddress: deployOptions.worldAddress, }; diff --git a/packages/cli/src/runDeploy.ts b/packages/cli/src/runDeploy.ts index 07a6868307..9a47b5c42c 100644 --- a/packages/cli/src/runDeploy.ts +++ b/packages/cli/src/runDeploy.ts @@ -37,6 +37,7 @@ export const deployOptions = { type: "boolean", desc: "Always run PostDeploy.s.sol after each deploy (including during upgrades). By default, PostDeploy.s.sol is only run once after a new world is deployed.", }, + forgeScriptOptions: { type: "string", description: "Options to pass to forge script PostDeploy.s.sol" }, salt: { type: "string", desc: "The deployment salt to use. Defaults to a random salt.", @@ -113,7 +114,7 @@ in your contracts directory to use the default anvil private key.`, withWorldProxy: configV2.deploy.useProxy, }); if (opts.worldAddress == null || opts.alwaysRunPostDeploy) { - await postDeploy(config.postDeployScript, worldDeploy.address, rpc, profile); + await postDeploy(config.postDeployScript, worldDeploy.address, rpc, profile, opts.forgeScriptOptions); } console.log(chalk.green("Deployment completed in", (Date.now() - startTime) / 1000, "seconds")); diff --git a/packages/cli/src/utils/postDeploy.ts b/packages/cli/src/utils/postDeploy.ts index a03eb1e2fa..343347801b 100644 --- a/packages/cli/src/utils/postDeploy.ts +++ b/packages/cli/src/utils/postDeploy.ts @@ -8,13 +8,26 @@ export async function postDeploy( worldAddress: string, rpc: string, profile: string | undefined, + forgeOptions: string | undefined, ): Promise { // Execute postDeploy forge script const postDeployPath = path.join(await getScriptDirectory(), postDeployScript + ".s.sol"); if (existsSync(postDeployPath)) { + const userOptions = forgeOptions?.replaceAll("\\", "").split(" ") ?? []; console.log(chalk.blue(`Executing post deploy script at ${postDeployPath}`)); await forge( - ["script", postDeployScript, "--sig", "run(address)", worldAddress, "--broadcast", "--rpc-url", rpc, "-vvv"], + [ + "script", + postDeployScript, + "--sig", + "run(address)", + worldAddress, + "--broadcast", + "--rpc-url", + rpc, + "-vvv", + ...userOptions, + ], { profile: profile, }, From 097ffed3aad365b197b067b683e44a48590e8560 Mon Sep 17 00:00:00 2001 From: Kevin Ingersoll Date: Thu, 25 Apr 2024 04:16:37 -0700 Subject: [PATCH 2/2] Create three-zoos-laugh.md --- .changeset/three-zoos-laugh.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/three-zoos-laugh.md diff --git a/.changeset/three-zoos-laugh.md b/.changeset/three-zoos-laugh.md new file mode 100644 index 0000000000..40a38a4dd4 --- /dev/null +++ b/.changeset/three-zoos-laugh.md @@ -0,0 +1,5 @@ +--- +"@latticexyz/cli": patch +--- + +Added a `--forgeScriptOptions` flag to deploy and dev commands to allow passing in additional CLI flags to `forge script` command.