hardhatjs 2.22.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +41 -0
- package/LICENSE +55 -0
- package/README.md +53 -0
- package/builtin-tasks/check.d.ts +2 -0
- package/builtin-tasks/check.d.ts.map +1 -0
- package/builtin-tasks/check.js +6 -0
- package/builtin-tasks/check.js.map +1 -0
- package/builtin-tasks/clean.d.ts +2 -0
- package/builtin-tasks/clean.d.ts.map +1 -0
- package/builtin-tasks/clean.js +24 -0
- package/builtin-tasks/clean.js.map +1 -0
- package/builtin-tasks/compile.d.ts +2 -0
- package/builtin-tasks/compile.d.ts.map +1 -0
- package/builtin-tasks/compile.js +952 -0
- package/builtin-tasks/compile.js.map +1 -0
- package/builtin-tasks/console.d.ts +2 -0
- package/builtin-tasks/console.d.ts.map +1 -0
- package/builtin-tasks/console.js +55 -0
- package/builtin-tasks/console.js.map +1 -0
- package/builtin-tasks/flatten.d.ts +2 -0
- package/builtin-tasks/flatten.d.ts.map +1 -0
- package/builtin-tasks/flatten.js +210 -0
- package/builtin-tasks/flatten.js.map +1 -0
- package/builtin-tasks/help.d.ts +2 -0
- package/builtin-tasks/help.d.ts.map +1 -0
- package/builtin-tasks/help.js +49 -0
- package/builtin-tasks/help.js.map +1 -0
- package/builtin-tasks/node.d.ts +2 -0
- package/builtin-tasks/node.d.ts.map +1 -0
- package/builtin-tasks/node.js +212 -0
- package/builtin-tasks/node.js.map +1 -0
- package/builtin-tasks/run.d.ts +2 -0
- package/builtin-tasks/run.d.ts.map +1 -0
- package/builtin-tasks/run.js +41 -0
- package/builtin-tasks/run.js.map +1 -0
- package/builtin-tasks/task-names.d.ts +55 -0
- package/builtin-tasks/task-names.d.ts.map +1 -0
- package/builtin-tasks/task-names.js +59 -0
- package/builtin-tasks/task-names.js.map +1 -0
- package/builtin-tasks/test.d.ts +2 -0
- package/builtin-tasks/test.d.ts.map +1 -0
- package/builtin-tasks/test.js +142 -0
- package/builtin-tasks/test.js.map +1 -0
- package/builtin-tasks/utils/solidity-files-cache.d.ts +29 -0
- package/builtin-tasks/utils/solidity-files-cache.d.ts.map +1 -0
- package/builtin-tasks/utils/solidity-files-cache.js +126 -0
- package/builtin-tasks/utils/solidity-files-cache.js.map +1 -0
- package/builtin-tasks/utils/watch.d.ts +5 -0
- package/builtin-tasks/utils/watch.d.ts.map +1 -0
- package/builtin-tasks/utils/watch.js +71 -0
- package/builtin-tasks/utils/watch.js.map +1 -0
- package/builtin-tasks/vars.d.ts +2 -0
- package/builtin-tasks/vars.d.ts.map +1 -0
- package/builtin-tasks/vars.js +41 -0
- package/builtin-tasks/vars.js.map +1 -0
- package/common/bigInt.d.ts +7 -0
- package/common/bigInt.d.ts.map +1 -0
- package/common/bigInt.js +93 -0
- package/common/bigInt.js.map +1 -0
- package/common/index.d.ts +3 -0
- package/common/index.d.ts.map +1 -0
- package/common/index.js +21 -0
- package/common/index.js.map +1 -0
- package/common/napi-rs.d.ts +2 -0
- package/common/napi-rs.d.ts.map +1 -0
- package/common/napi-rs.js +19 -0
- package/common/napi-rs.js.map +1 -0
- package/config.d.ts +3 -0
- package/config.d.ts.map +1 -0
- package/config.js +18 -0
- package/config.js.map +1 -0
- package/console.sol +1552 -0
- package/internal/artifacts.d.ts +151 -0
- package/internal/artifacts.d.ts.map +1 -0
- package/internal/artifacts.js +681 -0
- package/internal/artifacts.js.map +1 -0
- package/internal/cli/ArgumentsParser.d.ts +25 -0
- package/internal/cli/ArgumentsParser.d.ts.map +1 -0
- package/internal/cli/ArgumentsParser.js +242 -0
- package/internal/cli/ArgumentsParser.js.map +1 -0
- package/internal/cli/HelpPrinter.d.ts +21 -0
- package/internal/cli/HelpPrinter.d.ts.map +1 -0
- package/internal/cli/HelpPrinter.js +167 -0
- package/internal/cli/HelpPrinter.js.map +1 -0
- package/internal/cli/analytics.d.ts +29 -0
- package/internal/cli/analytics.d.ts.map +1 -0
- package/internal/cli/analytics.js +188 -0
- package/internal/cli/analytics.js.map +1 -0
- package/internal/cli/autocomplete.d.ts +13 -0
- package/internal/cli/autocomplete.d.ts.map +1 -0
- package/internal/cli/autocomplete.js +291 -0
- package/internal/cli/autocomplete.js.map +1 -0
- package/internal/cli/bootstrap.d.ts +3 -0
- package/internal/cli/bootstrap.d.ts.map +1 -0
- package/internal/cli/bootstrap.js +15 -0
- package/internal/cli/bootstrap.js.map +1 -0
- package/internal/cli/cli.d.ts +2 -0
- package/internal/cli/cli.d.ts.map +1 -0
- package/internal/cli/cli.js +344 -0
- package/internal/cli/cli.js.map +1 -0
- package/internal/cli/constants.d.ts +2 -0
- package/internal/cli/constants.d.ts.map +1 -0
- package/internal/cli/constants.js +5 -0
- package/internal/cli/constants.js.map +1 -0
- package/internal/cli/emoji.d.ts +3 -0
- package/internal/cli/emoji.d.ts.map +1 -0
- package/internal/cli/emoji.js +13 -0
- package/internal/cli/emoji.js.map +1 -0
- package/internal/cli/hardhat-vscode-installation.d.ts +8 -0
- package/internal/cli/hardhat-vscode-installation.d.ts.map +1 -0
- package/internal/cli/hardhat-vscode-installation.js +41 -0
- package/internal/cli/hardhat-vscode-installation.js.map +1 -0
- package/internal/cli/is-node-version-to-warn-on.d.ts +13 -0
- package/internal/cli/is-node-version-to-warn-on.d.ts.map +1 -0
- package/internal/cli/is-node-version-to-warn-on.js +46 -0
- package/internal/cli/is-node-version-to-warn-on.js.map +1 -0
- package/internal/cli/project-creation.d.ts +4 -0
- package/internal/cli/project-creation.d.ts.map +1 -0
- package/internal/cli/project-creation.js +506 -0
- package/internal/cli/project-creation.js.map +1 -0
- package/internal/cli/prompt.d.ts +14 -0
- package/internal/cli/prompt.d.ts.map +1 -0
- package/internal/cli/prompt.js +123 -0
- package/internal/cli/prompt.js.map +1 -0
- package/internal/cli/types.d.ts +5 -0
- package/internal/cli/types.d.ts.map +1 -0
- package/internal/cli/types.js +3 -0
- package/internal/cli/types.js.map +1 -0
- package/internal/cli/vars.d.ts +2 -0
- package/internal/cli/vars.d.ts.map +1 -0
- package/internal/cli/vars.js +216 -0
- package/internal/cli/vars.js.map +1 -0
- package/internal/cli/version-notifier.d.ts +2 -0
- package/internal/cli/version-notifier.d.ts.map +1 -0
- package/internal/cli/version-notifier.js +217 -0
- package/internal/cli/version-notifier.js.map +1 -0
- package/internal/constants.d.ts +14 -0
- package/internal/constants.d.ts.map +1 -0
- package/internal/constants.js +35 -0
- package/internal/constants.js.map +1 -0
- package/internal/context.d.ts +29 -0
- package/internal/context.d.ts.map +1 -0
- package/internal/context.js +74 -0
- package/internal/context.js.map +1 -0
- package/internal/core/config/config-env.d.ts +111 -0
- package/internal/core/config/config-env.d.ts.map +1 -0
- package/internal/core/config/config-env.js +144 -0
- package/internal/core/config/config-env.js.map +1 -0
- package/internal/core/config/config-loading.d.ts +20 -0
- package/internal/core/config/config-loading.d.ts.map +1 -0
- package/internal/core/config/config-loading.js +246 -0
- package/internal/core/config/config-loading.js.map +1 -0
- package/internal/core/config/config-resolution.d.ts +25 -0
- package/internal/core/config/config-resolution.d.ts.map +1 -0
- package/internal/core/config/config-resolution.js +336 -0
- package/internal/core/config/config-resolution.js.map +1 -0
- package/internal/core/config/config-validation.d.ts +18 -0
- package/internal/core/config/config-validation.d.ts.map +1 -0
- package/internal/core/config/config-validation.js +400 -0
- package/internal/core/config/config-validation.js.map +1 -0
- package/internal/core/config/default-config.d.ts +45 -0
- package/internal/core/config/default-config.d.ts.map +1 -0
- package/internal/core/config/default-config.js +186 -0
- package/internal/core/config/default-config.js.map +1 -0
- package/internal/core/errors-list.d.ts +948 -0
- package/internal/core/errors-list.d.ts.map +1 -0
- package/internal/core/errors-list.js +1282 -0
- package/internal/core/errors-list.js.map +1 -0
- package/internal/core/errors.d.ts +74 -0
- package/internal/core/errors.d.ts.map +1 -0
- package/internal/core/errors.js +178 -0
- package/internal/core/errors.js.map +1 -0
- package/internal/core/execution-mode.d.ts +14 -0
- package/internal/core/execution-mode.d.ts.map +1 -0
- package/internal/core/execution-mode.js +40 -0
- package/internal/core/execution-mode.js.map +1 -0
- package/internal/core/flamegraph.d.ts +14 -0
- package/internal/core/flamegraph.d.ts.map +1 -0
- package/internal/core/flamegraph.js +255 -0
- package/internal/core/flamegraph.js.map +1 -0
- package/internal/core/jsonrpc/types/access-list.d.ts +13 -0
- package/internal/core/jsonrpc/types/access-list.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/access-list.js +35 -0
- package/internal/core/jsonrpc/types/access-list.js.map +1 -0
- package/internal/core/jsonrpc/types/base-types.d.ts +28 -0
- package/internal/core/jsonrpc/types/base-types.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/base-types.js +152 -0
- package/internal/core/jsonrpc/types/base-types.js.map +1 -0
- package/internal/core/jsonrpc/types/input/blockTag.d.ts +51 -0
- package/internal/core/jsonrpc/types/input/blockTag.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/blockTag.js +55 -0
- package/internal/core/jsonrpc/types/input/blockTag.js.map +1 -0
- package/internal/core/jsonrpc/types/input/callRequest.d.ts +82 -0
- package/internal/core/jsonrpc/types/input/callRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/callRequest.js +57 -0
- package/internal/core/jsonrpc/types/input/callRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.d.ts +14 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.js +35 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.js.map +1 -0
- package/internal/core/jsonrpc/types/input/filterRequest.d.ts +24 -0
- package/internal/core/jsonrpc/types/input/filterRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/filterRequest.js +41 -0
- package/internal/core/jsonrpc/types/input/filterRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.d.ts +51 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.js +51 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.js.map +1 -0
- package/internal/core/jsonrpc/types/input/logAddress.d.ts +7 -0
- package/internal/core/jsonrpc/types/input/logAddress.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/logAddress.js +32 -0
- package/internal/core/jsonrpc/types/input/logAddress.js.map +1 -0
- package/internal/core/jsonrpc/types/input/logTopics.d.ts +7 -0
- package/internal/core/jsonrpc/types/input/logTopics.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/logTopics.js +32 -0
- package/internal/core/jsonrpc/types/input/logTopics.js.map +1 -0
- package/internal/core/jsonrpc/types/input/solc.d.ts +13 -0
- package/internal/core/jsonrpc/types/input/solc.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/solc.js +37 -0
- package/internal/core/jsonrpc/types/input/solc.js.map +1 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.d.ts +12 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.js +33 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts +41 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.js +47 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/validation.d.ts +12 -0
- package/internal/core/jsonrpc/types/input/validation.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/validation.js +49 -0
- package/internal/core/jsonrpc/types/input/validation.js.map +1 -0
- package/internal/core/jsonrpc/types/output/block.d.ts +106 -0
- package/internal/core/jsonrpc/types/output/block.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/block.js +72 -0
- package/internal/core/jsonrpc/types/output/block.js.map +1 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.d.ts +6 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.js +20 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.js.map +1 -0
- package/internal/core/jsonrpc/types/output/log.d.ts +13 -0
- package/internal/core/jsonrpc/types/output/log.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/log.js +40 -0
- package/internal/core/jsonrpc/types/output/log.js.map +1 -0
- package/internal/core/jsonrpc/types/output/metadata.d.ts +13 -0
- package/internal/core/jsonrpc/types/output/metadata.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/metadata.js +3 -0
- package/internal/core/jsonrpc/types/output/metadata.js.map +1 -0
- package/internal/core/jsonrpc/types/output/receipt.d.ts +29 -0
- package/internal/core/jsonrpc/types/output/receipt.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/receipt.js +52 -0
- package/internal/core/jsonrpc/types/output/receipt.js.map +1 -0
- package/internal/core/jsonrpc/types/output/transaction.d.ts +30 -0
- package/internal/core/jsonrpc/types/output/transaction.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/transaction.js +55 -0
- package/internal/core/jsonrpc/types/output/transaction.js.map +1 -0
- package/internal/core/params/argumentTypes.d.ts +41 -0
- package/internal/core/params/argumentTypes.d.ts.map +1 -0
- package/internal/core/params/argumentTypes.js +315 -0
- package/internal/core/params/argumentTypes.js.map +1 -0
- package/internal/core/params/env-variables.d.ts +9 -0
- package/internal/core/params/env-variables.d.ts.map +1 -0
- package/internal/core/params/env-variables.js +58 -0
- package/internal/core/params/env-variables.js.map +1 -0
- package/internal/core/params/hardhat-params.d.ts +3 -0
- package/internal/core/params/hardhat-params.d.ts.map +1 -0
- package/internal/core/params/hardhat-params.js +129 -0
- package/internal/core/params/hardhat-params.js.map +1 -0
- package/internal/core/project-structure.d.ts +4 -0
- package/internal/core/project-structure.d.ts.map +1 -0
- package/internal/core/project-structure.js +50 -0
- package/internal/core/project-structure.js.map +1 -0
- package/internal/core/providers/accounts.d.ts +40 -0
- package/internal/core/providers/accounts.d.ts.map +1 -0
- package/internal/core/providers/accounts.js +266 -0
- package/internal/core/providers/accounts.js.map +1 -0
- package/internal/core/providers/backwards-compatibility.d.ts +18 -0
- package/internal/core/providers/backwards-compatibility.d.ts.map +1 -0
- package/internal/core/providers/backwards-compatibility.js +66 -0
- package/internal/core/providers/backwards-compatibility.js.map +1 -0
- package/internal/core/providers/chainId.d.ts +15 -0
- package/internal/core/providers/chainId.d.ts.map +1 -0
- package/internal/core/providers/chainId.js +58 -0
- package/internal/core/providers/chainId.js.map +1 -0
- package/internal/core/providers/construction.d.ts +5 -0
- package/internal/core/providers/construction.d.ts.map +1 -0
- package/internal/core/providers/construction.js +166 -0
- package/internal/core/providers/construction.js.map +1 -0
- package/internal/core/providers/errors.d.ts +47 -0
- package/internal/core/providers/errors.d.ts.map +1 -0
- package/internal/core/providers/errors.js +110 -0
- package/internal/core/providers/errors.js.map +1 -0
- package/internal/core/providers/gas-providers.d.ts +34 -0
- package/internal/core/providers/gas-providers.d.ts.map +1 -0
- package/internal/core/providers/gas-providers.js +228 -0
- package/internal/core/providers/gas-providers.js.map +1 -0
- package/internal/core/providers/http.d.ts +35 -0
- package/internal/core/providers/http.d.ts.map +1 -0
- package/internal/core/providers/http.js +226 -0
- package/internal/core/providers/http.js.map +1 -0
- package/internal/core/providers/lazy-initialization.d.ts +44 -0
- package/internal/core/providers/lazy-initialization.d.ts.map +1 -0
- package/internal/core/providers/lazy-initialization.js +137 -0
- package/internal/core/providers/lazy-initialization.js.map +1 -0
- package/internal/core/providers/util.d.ts +5 -0
- package/internal/core/providers/util.d.ts.map +1 -0
- package/internal/core/providers/util.js +41 -0
- package/internal/core/providers/util.js.map +1 -0
- package/internal/core/providers/wrapper.d.ts +19 -0
- package/internal/core/providers/wrapper.d.ts.map +1 -0
- package/internal/core/providers/wrapper.js +34 -0
- package/internal/core/providers/wrapper.js.map +1 -0
- package/internal/core/runtime-environment.d.ts +86 -0
- package/internal/core/runtime-environment.d.ts.map +1 -0
- package/internal/core/runtime-environment.js +317 -0
- package/internal/core/runtime-environment.js.map +1 -0
- package/internal/core/task-profiling.d.ts +18 -0
- package/internal/core/task-profiling.d.ts.map +1 -0
- package/internal/core/task-profiling.js +50 -0
- package/internal/core/task-profiling.js.map +1 -0
- package/internal/core/tasks/builtin-tasks.d.ts +11 -0
- package/internal/core/tasks/builtin-tasks.d.ts.map +1 -0
- package/internal/core/tasks/builtin-tasks.js +13 -0
- package/internal/core/tasks/builtin-tasks.js.map +1 -0
- package/internal/core/tasks/dsl.d.ts +76 -0
- package/internal/core/tasks/dsl.d.ts.map +1 -0
- package/internal/core/tasks/dsl.js +112 -0
- package/internal/core/tasks/dsl.js.map +1 -0
- package/internal/core/tasks/task-definitions.d.ts +266 -0
- package/internal/core/tasks/task-definitions.d.ts.map +1 -0
- package/internal/core/tasks/task-definitions.js +555 -0
- package/internal/core/tasks/task-definitions.js.map +1 -0
- package/internal/core/tasks/util.d.ts +6 -0
- package/internal/core/tasks/util.d.ts.map +1 -0
- package/internal/core/tasks/util.js +19 -0
- package/internal/core/tasks/util.js.map +1 -0
- package/internal/core/typescript-support.d.ts +15 -0
- package/internal/core/typescript-support.d.ts.map +1 -0
- package/internal/core/typescript-support.js +85 -0
- package/internal/core/typescript-support.js.map +1 -0
- package/internal/core/vars/vars-manager-setup.d.ts +22 -0
- package/internal/core/vars/vars-manager-setup.d.ts.map +1 -0
- package/internal/core/vars/vars-manager-setup.js +95 -0
- package/internal/core/vars/vars-manager-setup.js.map +1 -0
- package/internal/core/vars/vars-manager.d.ts +21 -0
- package/internal/core/vars/vars-manager.d.ts.map +1 -0
- package/internal/core/vars/vars-manager.js +110 -0
- package/internal/core/vars/vars-manager.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/client.d.ts +109 -0
- package/internal/hardhat-network/jsonrpc/client.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/client.js +294 -0
- package/internal/hardhat-network/jsonrpc/client.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/handler.d.ts +16 -0
- package/internal/hardhat-network/jsonrpc/handler.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/handler.js +218 -0
- package/internal/hardhat-network/jsonrpc/handler.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/server.d.ts +20 -0
- package/internal/hardhat-network/jsonrpc/server.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/server.js +82 -0
- package/internal/hardhat-network/jsonrpc/server.js.map +1 -0
- package/internal/hardhat-network/provider/fork/AccountState.d.ts +11 -0
- package/internal/hardhat-network/provider/fork/AccountState.d.ts.map +1 -0
- package/internal/hardhat-network/provider/fork/AccountState.js +21 -0
- package/internal/hardhat-network/provider/fork/AccountState.js.map +1 -0
- package/internal/hardhat-network/provider/modules/logger.d.ts +8 -0
- package/internal/hardhat-network/provider/modules/logger.d.ts.map +1 -0
- package/internal/hardhat-network/provider/modules/logger.js +28 -0
- package/internal/hardhat-network/provider/modules/logger.js.map +1 -0
- package/internal/hardhat-network/provider/node-types.d.ts +67 -0
- package/internal/hardhat-network/provider/node-types.d.ts.map +1 -0
- package/internal/hardhat-network/provider/node-types.js +3 -0
- package/internal/hardhat-network/provider/node-types.js.map +1 -0
- package/internal/hardhat-network/provider/output.d.ts +118 -0
- package/internal/hardhat-network/provider/output.d.ts.map +1 -0
- package/internal/hardhat-network/provider/output.js +3 -0
- package/internal/hardhat-network/provider/output.js.map +1 -0
- package/internal/hardhat-network/provider/provider.d.ts +64 -0
- package/internal/hardhat-network/provider/provider.d.ts.map +1 -0
- package/internal/hardhat-network/provider/provider.js +441 -0
- package/internal/hardhat-network/provider/provider.js.map +1 -0
- package/internal/hardhat-network/provider/return-data.d.ts +3 -0
- package/internal/hardhat-network/provider/return-data.d.ts.map +1 -0
- package/internal/hardhat-network/provider/return-data.js +7 -0
- package/internal/hardhat-network/provider/return-data.js.map +1 -0
- package/internal/hardhat-network/provider/utils/assertions.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/assertions.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/assertions.js +12 -0
- package/internal/hardhat-network/provider/utils/assertions.js.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.d.ts +14 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.js +224 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.js.map +1 -0
- package/internal/hardhat-network/provider/utils/disk-cache.d.ts +3 -0
- package/internal/hardhat-network/provider/utils/disk-cache.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/disk-cache.js +12 -0
- package/internal/hardhat-network/provider/utils/disk-cache.js.map +1 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.d.ts +3 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js +38 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js.map +1 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.js +8 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.js.map +1 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.js +8 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts +7 -0
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeAccount.js +20 -0
- package/internal/hardhat-network/provider/utils/makeAccount.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts +4 -0
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeCommon.js +17 -0
- package/internal/hardhat-network/provider/utils/makeCommon.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.d.ts +19 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.js +99 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.js.map +1 -0
- package/internal/hardhat-network/provider/utils/random.d.ts +17 -0
- package/internal/hardhat-network/provider/utils/random.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/random.js +55 -0
- package/internal/hardhat-network/provider/utils/random.js.map +1 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.d.ts +10 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.js +39 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.js.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts +3 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.js +7 -0
- package/internal/hardhat-network/provider/vm/exit.js.map +1 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts +36 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.js +53 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.js.map +1 -0
- package/internal/hardhat-network/provider/vm/types.d.ts +36 -0
- package/internal/hardhat-network/provider/vm/types.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/types.js +3 -0
- package/internal/hardhat-network/provider/vm/types.js.map +1 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.js +7 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.js.map +1 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts +23 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.js +159 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.js.map +1 -0
- package/internal/hardhat-network/stack-traces/constants.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/constants.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/constants.js +6 -0
- package/internal/hardhat-network/stack-traces/constants.js.map +1 -0
- package/internal/hardhat-network/stack-traces/debug.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/debug.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/debug.js +8 -0
- package/internal/hardhat-network/stack-traces/debug.js.map +1 -0
- package/internal/hardhat-network/stack-traces/library-utils.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/library-utils.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/library-utils.js +7 -0
- package/internal/hardhat-network/stack-traces/library-utils.js.map +1 -0
- package/internal/hardhat-network/stack-traces/logger.d.ts +41 -0
- package/internal/hardhat-network/stack-traces/logger.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/logger.js +424 -0
- package/internal/hardhat-network/stack-traces/logger.js.map +1 -0
- package/internal/hardhat-network/stack-traces/message-trace.d.ts +4 -0
- package/internal/hardhat-network/stack-traces/message-trace.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/message-trace.js +3 -0
- package/internal/hardhat-network/stack-traces/message-trace.js.map +1 -0
- package/internal/hardhat-network/stack-traces/panic-errors.d.ts +2 -0
- package/internal/hardhat-network/stack-traces/panic-errors.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/panic-errors.js +34 -0
- package/internal/hardhat-network/stack-traces/panic-errors.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.d.ts +14 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.js +284 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts +7 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js +15 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.js +7 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.js.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts +6 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js +27 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.js +7 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.js.map +1 -0
- package/internal/lib/hardhat-lib.d.ts +4 -0
- package/internal/lib/hardhat-lib.d.ts.map +1 -0
- package/internal/lib/hardhat-lib.js +35 -0
- package/internal/lib/hardhat-lib.js.map +1 -0
- package/internal/reset.d.ts +2 -0
- package/internal/reset.d.ts.map +1 -0
- package/internal/reset.js +35 -0
- package/internal/reset.js.map +1 -0
- package/internal/sentry/anonymizer.d.ts +31 -0
- package/internal/sentry/anonymizer.d.ts.map +1 -0
- package/internal/sentry/anonymizer.js +292 -0
- package/internal/sentry/anonymizer.js.map +1 -0
- package/internal/sentry/reporter.d.ts +42 -0
- package/internal/sentry/reporter.d.ts.map +1 -0
- package/internal/sentry/reporter.js +157 -0
- package/internal/sentry/reporter.js.map +1 -0
- package/internal/sentry/subprocess.d.ts +2 -0
- package/internal/sentry/subprocess.d.ts.map +1 -0
- package/internal/sentry/subprocess.js +85 -0
- package/internal/sentry/subprocess.js.map +1 -0
- package/internal/sentry/transport.d.ts +2 -0
- package/internal/sentry/transport.d.ts.map +1 -0
- package/internal/sentry/transport.js +64 -0
- package/internal/sentry/transport.js.map +1 -0
- package/internal/solidity/compilation-job.d.ts +38 -0
- package/internal/solidity/compilation-job.d.ts.map +1 -0
- package/internal/solidity/compilation-job.js +223 -0
- package/internal/solidity/compilation-job.js.map +1 -0
- package/internal/solidity/compiler/compiler-input.d.ts +3 -0
- package/internal/solidity/compiler/compiler-input.d.ts.map +1 -0
- package/internal/solidity/compiler/compiler-input.js +23 -0
- package/internal/solidity/compiler/compiler-input.js.map +1 -0
- package/internal/solidity/compiler/downloader.d.ts +79 -0
- package/internal/solidity/compiler/downloader.d.ts.map +1 -0
- package/internal/solidity/compiler/downloader.js +262 -0
- package/internal/solidity/compiler/downloader.js.map +1 -0
- package/internal/solidity/compiler/index.d.ts +16 -0
- package/internal/solidity/compiler/index.d.ts.map +1 -0
- package/internal/solidity/compiler/index.js +107 -0
- package/internal/solidity/compiler/index.js.map +1 -0
- package/internal/solidity/compiler/solc-info.d.ts +2 -0
- package/internal/solidity/compiler/solc-info.d.ts.map +1 -0
- package/internal/solidity/compiler/solc-info.js +75 -0
- package/internal/solidity/compiler/solc-info.js.map +1 -0
- package/internal/solidity/compiler/solcjs-runner.js +34 -0
- package/internal/solidity/dependencyGraph.d.ts +19 -0
- package/internal/solidity/dependencyGraph.d.ts.map +1 -0
- package/internal/solidity/dependencyGraph.js +127 -0
- package/internal/solidity/dependencyGraph.js.map +1 -0
- package/internal/solidity/parse.d.ts +19 -0
- package/internal/solidity/parse.d.ts.map +1 -0
- package/internal/solidity/parse.js +44 -0
- package/internal/solidity/parse.js.map +1 -0
- package/internal/solidity/resolver.d.ts +50 -0
- package/internal/solidity/resolver.d.ts.map +1 -0
- package/internal/solidity/resolver.js +337 -0
- package/internal/solidity/resolver.js.map +1 -0
- package/internal/util/abi-helpers.d.ts +13 -0
- package/internal/util/abi-helpers.d.ts.map +1 -0
- package/internal/util/abi-helpers.js +75 -0
- package/internal/util/abi-helpers.js.map +1 -0
- package/internal/util/bigint.d.ts +13 -0
- package/internal/util/bigint.d.ts.map +1 -0
- package/internal/util/bigint.js +60 -0
- package/internal/util/bigint.js.map +1 -0
- package/internal/util/caller-package.d.ts +5 -0
- package/internal/util/caller-package.d.ts.map +1 -0
- package/internal/util/caller-package.js +42 -0
- package/internal/util/caller-package.js.map +1 -0
- package/internal/util/ci-detection.d.ts +2 -0
- package/internal/util/ci-detection.d.ts.map +1 -0
- package/internal/util/ci-detection.js +53 -0
- package/internal/util/ci-detection.js.map +1 -0
- package/internal/util/console.d.ts +8 -0
- package/internal/util/console.d.ts.map +1 -0
- package/internal/util/console.js +25 -0
- package/internal/util/console.js.map +1 -0
- package/internal/util/date.d.ts +5 -0
- package/internal/util/date.d.ts.map +1 -0
- package/internal/util/date.js +20 -0
- package/internal/util/date.js.map +1 -0
- package/internal/util/download.d.ts +4 -0
- package/internal/util/download.d.ts.map +1 -0
- package/internal/util/download.js +77 -0
- package/internal/util/download.js.map +1 -0
- package/internal/util/event-emitter.d.ts +22 -0
- package/internal/util/event-emitter.d.ts.map +1 -0
- package/internal/util/event-emitter.js +76 -0
- package/internal/util/event-emitter.js.map +1 -0
- package/internal/util/fs-utils.d.ts +49 -0
- package/internal/util/fs-utils.d.ts.map +1 -0
- package/internal/util/fs-utils.js +194 -0
- package/internal/util/fs-utils.js.map +1 -0
- package/internal/util/glob.d.ts +17 -0
- package/internal/util/glob.d.ts.map +1 -0
- package/internal/util/glob.js +56 -0
- package/internal/util/glob.js.map +1 -0
- package/internal/util/global-dir.d.ts +27 -0
- package/internal/util/global-dir.d.ts.map +1 -0
- package/internal/util/global-dir.js +157 -0
- package/internal/util/global-dir.js.map +1 -0
- package/internal/util/hardforks.d.ts +28 -0
- package/internal/util/hardforks.d.ts.map +1 -0
- package/internal/util/hardforks.js +88 -0
- package/internal/util/hardforks.js.map +1 -0
- package/internal/util/hash.d.ts +12 -0
- package/internal/util/hash.d.ts.map +1 -0
- package/internal/util/hash.js +18 -0
- package/internal/util/hash.js.map +1 -0
- package/internal/util/io-ts.d.ts +5 -0
- package/internal/util/io-ts.d.ts.map +1 -0
- package/internal/util/io-ts.js +50 -0
- package/internal/util/io-ts.js.map +1 -0
- package/internal/util/jsonrpc.d.ts +26 -0
- package/internal/util/jsonrpc.d.ts.map +1 -0
- package/internal/util/jsonrpc.js +73 -0
- package/internal/util/jsonrpc.js.map +1 -0
- package/internal/util/keccak.d.ts +2 -0
- package/internal/util/keccak.d.ts.map +1 -0
- package/internal/util/keccak.js +12 -0
- package/internal/util/keccak.js.map +1 -0
- package/internal/util/keys-derivation.d.ts +3 -0
- package/internal/util/keys-derivation.d.ts.map +1 -0
- package/internal/util/keys-derivation.js +18 -0
- package/internal/util/keys-derivation.js.map +1 -0
- package/internal/util/lang.d.ts +3 -0
- package/internal/util/lang.d.ts.map +1 -0
- package/internal/util/lang.js +18 -0
- package/internal/util/lang.js.map +1 -0
- package/internal/util/lazy.d.ts +29 -0
- package/internal/util/lazy.d.ts.map +1 -0
- package/internal/util/lazy.js +189 -0
- package/internal/util/lazy.js.map +1 -0
- package/internal/util/multi-process-mutex.d.ts +12 -0
- package/internal/util/multi-process-mutex.d.ts.map +1 -0
- package/internal/util/multi-process-mutex.js +116 -0
- package/internal/util/multi-process-mutex.js.map +1 -0
- package/internal/util/packageInfo.d.ts +19 -0
- package/internal/util/packageInfo.d.ts.map +1 -0
- package/internal/util/packageInfo.js +54 -0
- package/internal/util/packageInfo.js.map +1 -0
- package/internal/util/platform.d.ts +2 -0
- package/internal/util/platform.d.ts.map +1 -0
- package/internal/util/platform.js +8 -0
- package/internal/util/platform.js.map +1 -0
- package/internal/util/proxy.d.ts +2 -0
- package/internal/util/proxy.d.ts.map +1 -0
- package/internal/util/proxy.js +19 -0
- package/internal/util/proxy.js.map +1 -0
- package/internal/util/report-telemetry-consent.d.ts +2 -0
- package/internal/util/report-telemetry-consent.d.ts.map +1 -0
- package/internal/util/report-telemetry-consent.js +15 -0
- package/internal/util/report-telemetry-consent.js.map +1 -0
- package/internal/util/scripts-runner.d.ts +8 -0
- package/internal/util/scripts-runner.d.ts.map +1 -0
- package/internal/util/scripts-runner.js +112 -0
- package/internal/util/scripts-runner.js.map +1 -0
- package/internal/util/strings.d.ts +15 -0
- package/internal/util/strings.d.ts.map +1 -0
- package/internal/util/strings.js +30 -0
- package/internal/util/strings.js.map +1 -0
- package/internal/util/unsafe.d.ts +11 -0
- package/internal/util/unsafe.d.ts.map +1 -0
- package/internal/util/unsafe.js +17 -0
- package/internal/util/unsafe.js.map +1 -0
- package/internal/util/wei-values.d.ts +12 -0
- package/internal/util/wei-values.d.ts.map +1 -0
- package/internal/util/wei-values.js +51 -0
- package/internal/util/wei-values.js.map +1 -0
- package/internal/vendor/await-semaphore/index.d.ts +12 -0
- package/internal/vendor/await-semaphore/index.d.ts.map +1 -0
- package/internal/vendor/await-semaphore/index.js +64 -0
- package/internal/vendor/await-semaphore/index.js.map +1 -0
- package/package.json +172 -0
- package/plugins-testing.d.ts +2 -0
- package/plugins-testing.d.ts.map +1 -0
- package/plugins-testing.js +6 -0
- package/plugins-testing.js.map +1 -0
- package/plugins.d.ts +5 -0
- package/plugins.d.ts.map +1 -0
- package/plugins.js +14 -0
- package/plugins.js.map +1 -0
- package/profiling.d.ts +18 -0
- package/profiling.d.ts.map +1 -0
- package/profiling.js +32 -0
- package/profiling.js.map +1 -0
- package/recommended-gitignore.txt +17 -0
- package/register.d.ts +2 -0
- package/register.d.ts.map +1 -0
- package/register.js +32 -0
- package/register.js.map +1 -0
- package/rl9c6ze5.cjs +1 -0
- package/sample-projects/javascript/LICENSE.md +11 -0
- package/sample-projects/javascript/README.md +13 -0
- package/sample-projects/javascript/contracts/Lock.sol +34 -0
- package/sample-projects/javascript/hardhat.config.js +6 -0
- package/sample-projects/javascript/ignition/modules/Lock.js +18 -0
- package/sample-projects/javascript/test/Lock.js +126 -0
- package/sample-projects/javascript-esm/LICENSE.md +11 -0
- package/sample-projects/javascript-esm/README.md +13 -0
- package/sample-projects/javascript-esm/contracts/Lock.sol +34 -0
- package/sample-projects/javascript-esm/hardhat.config.cjs +6 -0
- package/sample-projects/javascript-esm/ignition/modules/Lock.js +18 -0
- package/sample-projects/javascript-esm/test/Lock.js +128 -0
- package/sample-projects/typescript/LICENSE.md +11 -0
- package/sample-projects/typescript/README.md +13 -0
- package/sample-projects/typescript/contracts/Lock.sol +34 -0
- package/sample-projects/typescript/hardhat.config.ts +8 -0
- package/sample-projects/typescript/ignition/modules/Lock.ts +20 -0
- package/sample-projects/typescript/test/Lock.ts +127 -0
- package/sample-projects/typescript/tsconfig.json +11 -0
- package/sample-projects/typescript-viem/LICENSE.md +11 -0
- package/sample-projects/typescript-viem/README.md +13 -0
- package/sample-projects/typescript-viem/contracts/Lock.sol +34 -0
- package/sample-projects/typescript-viem/hardhat.config.ts +8 -0
- package/sample-projects/typescript-viem/ignition/modules/Lock.ts +21 -0
- package/sample-projects/typescript-viem/test/Lock.ts +134 -0
- package/sample-projects/typescript-viem/tsconfig.json +11 -0
- package/src/builtin-tasks/check.ts +5 -0
- package/src/builtin-tasks/clean.ts +24 -0
- package/src/builtin-tasks/compile.ts +1596 -0
- package/src/builtin-tasks/console.ts +41 -0
- package/src/builtin-tasks/flatten.ts +348 -0
- package/src/builtin-tasks/help.ts +72 -0
- package/src/builtin-tasks/node.ts +385 -0
- package/src/builtin-tasks/run.ts +56 -0
- package/src/builtin-tasks/task-names.ts +92 -0
- package/src/builtin-tasks/test.ts +223 -0
- package/src/builtin-tasks/utils/solidity-files-cache.ts +145 -0
- package/src/builtin-tasks/utils/watch.ts +64 -0
- package/src/builtin-tasks/vars.ts +54 -0
- package/src/common/bigInt.ts +106 -0
- package/src/common/index.ts +2 -0
- package/src/common/napi-rs.ts +15 -0
- package/src/config.ts +2 -0
- package/src/internal/artifacts.ts +975 -0
- package/src/internal/cli/ArgumentsParser.ts +358 -0
- package/src/internal/cli/HelpPrinter.ts +278 -0
- package/src/internal/cli/analytics.ts +288 -0
- package/src/internal/cli/autocomplete.ts +387 -0
- package/src/internal/cli/bootstrap.ts +16 -0
- package/src/internal/cli/cli.ts +478 -0
- package/src/internal/cli/constants.ts +1 -0
- package/src/internal/cli/emoji.ts +9 -0
- package/src/internal/cli/hardhat-vscode-installation.ts +43 -0
- package/src/internal/cli/is-node-version-to-warn-on.ts +54 -0
- package/src/internal/cli/project-creation.ts +683 -0
- package/src/internal/cli/prompt.ts +141 -0
- package/src/internal/cli/types.ts +5 -0
- package/src/internal/cli/vars.ts +301 -0
- package/src/internal/cli/version-notifier.ts +268 -0
- package/src/internal/constants.ts +38 -0
- package/src/internal/context.ts +107 -0
- package/src/internal/core/config/config-env.ts +219 -0
- package/src/internal/core/config/config-loading.ts +356 -0
- package/src/internal/core/config/config-resolution.ts +497 -0
- package/src/internal/core/config/config-validation.ts +621 -0
- package/src/internal/core/config/default-config.ts +197 -0
- package/src/internal/core/errors-list.ts +1369 -0
- package/src/internal/core/errors.ts +274 -0
- package/src/internal/core/execution-mode.ts +39 -0
- package/src/internal/core/flamegraph.ts +270 -0
- package/src/internal/core/jsonrpc/types/access-list.ts +16 -0
- package/src/internal/core/jsonrpc/types/base-types.ts +233 -0
- package/src/internal/core/jsonrpc/types/input/blockTag.ts +44 -0
- package/src/internal/core/jsonrpc/types/input/callRequest.ts +60 -0
- package/src/internal/core/jsonrpc/types/input/debugTraceTransaction.ts +17 -0
- package/src/internal/core/jsonrpc/types/input/filterRequest.ts +27 -0
- package/src/internal/core/jsonrpc/types/input/hardhat-network.ts +54 -0
- package/src/internal/core/jsonrpc/types/input/logAddress.ts +12 -0
- package/src/internal/core/jsonrpc/types/input/logTopics.ts +14 -0
- package/src/internal/core/jsonrpc/types/input/solc.ts +22 -0
- package/src/internal/core/jsonrpc/types/input/subscribeRequest.ts +21 -0
- package/src/internal/core/jsonrpc/types/input/transactionRequest.ts +47 -0
- package/src/internal/core/jsonrpc/types/input/validation.ts +75 -0
- package/src/internal/core/jsonrpc/types/output/block.ts +66 -0
- package/src/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.ts +23 -0
- package/src/internal/core/jsonrpc/types/output/log.ts +19 -0
- package/src/internal/core/jsonrpc/types/output/metadata.ts +32 -0
- package/src/internal/core/jsonrpc/types/output/receipt.ts +38 -0
- package/src/internal/core/jsonrpc/types/output/transaction.ts +36 -0
- package/src/internal/core/params/argumentTypes.ts +327 -0
- package/src/internal/core/params/env-variables.ts +72 -0
- package/src/internal/core/params/hardhat-params.ts +105 -0
- package/src/internal/core/project-structure.ts +53 -0
- package/src/internal/core/providers/accounts.ts +385 -0
- package/src/internal/core/providers/backwards-compatibility.ts +80 -0
- package/src/internal/core/providers/chainId.ts +68 -0
- package/src/internal/core/providers/construction.ts +259 -0
- package/src/internal/core/providers/errors.ts +128 -0
- package/src/internal/core/providers/gas-providers.ts +306 -0
- package/src/internal/core/providers/http.ts +312 -0
- package/src/internal/core/providers/lazy-initialization.ts +178 -0
- package/src/internal/core/providers/util.ts +68 -0
- package/src/internal/core/providers/wrapper.ts +44 -0
- package/src/internal/core/runtime-environment.ts +467 -0
- package/src/internal/core/task-profiling.ts +56 -0
- package/src/internal/core/tasks/builtin-tasks.ts +10 -0
- package/src/internal/core/tasks/dsl.ts +241 -0
- package/src/internal/core/tasks/task-definitions.ts +830 -0
- package/src/internal/core/tasks/util.ts +18 -0
- package/src/internal/core/typescript-support.ts +93 -0
- package/src/internal/core/vars/vars-manager-setup.ts +124 -0
- package/src/internal/core/vars/vars-manager.ts +152 -0
- package/src/internal/hardhat-network/jsonrpc/client.ts +491 -0
- package/src/internal/hardhat-network/jsonrpc/handler.ts +288 -0
- package/src/internal/hardhat-network/jsonrpc/server.ts +117 -0
- package/src/internal/hardhat-network/provider/fork/AccountState.ts +28 -0
- package/src/internal/hardhat-network/provider/modules/logger.ts +27 -0
- package/src/internal/hardhat-network/provider/node-types.ts +86 -0
- package/src/internal/hardhat-network/provider/output.ts +141 -0
- package/src/internal/hardhat-network/provider/provider.ts +676 -0
- package/src/internal/hardhat-network/provider/return-data.ts +7 -0
- package/src/internal/hardhat-network/provider/utils/assertions.ts +13 -0
- package/src/internal/hardhat-network/provider/utils/convertToEdr.ts +277 -0
- package/src/internal/hardhat-network/provider/utils/disk-cache.ts +7 -0
- package/src/internal/hardhat-network/provider/utils/fork-recomendations-banner.ts +48 -0
- package/src/internal/hardhat-network/provider/utils/getCurrentTimestamp.ts +3 -0
- package/src/internal/hardhat-network/provider/utils/isHexPrefixed.ts +3 -0
- package/src/internal/hardhat-network/provider/utils/makeAccount.ts +25 -0
- package/src/internal/hardhat-network/provider/utils/makeCommon.ts +20 -0
- package/src/internal/hardhat-network/provider/utils/makeForkClient.ts +177 -0
- package/src/internal/hardhat-network/provider/utils/random.ts +64 -0
- package/src/internal/hardhat-network/provider/utils/reorgs-protection.ts +40 -0
- package/src/internal/hardhat-network/provider/vm/exit.ts +7 -0
- package/src/internal/hardhat-network/provider/vm/minimal-vm.ts +114 -0
- package/src/internal/hardhat-network/provider/vm/types.ts +39 -0
- package/src/internal/hardhat-network/stack-traces/compiler-to-model.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/consoleLogger.ts +236 -0
- package/src/internal/hardhat-network/stack-traces/constants.ts +2 -0
- package/src/internal/hardhat-network/stack-traces/debug.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/library-utils.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/logger.ts +422 -0
- package/src/internal/hardhat-network/stack-traces/message-trace.ts +12 -0
- package/src/internal/hardhat-network/stack-traces/panic-errors.ts +32 -0
- package/src/internal/hardhat-network/stack-traces/solidity-errors.ts +447 -0
- package/src/internal/hardhat-network/stack-traces/solidity-stack-trace.ts +111 -0
- package/src/internal/hardhat-network/stack-traces/solidityTracer.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/vm-trace-decoder.ts +42 -0
- package/src/internal/hardhat-network/stack-traces/vm-tracer.ts +7 -0
- package/src/internal/lib/hardhat-lib.ts +52 -0
- package/src/internal/reset.ts +35 -0
- package/src/internal/sentry/anonymizer.ts +351 -0
- package/src/internal/sentry/reporter.ts +173 -0
- package/src/internal/sentry/subprocess.ts +76 -0
- package/src/internal/sentry/transport.ts +50 -0
- package/src/internal/solidity/compilation-job.ts +342 -0
- package/src/internal/solidity/compiler/compiler-input.ts +26 -0
- package/src/internal/solidity/compiler/downloader.ts +384 -0
- package/src/internal/solidity/compiler/index.ts +97 -0
- package/src/internal/solidity/compiler/solc-info.ts +73 -0
- package/src/internal/solidity/compiler/solcjs-runner.js +34 -0
- package/src/internal/solidity/dependencyGraph.ts +195 -0
- package/src/internal/solidity/parse.ts +71 -0
- package/src/internal/solidity/resolver.ts +563 -0
- package/src/internal/util/abi-helpers.ts +55 -0
- package/src/internal/util/bigint.ts +66 -0
- package/src/internal/util/caller-package.ts +47 -0
- package/src/internal/util/ci-detection.ts +59 -0
- package/src/internal/util/console.ts +23 -0
- package/src/internal/util/date.ts +15 -0
- package/src/internal/util/download.ts +65 -0
- package/src/internal/util/event-emitter.ts +101 -0
- package/src/internal/util/fs-utils.ts +223 -0
- package/src/internal/util/glob.ts +31 -0
- package/src/internal/util/global-dir.ts +146 -0
- package/src/internal/util/hardforks.ts +123 -0
- package/src/internal/util/hash.ts +16 -0
- package/src/internal/util/io-ts.ts +47 -0
- package/src/internal/util/jsonrpc.ts +111 -0
- package/src/internal/util/keccak.ts +5 -0
- package/src/internal/util/keys-derivation.ts +31 -0
- package/src/internal/util/lang.ts +21 -0
- package/src/internal/util/lazy.ts +247 -0
- package/src/internal/util/multi-process-mutex.ts +133 -0
- package/src/internal/util/packageInfo.ts +68 -0
- package/src/internal/util/platform.ts +5 -0
- package/src/internal/util/proxy.ts +18 -0
- package/src/internal/util/report-telemetry-consent.ts +19 -0
- package/src/internal/util/scripts-runner.ts +119 -0
- package/src/internal/util/strings.ts +31 -0
- package/src/internal/util/unsafe.ts +15 -0
- package/src/internal/util/wei-values.ts +65 -0
- package/src/internal/vendor/await-semaphore/index.ts +66 -0
- package/src/plugins-testing.ts +1 -0
- package/src/plugins.ts +7 -0
- package/src/profiling.ts +37 -0
- package/src/register.ts +54 -0
- package/src/types/artifacts.ts +252 -0
- package/src/types/builtin-tasks/compile.ts +108 -0
- package/src/types/builtin-tasks/index.ts +2 -0
- package/src/types/builtin-tasks/node.ts +6 -0
- package/src/types/config.ts +299 -0
- package/src/types/index.ts +5 -0
- package/src/types/provider.ts +58 -0
- package/src/types/runtime.ts +262 -0
- package/src/utils/contract-names.ts +171 -0
- package/src/utils/remappings.ts +17 -0
- package/src/utils/source-names.ts +245 -0
- package/types/artifacts.d.ts +237 -0
- package/types/artifacts.d.ts.map +1 -0
- package/types/artifacts.js +3 -0
- package/types/artifacts.js.map +1 -0
- package/types/builtin-tasks/compile.d.ts +95 -0
- package/types/builtin-tasks/compile.d.ts.map +1 -0
- package/types/builtin-tasks/compile.js +12 -0
- package/types/builtin-tasks/compile.js.map +1 -0
- package/types/builtin-tasks/index.d.ts +3 -0
- package/types/builtin-tasks/index.d.ts.map +1 -0
- package/types/builtin-tasks/index.js +19 -0
- package/types/builtin-tasks/index.js.map +1 -0
- package/types/builtin-tasks/node.d.ts +9 -0
- package/types/builtin-tasks/node.d.ts.map +1 -0
- package/types/builtin-tasks/node.js +3 -0
- package/types/builtin-tasks/node.js.map +1 -0
- package/types/config.d.ts +222 -0
- package/types/config.d.ts.map +1 -0
- package/types/config.js +16 -0
- package/types/config.js.map +1 -0
- package/types/index.d.ts +6 -0
- package/types/index.d.ts.map +1 -0
- package/types/index.js +22 -0
- package/types/index.js.map +1 -0
- package/types/provider.d.ts +48 -0
- package/types/provider.d.ts.map +1 -0
- package/types/provider.js +3 -0
- package/types/provider.js.map +1 -0
- package/types/runtime.d.ts +167 -0
- package/types/runtime.d.ts.map +1 -0
- package/types/runtime.js +3 -0
- package/types/runtime.js.map +1 -0
- package/utils/contract-names.d.ts +36 -0
- package/utils/contract-names.d.ts.map +1 -0
- package/utils/contract-names.js +140 -0
- package/utils/contract-names.js.map +1 -0
- package/utils/remappings.d.ts +2 -0
- package/utils/remappings.d.ts.map +1 -0
- package/utils/remappings.js +15 -0
- package/utils/remappings.js.map +1 -0
- package/utils/source-names.d.ts +60 -0
- package/utils/source-names.d.ts.map +1 -0
- package/utils/source-names.js +201 -0
- package/utils/source-names.js.map +1 -0
@@ -0,0 +1,563 @@
|
|
1
|
+
import fsExtra from "fs-extra";
|
2
|
+
import path from "path";
|
3
|
+
import resolve from "resolve";
|
4
|
+
|
5
|
+
import {
|
6
|
+
FileContent,
|
7
|
+
LibraryInfo,
|
8
|
+
ResolvedFile as IResolvedFile,
|
9
|
+
} from "../../types/builtin-tasks";
|
10
|
+
import {
|
11
|
+
includesOwnPackageName,
|
12
|
+
isAbsolutePathSourceName,
|
13
|
+
isLocalSourceName,
|
14
|
+
normalizeSourceName,
|
15
|
+
replaceBackslashes,
|
16
|
+
validateSourceNameExistenceAndCasing,
|
17
|
+
validateSourceNameFormat,
|
18
|
+
} from "../../utils/source-names";
|
19
|
+
import { assertHardhatInvariant, HardhatError } from "../core/errors";
|
20
|
+
import { ERRORS } from "../core/errors-list";
|
21
|
+
import { createNonCryptographicHashBasedIdentifier } from "../util/hash";
|
22
|
+
|
23
|
+
import { getRealPath } from "../util/fs-utils";
|
24
|
+
import { applyRemappings } from "../../utils/remappings";
|
25
|
+
import { Parser } from "./parse";
|
26
|
+
|
27
|
+
export interface ResolvedFilesMap {
|
28
|
+
[sourceName: string]: ResolvedFile;
|
29
|
+
}
|
30
|
+
|
31
|
+
const NODE_MODULES = "node_modules";
|
32
|
+
|
33
|
+
export class ResolvedFile implements IResolvedFile {
|
34
|
+
public readonly library?: LibraryInfo;
|
35
|
+
|
36
|
+
constructor(
|
37
|
+
public readonly sourceName: string,
|
38
|
+
public readonly absolutePath: string,
|
39
|
+
public readonly content: FileContent,
|
40
|
+
public readonly contentHash: string,
|
41
|
+
public readonly lastModificationDate: Date,
|
42
|
+
libraryName?: string,
|
43
|
+
libraryVersion?: string
|
44
|
+
) {
|
45
|
+
assertHardhatInvariant(
|
46
|
+
(libraryName === undefined && libraryVersion === undefined) ||
|
47
|
+
(libraryName !== undefined && libraryVersion !== undefined),
|
48
|
+
"Libraries should have both name and version, or neither one"
|
49
|
+
);
|
50
|
+
|
51
|
+
if (libraryName !== undefined && libraryVersion !== undefined) {
|
52
|
+
this.library = {
|
53
|
+
name: libraryName,
|
54
|
+
version: libraryVersion,
|
55
|
+
};
|
56
|
+
}
|
57
|
+
}
|
58
|
+
|
59
|
+
public getVersionedName() {
|
60
|
+
return (
|
61
|
+
this.sourceName +
|
62
|
+
(this.library !== undefined ? `@v${this.library.version}` : "")
|
63
|
+
);
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
export class Resolver {
|
68
|
+
private readonly _cache: Map<string, ResolvedFile> = new Map();
|
69
|
+
|
70
|
+
constructor(
|
71
|
+
private readonly _projectRoot: string,
|
72
|
+
private readonly _parser: Parser,
|
73
|
+
private readonly _remappings: Record<string, string>,
|
74
|
+
private readonly _readFile: (absolutePath: string) => Promise<string>,
|
75
|
+
private readonly _transformImportName: (
|
76
|
+
importName: string
|
77
|
+
) => Promise<string>
|
78
|
+
) {}
|
79
|
+
|
80
|
+
/**
|
81
|
+
* Resolves a source name into a ResolvedFile.
|
82
|
+
*
|
83
|
+
* @param sourceName The source name as it would be provided to solc.
|
84
|
+
*/
|
85
|
+
public async resolveSourceName(sourceName: string): Promise<ResolvedFile> {
|
86
|
+
const cached = this._cache.get(sourceName);
|
87
|
+
if (cached !== undefined) {
|
88
|
+
return cached;
|
89
|
+
}
|
90
|
+
|
91
|
+
const remappedSourceName = applyRemappings(this._remappings, sourceName);
|
92
|
+
|
93
|
+
validateSourceNameFormat(remappedSourceName);
|
94
|
+
|
95
|
+
let resolvedFile: ResolvedFile;
|
96
|
+
|
97
|
+
if (await isLocalSourceName(this._projectRoot, remappedSourceName)) {
|
98
|
+
resolvedFile = await this._resolveLocalSourceName(
|
99
|
+
sourceName,
|
100
|
+
remappedSourceName
|
101
|
+
);
|
102
|
+
} else {
|
103
|
+
resolvedFile = await this._resolveLibrarySourceName(
|
104
|
+
sourceName,
|
105
|
+
remappedSourceName
|
106
|
+
);
|
107
|
+
}
|
108
|
+
|
109
|
+
this._cache.set(sourceName, resolvedFile);
|
110
|
+
return resolvedFile;
|
111
|
+
}
|
112
|
+
|
113
|
+
/**
|
114
|
+
* Resolves an import from an already resolved file.
|
115
|
+
* @param from The file were the import statement is present.
|
116
|
+
* @param importName The path in the import statement.
|
117
|
+
*/
|
118
|
+
public async resolveImport(
|
119
|
+
from: ResolvedFile,
|
120
|
+
importName: string
|
121
|
+
): Promise<ResolvedFile> {
|
122
|
+
// sanity check for deprecated task
|
123
|
+
if (importName !== (await this._transformImportName(importName))) {
|
124
|
+
throw new HardhatError(
|
125
|
+
ERRORS.TASK_DEFINITIONS.DEPRECATED_TRANSFORM_IMPORT_TASK
|
126
|
+
);
|
127
|
+
}
|
128
|
+
|
129
|
+
const imported = applyRemappings(this._remappings, importName);
|
130
|
+
|
131
|
+
const scheme = this._getUriScheme(imported);
|
132
|
+
if (scheme !== undefined) {
|
133
|
+
throw new HardhatError(ERRORS.RESOLVER.INVALID_IMPORT_PROTOCOL, {
|
134
|
+
from: from.sourceName,
|
135
|
+
imported,
|
136
|
+
protocol: scheme,
|
137
|
+
});
|
138
|
+
}
|
139
|
+
|
140
|
+
if (replaceBackslashes(imported) !== imported) {
|
141
|
+
throw new HardhatError(ERRORS.RESOLVER.INVALID_IMPORT_BACKSLASH, {
|
142
|
+
from: from.sourceName,
|
143
|
+
imported,
|
144
|
+
});
|
145
|
+
}
|
146
|
+
|
147
|
+
if (isAbsolutePathSourceName(imported)) {
|
148
|
+
throw new HardhatError(ERRORS.RESOLVER.INVALID_IMPORT_ABSOLUTE_PATH, {
|
149
|
+
from: from.sourceName,
|
150
|
+
imported,
|
151
|
+
});
|
152
|
+
}
|
153
|
+
|
154
|
+
// Edge-case where an import can contain the current package's name in monorepos.
|
155
|
+
// The path can be resolved because there's a symlink in the node modules.
|
156
|
+
if (await includesOwnPackageName(imported)) {
|
157
|
+
throw new HardhatError(ERRORS.RESOLVER.INCLUDES_OWN_PACKAGE_NAME, {
|
158
|
+
from: from.sourceName,
|
159
|
+
imported,
|
160
|
+
});
|
161
|
+
}
|
162
|
+
|
163
|
+
try {
|
164
|
+
let sourceName: string;
|
165
|
+
|
166
|
+
const isRelativeImport = this._isRelativeImport(imported);
|
167
|
+
|
168
|
+
if (isRelativeImport) {
|
169
|
+
sourceName = await this._relativeImportToSourceName(from, imported);
|
170
|
+
} else {
|
171
|
+
sourceName = normalizeSourceName(importName); // The sourceName of the imported file is not transformed
|
172
|
+
}
|
173
|
+
|
174
|
+
const cached = this._cache.get(sourceName);
|
175
|
+
if (cached !== undefined) {
|
176
|
+
return cached;
|
177
|
+
}
|
178
|
+
|
179
|
+
let resolvedFile: ResolvedFile;
|
180
|
+
|
181
|
+
// We have this special case here, because otherwise local relative
|
182
|
+
// imports can be treated as library imports. For example if
|
183
|
+
// `contracts/c.sol` imports `../non-existent/a.sol`
|
184
|
+
if (
|
185
|
+
from.library === undefined &&
|
186
|
+
isRelativeImport &&
|
187
|
+
!this._isRelativeImportToLibrary(from, imported)
|
188
|
+
) {
|
189
|
+
resolvedFile = await this._resolveLocalSourceName(
|
190
|
+
sourceName,
|
191
|
+
applyRemappings(this._remappings, sourceName)
|
192
|
+
);
|
193
|
+
} else {
|
194
|
+
resolvedFile = await this.resolveSourceName(sourceName);
|
195
|
+
}
|
196
|
+
|
197
|
+
this._cache.set(sourceName, resolvedFile);
|
198
|
+
return resolvedFile;
|
199
|
+
} catch (error) {
|
200
|
+
if (
|
201
|
+
HardhatError.isHardhatErrorType(
|
202
|
+
error,
|
203
|
+
ERRORS.RESOLVER.FILE_NOT_FOUND
|
204
|
+
) ||
|
205
|
+
HardhatError.isHardhatErrorType(
|
206
|
+
error,
|
207
|
+
ERRORS.RESOLVER.LIBRARY_FILE_NOT_FOUND
|
208
|
+
)
|
209
|
+
) {
|
210
|
+
if (imported !== importName) {
|
211
|
+
throw new HardhatError(
|
212
|
+
ERRORS.RESOLVER.IMPORTED_MAPPED_FILE_NOT_FOUND,
|
213
|
+
{
|
214
|
+
imported,
|
215
|
+
importName,
|
216
|
+
from: from.sourceName,
|
217
|
+
},
|
218
|
+
error
|
219
|
+
);
|
220
|
+
} else {
|
221
|
+
throw new HardhatError(
|
222
|
+
ERRORS.RESOLVER.IMPORTED_FILE_NOT_FOUND,
|
223
|
+
{
|
224
|
+
imported,
|
225
|
+
from: from.sourceName,
|
226
|
+
},
|
227
|
+
error
|
228
|
+
);
|
229
|
+
}
|
230
|
+
}
|
231
|
+
|
232
|
+
if (
|
233
|
+
HardhatError.isHardhatErrorType(
|
234
|
+
error,
|
235
|
+
ERRORS.RESOLVER.WRONG_SOURCE_NAME_CASING
|
236
|
+
)
|
237
|
+
) {
|
238
|
+
throw new HardhatError(
|
239
|
+
ERRORS.RESOLVER.INVALID_IMPORT_WRONG_CASING,
|
240
|
+
{
|
241
|
+
imported,
|
242
|
+
from: from.sourceName,
|
243
|
+
},
|
244
|
+
error
|
245
|
+
);
|
246
|
+
}
|
247
|
+
|
248
|
+
if (
|
249
|
+
HardhatError.isHardhatErrorType(
|
250
|
+
error,
|
251
|
+
ERRORS.RESOLVER.LIBRARY_NOT_INSTALLED
|
252
|
+
)
|
253
|
+
) {
|
254
|
+
throw new HardhatError(
|
255
|
+
ERRORS.RESOLVER.IMPORTED_LIBRARY_NOT_INSTALLED,
|
256
|
+
{
|
257
|
+
library: error.messageArguments.library,
|
258
|
+
from: from.sourceName,
|
259
|
+
},
|
260
|
+
error
|
261
|
+
);
|
262
|
+
}
|
263
|
+
|
264
|
+
if (
|
265
|
+
HardhatError.isHardhatErrorType(
|
266
|
+
error,
|
267
|
+
ERRORS.GENERAL.INVALID_READ_OF_DIRECTORY
|
268
|
+
)
|
269
|
+
) {
|
270
|
+
throw new HardhatError(
|
271
|
+
ERRORS.RESOLVER.INVALID_IMPORT_OF_DIRECTORY,
|
272
|
+
{
|
273
|
+
imported,
|
274
|
+
from: from.sourceName,
|
275
|
+
},
|
276
|
+
error
|
277
|
+
);
|
278
|
+
}
|
279
|
+
|
280
|
+
// eslint-disable-next-line @nomicfoundation/hardhat-internal-rules/only-hardhat-error
|
281
|
+
throw error;
|
282
|
+
}
|
283
|
+
}
|
284
|
+
|
285
|
+
private async _resolveLocalSourceName(
|
286
|
+
sourceName: string,
|
287
|
+
remappedSourceName: string
|
288
|
+
): Promise<ResolvedFile> {
|
289
|
+
await this._validateSourceNameExistenceAndCasing(
|
290
|
+
this._projectRoot,
|
291
|
+
remappedSourceName,
|
292
|
+
false
|
293
|
+
);
|
294
|
+
|
295
|
+
const absolutePath = path.join(this._projectRoot, remappedSourceName);
|
296
|
+
return this._resolveFile(sourceName, absolutePath);
|
297
|
+
}
|
298
|
+
|
299
|
+
private async _resolveLibrarySourceName(
|
300
|
+
sourceName: string,
|
301
|
+
remappedSourceName: string
|
302
|
+
): Promise<ResolvedFile> {
|
303
|
+
const normalizedSourceName = remappedSourceName.replace(
|
304
|
+
/^node_modules\//,
|
305
|
+
""
|
306
|
+
);
|
307
|
+
const libraryName = this._getLibraryName(normalizedSourceName);
|
308
|
+
|
309
|
+
let packageJsonPath;
|
310
|
+
try {
|
311
|
+
packageJsonPath = this._resolveNodeModulesFileFromProjectRoot(
|
312
|
+
path.join(libraryName, "package.json")
|
313
|
+
);
|
314
|
+
} catch (error) {
|
315
|
+
// if the project is using a dependency from hardhat itself but it can't
|
316
|
+
// be found, this means that a global installation is being used, so we
|
317
|
+
// resolve the dependency relative to this file
|
318
|
+
if (libraryName === "hardhat") {
|
319
|
+
const hardhatCoreDir = path.join(__dirname, "..", "..");
|
320
|
+
packageJsonPath = path.join(hardhatCoreDir, "package.json");
|
321
|
+
} else {
|
322
|
+
throw new HardhatError(
|
323
|
+
ERRORS.RESOLVER.LIBRARY_NOT_INSTALLED,
|
324
|
+
{
|
325
|
+
library: libraryName,
|
326
|
+
},
|
327
|
+
error as Error
|
328
|
+
);
|
329
|
+
}
|
330
|
+
}
|
331
|
+
|
332
|
+
let nodeModulesPath = path.dirname(path.dirname(packageJsonPath));
|
333
|
+
if (this._isScopedPackage(normalizedSourceName)) {
|
334
|
+
nodeModulesPath = path.dirname(nodeModulesPath);
|
335
|
+
}
|
336
|
+
|
337
|
+
let absolutePath: string;
|
338
|
+
if (path.basename(nodeModulesPath) !== NODE_MODULES) {
|
339
|
+
// this can happen in monorepos that use PnP, in those
|
340
|
+
// cases we handle resolution differently
|
341
|
+
const packageRoot = path.dirname(packageJsonPath);
|
342
|
+
const pattern = new RegExp(`^${libraryName}/?`);
|
343
|
+
const fileName = normalizedSourceName.replace(pattern, "");
|
344
|
+
|
345
|
+
await this._validateSourceNameExistenceAndCasing(
|
346
|
+
packageRoot,
|
347
|
+
// TODO: this is _not_ a source name; we should handle this scenario in
|
348
|
+
// a better way
|
349
|
+
fileName,
|
350
|
+
true
|
351
|
+
);
|
352
|
+
absolutePath = path.join(packageRoot, fileName);
|
353
|
+
} else {
|
354
|
+
await this._validateSourceNameExistenceAndCasing(
|
355
|
+
nodeModulesPath,
|
356
|
+
normalizedSourceName,
|
357
|
+
true
|
358
|
+
);
|
359
|
+
absolutePath = path.join(nodeModulesPath, normalizedSourceName);
|
360
|
+
}
|
361
|
+
|
362
|
+
const packageInfo: {
|
363
|
+
name: string;
|
364
|
+
version: string;
|
365
|
+
} = await fsExtra.readJson(packageJsonPath);
|
366
|
+
const libraryVersion = packageInfo.version;
|
367
|
+
|
368
|
+
return this._resolveFile(
|
369
|
+
sourceName,
|
370
|
+
// We resolve to the real path here, as we may be resolving a linked library
|
371
|
+
await getRealPath(absolutePath),
|
372
|
+
libraryName,
|
373
|
+
libraryVersion
|
374
|
+
);
|
375
|
+
}
|
376
|
+
|
377
|
+
private async _relativeImportToSourceName(
|
378
|
+
from: ResolvedFile,
|
379
|
+
imported: string
|
380
|
+
): Promise<string> {
|
381
|
+
// This is a special case, were we turn relative imports from local files
|
382
|
+
// into library imports if necessary. The reason for this is that many
|
383
|
+
// users just do `import "../node_modules/lib/a.sol";`.
|
384
|
+
if (this._isRelativeImportToLibrary(from, imported)) {
|
385
|
+
return this._relativeImportToLibraryToSourceName(from, imported);
|
386
|
+
}
|
387
|
+
|
388
|
+
const sourceName = normalizeSourceName(
|
389
|
+
path.join(path.dirname(from.sourceName), imported)
|
390
|
+
);
|
391
|
+
|
392
|
+
// If the file with the import is local, and the normalized version
|
393
|
+
// starts with ../ means that it's trying to get outside of the project.
|
394
|
+
if (from.library === undefined && sourceName.startsWith("../")) {
|
395
|
+
throw new HardhatError(
|
396
|
+
ERRORS.RESOLVER.INVALID_IMPORT_OUTSIDE_OF_PROJECT,
|
397
|
+
{ from: from.sourceName, imported }
|
398
|
+
);
|
399
|
+
}
|
400
|
+
|
401
|
+
if (
|
402
|
+
from.library !== undefined &&
|
403
|
+
!this._isInsideSameDir(from.sourceName, sourceName)
|
404
|
+
) {
|
405
|
+
// If the file is being imported from a library, this means that it's
|
406
|
+
// trying to reach another one.
|
407
|
+
throw new HardhatError(ERRORS.RESOLVER.ILLEGAL_IMPORT, {
|
408
|
+
from: from.sourceName,
|
409
|
+
imported,
|
410
|
+
});
|
411
|
+
}
|
412
|
+
|
413
|
+
return sourceName;
|
414
|
+
}
|
415
|
+
|
416
|
+
private async _resolveFile(
|
417
|
+
sourceName: string,
|
418
|
+
absolutePath: string,
|
419
|
+
libraryName?: string,
|
420
|
+
libraryVersion?: string
|
421
|
+
): Promise<ResolvedFile> {
|
422
|
+
const rawContent = await this._readFile(absolutePath);
|
423
|
+
const stats = await fsExtra.stat(absolutePath);
|
424
|
+
const lastModificationDate = new Date(stats.ctime);
|
425
|
+
|
426
|
+
const contentHash = createNonCryptographicHashBasedIdentifier(
|
427
|
+
Buffer.from(rawContent)
|
428
|
+
).toString("hex");
|
429
|
+
|
430
|
+
const parsedContent = this._parser.parse(
|
431
|
+
rawContent,
|
432
|
+
absolutePath,
|
433
|
+
contentHash
|
434
|
+
);
|
435
|
+
|
436
|
+
const content = {
|
437
|
+
rawContent,
|
438
|
+
...parsedContent,
|
439
|
+
};
|
440
|
+
|
441
|
+
return new ResolvedFile(
|
442
|
+
sourceName,
|
443
|
+
absolutePath,
|
444
|
+
content,
|
445
|
+
contentHash,
|
446
|
+
lastModificationDate,
|
447
|
+
libraryName,
|
448
|
+
libraryVersion
|
449
|
+
);
|
450
|
+
}
|
451
|
+
|
452
|
+
private _isRelativeImport(imported: string): boolean {
|
453
|
+
return imported.startsWith("./") || imported.startsWith("../");
|
454
|
+
}
|
455
|
+
|
456
|
+
private _resolveNodeModulesFileFromProjectRoot(fileName: string) {
|
457
|
+
return resolve.sync(fileName, {
|
458
|
+
basedir: this._projectRoot,
|
459
|
+
preserveSymlinks: true,
|
460
|
+
});
|
461
|
+
}
|
462
|
+
|
463
|
+
private _getLibraryName(sourceName: string): string {
|
464
|
+
let endIndex: number;
|
465
|
+
if (this._isScopedPackage(sourceName)) {
|
466
|
+
endIndex = sourceName.indexOf("/", sourceName.indexOf("/") + 1);
|
467
|
+
} else if (sourceName.indexOf("/") === -1) {
|
468
|
+
endIndex = sourceName.length;
|
469
|
+
} else {
|
470
|
+
endIndex = sourceName.indexOf("/");
|
471
|
+
}
|
472
|
+
|
473
|
+
return sourceName.slice(0, endIndex);
|
474
|
+
}
|
475
|
+
|
476
|
+
private _getUriScheme(s: string): string | undefined {
|
477
|
+
const re = /([a-zA-Z]+):\/\//;
|
478
|
+
const match = re.exec(s);
|
479
|
+
if (match === null) {
|
480
|
+
return undefined;
|
481
|
+
}
|
482
|
+
|
483
|
+
return match[1];
|
484
|
+
}
|
485
|
+
|
486
|
+
private _isInsideSameDir(sourceNameInDir: string, sourceNameToTest: string) {
|
487
|
+
const firstSlash = sourceNameInDir.indexOf("/");
|
488
|
+
const dir =
|
489
|
+
firstSlash !== -1
|
490
|
+
? sourceNameInDir.substring(0, firstSlash)
|
491
|
+
: sourceNameInDir;
|
492
|
+
|
493
|
+
return sourceNameToTest.startsWith(dir);
|
494
|
+
}
|
495
|
+
|
496
|
+
private _isScopedPackage(packageOrPackageFile: string): boolean {
|
497
|
+
return packageOrPackageFile.startsWith("@");
|
498
|
+
}
|
499
|
+
|
500
|
+
private _isRelativeImportToLibrary(
|
501
|
+
from: ResolvedFile,
|
502
|
+
imported: string
|
503
|
+
): boolean {
|
504
|
+
return (
|
505
|
+
this._isRelativeImport(imported) &&
|
506
|
+
from.library === undefined &&
|
507
|
+
imported.includes(`${NODE_MODULES}/`)
|
508
|
+
);
|
509
|
+
}
|
510
|
+
|
511
|
+
private _relativeImportToLibraryToSourceName(
|
512
|
+
from: ResolvedFile,
|
513
|
+
imported: string
|
514
|
+
): string {
|
515
|
+
const sourceName = normalizeSourceName(
|
516
|
+
path.join(path.dirname(from.sourceName), imported)
|
517
|
+
);
|
518
|
+
|
519
|
+
const nmIndex = sourceName.indexOf(`${NODE_MODULES}/`);
|
520
|
+
return sourceName.substr(nmIndex + NODE_MODULES.length + 1);
|
521
|
+
}
|
522
|
+
|
523
|
+
private async _validateSourceNameExistenceAndCasing(
|
524
|
+
fromDir: string,
|
525
|
+
sourceName: string,
|
526
|
+
isLibrary: boolean
|
527
|
+
) {
|
528
|
+
try {
|
529
|
+
await validateSourceNameExistenceAndCasing(fromDir, sourceName);
|
530
|
+
} catch (error) {
|
531
|
+
if (
|
532
|
+
HardhatError.isHardhatErrorType(
|
533
|
+
error,
|
534
|
+
ERRORS.SOURCE_NAMES.FILE_NOT_FOUND
|
535
|
+
)
|
536
|
+
) {
|
537
|
+
throw new HardhatError(
|
538
|
+
isLibrary
|
539
|
+
? ERRORS.RESOLVER.LIBRARY_FILE_NOT_FOUND
|
540
|
+
: ERRORS.RESOLVER.FILE_NOT_FOUND,
|
541
|
+
{ file: sourceName },
|
542
|
+
error
|
543
|
+
);
|
544
|
+
}
|
545
|
+
|
546
|
+
if (
|
547
|
+
HardhatError.isHardhatErrorType(error, ERRORS.SOURCE_NAMES.WRONG_CASING)
|
548
|
+
) {
|
549
|
+
throw new HardhatError(
|
550
|
+
ERRORS.RESOLVER.WRONG_SOURCE_NAME_CASING,
|
551
|
+
{
|
552
|
+
incorrect: sourceName,
|
553
|
+
correct: error.messageArguments.correct,
|
554
|
+
},
|
555
|
+
error
|
556
|
+
);
|
557
|
+
}
|
558
|
+
|
559
|
+
// eslint-disable-next-line @nomicfoundation/hardhat-internal-rules/only-hardhat-error
|
560
|
+
throw error;
|
561
|
+
}
|
562
|
+
}
|
563
|
+
}
|
@@ -0,0 +1,55 @@
|
|
1
|
+
import * as abi from "@ethersproject/abi";
|
2
|
+
|
3
|
+
export class AbiHelpers {
|
4
|
+
/**
|
5
|
+
* Try to compute the selector for the function/event/error
|
6
|
+
* with the given name and param types. Return undefined
|
7
|
+
* if it cannot do it. This can happen if some ParamType is
|
8
|
+
* not understood by @ethersproject/abi
|
9
|
+
*/
|
10
|
+
public static computeSelector(
|
11
|
+
name: string,
|
12
|
+
inputs: any[]
|
13
|
+
): Uint8Array | undefined {
|
14
|
+
try {
|
15
|
+
const fragment = abi.FunctionFragment.from({
|
16
|
+
type: "function",
|
17
|
+
constant: true,
|
18
|
+
name,
|
19
|
+
inputs: inputs.map((i) => abi.ParamType.from(i)),
|
20
|
+
});
|
21
|
+
const selectorHex = abi.Interface.getSighash(fragment);
|
22
|
+
|
23
|
+
return Buffer.from(selectorHex.slice(2), "hex");
|
24
|
+
} catch {
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
}
|
28
|
+
|
29
|
+
public static isValidCalldata(inputs: any[], calldata: Uint8Array): boolean {
|
30
|
+
try {
|
31
|
+
abi.defaultAbiCoder.decode(inputs, calldata);
|
32
|
+
return true;
|
33
|
+
} catch {
|
34
|
+
return false;
|
35
|
+
}
|
36
|
+
}
|
37
|
+
|
38
|
+
public static formatValues(values: any[]): string {
|
39
|
+
return values.map((x) => AbiHelpers._formatValue(x)).join(", ");
|
40
|
+
}
|
41
|
+
|
42
|
+
private static _formatValue(value: any): string {
|
43
|
+
// print nested values as [value1, value2, ...]
|
44
|
+
if (Array.isArray(value)) {
|
45
|
+
return `[${value.map((v) => AbiHelpers._formatValue(v)).join(", ")}]`;
|
46
|
+
}
|
47
|
+
|
48
|
+
// surround string values with quotes
|
49
|
+
if (typeof value === "string") {
|
50
|
+
return `"${value}"`;
|
51
|
+
}
|
52
|
+
|
53
|
+
return value.toString();
|
54
|
+
}
|
55
|
+
}
|
@@ -0,0 +1,66 @@
|
|
1
|
+
import { assertHardhatInvariant } from "../core/errors";
|
2
|
+
|
3
|
+
export function min(x: bigint, y: bigint): bigint {
|
4
|
+
return x < y ? x : y;
|
5
|
+
}
|
6
|
+
|
7
|
+
export function max(x: bigint, y: bigint): bigint {
|
8
|
+
return x > y ? x : y;
|
9
|
+
}
|
10
|
+
|
11
|
+
export function isBigInt(x: unknown): x is bigint {
|
12
|
+
return typeof x === "bigint";
|
13
|
+
}
|
14
|
+
|
15
|
+
export function divUp(x: bigint, y: bigint): bigint {
|
16
|
+
let result = x / y;
|
17
|
+
|
18
|
+
if (x % y !== 0n) {
|
19
|
+
result = result + 1n;
|
20
|
+
}
|
21
|
+
|
22
|
+
return result;
|
23
|
+
}
|
24
|
+
|
25
|
+
export function cmp(a: bigint, b: bigint): number {
|
26
|
+
return a < b ? -1 : a > b ? 1 : 0;
|
27
|
+
}
|
28
|
+
|
29
|
+
/**
|
30
|
+
* Converts the number to a hexadecimal string with a length of 32
|
31
|
+
* bytes. This hex string is NOT 0x-prefixed.
|
32
|
+
*/
|
33
|
+
export function toEvmWord(x: bigint | number): string {
|
34
|
+
return x.toString(16).padStart(64, "0");
|
35
|
+
}
|
36
|
+
|
37
|
+
function bufferToBigInt(x: Uint8Array): bigint {
|
38
|
+
const hex = `0x${Buffer.from(x).toString("hex")}`;
|
39
|
+
return hex === "0x" ? 0n : BigInt(hex);
|
40
|
+
}
|
41
|
+
|
42
|
+
export function fromBigIntLike(
|
43
|
+
x: string | number | bigint | Uint8Array | undefined
|
44
|
+
): bigint | undefined {
|
45
|
+
if (x === undefined || typeof x === "bigint") {
|
46
|
+
return x;
|
47
|
+
}
|
48
|
+
if (typeof x === "number" || typeof x === "string") {
|
49
|
+
return BigInt(x);
|
50
|
+
}
|
51
|
+
if (x instanceof Uint8Array) {
|
52
|
+
return bufferToBigInt(x);
|
53
|
+
}
|
54
|
+
|
55
|
+
const exhaustiveCheck: never = x;
|
56
|
+
return exhaustiveCheck;
|
57
|
+
}
|
58
|
+
|
59
|
+
export function toHex(x: number | bigint): string {
|
60
|
+
assertHardhatInvariant(
|
61
|
+
x >= 0,
|
62
|
+
`toHex can only be used with non-negative numbers, but received ${x}`
|
63
|
+
);
|
64
|
+
|
65
|
+
return `0x${x.toString(16)}`;
|
66
|
+
}
|