From 725dc123b0020d2f50143f16aa770fe0fd0b165d Mon Sep 17 00:00:00 2001 From: telome <130504305+telome@users.noreply.github.com> Date: Wed, 21 Aug 2024 12:54:25 +0200 Subject: [PATCH] Extend ScriptTools and Domain to support export & loading of address arrays (#46) * Extend ScriptTools and Domain to support export and loading of address arrays * Update src/ScriptTools.sol Co-authored-by: sunbreak1211 <129470872+sunbreak1211@users.noreply.github.com> --------- Co-authored-by: telome <> Co-authored-by: sunbreak1211 <129470872+sunbreak1211@users.noreply.github.com> --- src/ScriptTools.sol | 15 +++++++++++++++ src/domains/Domain.sol | 9 +++++++++ src/tests/ScriptToolsTest.t.sol | 5 +++++ 3 files changed, 29 insertions(+) diff --git a/src/ScriptTools.sol b/src/ScriptTools.sol index 733f0aa..c1fc8dd 100644 --- a/src/ScriptTools.sol +++ b/src/ScriptTools.sol @@ -141,6 +141,21 @@ library ScriptTools { _doExport(name, json); } + /** + * @notice Used to export important contracts to higher level deploy scripts. Specifically, + * this function exports an array of contracts under the same key (label). + * Note waiting on Foundry to have better primitives, but roll our own for now. + * @dev Set FOUNDRY_EXPORTS_NAME to override the name of the json file. + * @param name The name to give the json file. + * @param label The label of the addresses. + * @param addr The addresses to export. + */ + function exportContracts(string memory name, string memory label, address[] memory addr) internal { + name = vm.envOr("FOUNDRY_EXPORTS_NAME", name); + string memory json = vm.serializeAddress(string(abi.encodePacked(EXPORT_JSON_KEY, "_", name)), label, addr); + _doExport(name, json); + } + /** * @notice Used to export important values to higher level deploy scripts. * Note waiting on Foundry to have better primitives, but roll our own for now. diff --git a/src/domains/Domain.sol b/src/domains/Domain.sol index 1e5d45a..f6f9c78 100644 --- a/src/domains/Domain.sol +++ b/src/domains/Domain.sol @@ -39,6 +39,11 @@ contract Domain { vm.makePersistent(address(this)); } + function hasConfigKey(string memory key) internal view returns (bool) { + bytes memory raw = config.parseRaw(string.concat(".domains.", _details.chainAlias, ".", key)); + return raw.length > 0; + } + function readConfigString(string memory key) public view returns (string memory) { return config.readString(string.concat(".domains.", _details.chainAlias, ".", key)); } @@ -47,6 +52,10 @@ contract Domain { return config.readAddress(string.concat(".domains.", _details.chainAlias, ".", key)); } + function readConfigAddresses(string memory key) internal view returns (address[] memory) { + return config.readAddressArray(string.concat(".domains.", _details.chainAlias, ".", key)); + } + function readConfigUint(string memory key) public view returns (uint256) { return config.readUint(string.concat(".domains.", _details.chainAlias, ".", key)); } diff --git a/src/tests/ScriptToolsTest.t.sol b/src/tests/ScriptToolsTest.t.sol index 9829ce2..fe2cd3e 100644 --- a/src/tests/ScriptToolsTest.t.sol +++ b/src/tests/ScriptToolsTest.t.sol @@ -54,11 +54,16 @@ contract ScriptToolTest is DssTest { // Export some contracts and write to output ScriptTools.exportContract("myExports", "addr1", address(0x1)); ScriptTools.exportContract("myExports", "addr2", address(0x2)); + address[] memory addr34 = new address[](2); + addr34[0] = address(0x3); + addr34[1] = address(0x4); + ScriptTools.exportContracts("myExports", "addr34", addr34); // Simulate a subsequent run loading a previously written file (use latest deploy) loadedExports = ScriptTools.readOutput("myExports", 1); assertEq(stdJson.readAddress(loadedExports, ".addr1"), address(0x1)); assertEq(stdJson.readAddress(loadedExports, ".addr2"), address(0x2)); + assertEq(stdJson.readAddressArray(loadedExports, ".addr34"), addr34); // Export some values and write to output ScriptTools.exportValue("myExports", "label1", 1);