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,223 @@
|
|
1
|
+
import type { MochaOptions } from "mocha";
|
2
|
+
|
3
|
+
import chalk from "chalk";
|
4
|
+
import path from "path";
|
5
|
+
|
6
|
+
import { HARDHAT_NETWORK_NAME } from "../internal/constants";
|
7
|
+
import { subtask, task } from "../internal/core/config/config-env";
|
8
|
+
import { HardhatError } from "../internal/core/errors";
|
9
|
+
import { ERRORS } from "../internal/core/errors-list";
|
10
|
+
import {
|
11
|
+
isJavascriptFile,
|
12
|
+
isRunningWithTypescript,
|
13
|
+
isTypescriptFile,
|
14
|
+
} from "../internal/core/typescript-support";
|
15
|
+
import { getForkCacheDirPath } from "../internal/hardhat-network/provider/utils/disk-cache";
|
16
|
+
import { showForkRecommendationsBannerIfNecessary } from "../internal/hardhat-network/provider/utils/fork-recomendations-banner";
|
17
|
+
import { pluralize } from "../internal/util/strings";
|
18
|
+
import { getAllFilesMatching } from "../internal/util/fs-utils";
|
19
|
+
import { getProjectPackageJson } from "../internal/util/packageInfo";
|
20
|
+
|
21
|
+
import {
|
22
|
+
TASK_COMPILE,
|
23
|
+
TASK_TEST,
|
24
|
+
TASK_TEST_GET_TEST_FILES,
|
25
|
+
TASK_TEST_RUN_MOCHA_TESTS,
|
26
|
+
TASK_TEST_RUN_SHOW_FORK_RECOMMENDATIONS,
|
27
|
+
TASK_TEST_SETUP_TEST_ENVIRONMENT,
|
28
|
+
} from "./task-names";
|
29
|
+
|
30
|
+
subtask(TASK_TEST_GET_TEST_FILES)
|
31
|
+
.addOptionalVariadicPositionalParam(
|
32
|
+
"testFiles",
|
33
|
+
"An optional list of files to test",
|
34
|
+
[]
|
35
|
+
)
|
36
|
+
.setAction(async ({ testFiles }: { testFiles: string[] }, { config }) => {
|
37
|
+
if (testFiles.length !== 0) {
|
38
|
+
const testFilesAbsolutePaths = testFiles.map((x) =>
|
39
|
+
path.resolve(process.cwd(), x)
|
40
|
+
);
|
41
|
+
|
42
|
+
return testFilesAbsolutePaths;
|
43
|
+
}
|
44
|
+
|
45
|
+
const jsFiles = await getAllFilesMatching(
|
46
|
+
config.paths.tests,
|
47
|
+
isJavascriptFile
|
48
|
+
);
|
49
|
+
|
50
|
+
if (!isRunningWithTypescript(config)) {
|
51
|
+
return jsFiles;
|
52
|
+
}
|
53
|
+
|
54
|
+
const tsFiles = await getAllFilesMatching(
|
55
|
+
config.paths.tests,
|
56
|
+
isTypescriptFile
|
57
|
+
);
|
58
|
+
|
59
|
+
return [...jsFiles, ...tsFiles];
|
60
|
+
});
|
61
|
+
|
62
|
+
subtask(TASK_TEST_SETUP_TEST_ENVIRONMENT, async () => {});
|
63
|
+
|
64
|
+
let testsAlreadyRun = false;
|
65
|
+
subtask(TASK_TEST_RUN_MOCHA_TESTS)
|
66
|
+
.addFlag("parallel", "Run tests in parallel")
|
67
|
+
.addFlag("bail", "Stop running tests after the first test failure")
|
68
|
+
.addOptionalParam(
|
69
|
+
"grep",
|
70
|
+
"Only run tests matching the given string or regexp"
|
71
|
+
)
|
72
|
+
.addOptionalVariadicPositionalParam(
|
73
|
+
"testFiles",
|
74
|
+
"An optional list of files to test",
|
75
|
+
[]
|
76
|
+
)
|
77
|
+
.setAction(
|
78
|
+
async (
|
79
|
+
taskArgs: {
|
80
|
+
bail: boolean;
|
81
|
+
parallel: boolean;
|
82
|
+
testFiles: string[];
|
83
|
+
grep?: string;
|
84
|
+
},
|
85
|
+
{ config }
|
86
|
+
) => {
|
87
|
+
const { default: Mocha } = await import("mocha");
|
88
|
+
|
89
|
+
const mochaConfig: MochaOptions = { ...config.mocha };
|
90
|
+
|
91
|
+
if (taskArgs.grep !== undefined) {
|
92
|
+
mochaConfig.grep = taskArgs.grep;
|
93
|
+
}
|
94
|
+
if (taskArgs.bail) {
|
95
|
+
mochaConfig.bail = true;
|
96
|
+
}
|
97
|
+
if (taskArgs.parallel) {
|
98
|
+
mochaConfig.parallel = true;
|
99
|
+
}
|
100
|
+
|
101
|
+
if (mochaConfig.parallel === true) {
|
102
|
+
const mochaRequire = mochaConfig.require ?? [];
|
103
|
+
if (!mochaRequire.includes("hardhat/register")) {
|
104
|
+
mochaRequire.push("hardhat/register");
|
105
|
+
}
|
106
|
+
mochaConfig.require = mochaRequire;
|
107
|
+
}
|
108
|
+
|
109
|
+
const mocha = new Mocha(mochaConfig);
|
110
|
+
taskArgs.testFiles.forEach((file) => mocha.addFile(file));
|
111
|
+
|
112
|
+
// if the project is of type "module" or if there's some ESM test file,
|
113
|
+
// we call loadFilesAsync to enable Mocha's ESM support
|
114
|
+
const projectPackageJson = await getProjectPackageJson();
|
115
|
+
const isTypeModule = projectPackageJson.type === "module";
|
116
|
+
const hasEsmTest = taskArgs.testFiles.some((file) =>
|
117
|
+
file.endsWith(".mjs")
|
118
|
+
);
|
119
|
+
if (isTypeModule || hasEsmTest) {
|
120
|
+
// Because of the way the ESM cache works, loadFilesAsync doesn't work
|
121
|
+
// correctly if used twice within the same process, so we throw an error
|
122
|
+
// in that case
|
123
|
+
if (testsAlreadyRun) {
|
124
|
+
throw new HardhatError(
|
125
|
+
ERRORS.BUILTIN_TASKS.TEST_TASK_ESM_TESTS_RUN_TWICE
|
126
|
+
);
|
127
|
+
}
|
128
|
+
testsAlreadyRun = true;
|
129
|
+
|
130
|
+
// This instructs Mocha to use the more verbose file loading infrastructure
|
131
|
+
// which supports both ESM and CJS
|
132
|
+
await mocha.loadFilesAsync();
|
133
|
+
}
|
134
|
+
|
135
|
+
const testFailures = await new Promise<number>((resolve) => {
|
136
|
+
mocha.run(resolve);
|
137
|
+
});
|
138
|
+
|
139
|
+
mocha.dispose();
|
140
|
+
|
141
|
+
return testFailures;
|
142
|
+
}
|
143
|
+
);
|
144
|
+
|
145
|
+
subtask(TASK_TEST_RUN_SHOW_FORK_RECOMMENDATIONS).setAction(
|
146
|
+
async (_, { config, network }) => {
|
147
|
+
if (network.name !== HARDHAT_NETWORK_NAME) {
|
148
|
+
return;
|
149
|
+
}
|
150
|
+
|
151
|
+
const forkCache = getForkCacheDirPath(config.paths);
|
152
|
+
await showForkRecommendationsBannerIfNecessary(network.config, forkCache);
|
153
|
+
}
|
154
|
+
);
|
155
|
+
|
156
|
+
task(TASK_TEST, "Runs mocha tests")
|
157
|
+
.addOptionalVariadicPositionalParam(
|
158
|
+
"testFiles",
|
159
|
+
"An optional list of files to test",
|
160
|
+
[]
|
161
|
+
)
|
162
|
+
.addFlag("noCompile", "Don't compile before running this task")
|
163
|
+
.addFlag("parallel", "Run tests in parallel")
|
164
|
+
.addFlag("bail", "Stop running tests after the first test failure")
|
165
|
+
.addOptionalParam(
|
166
|
+
"grep",
|
167
|
+
"Only run tests matching the given string or regexp"
|
168
|
+
)
|
169
|
+
.setAction(
|
170
|
+
async (
|
171
|
+
{
|
172
|
+
testFiles,
|
173
|
+
noCompile,
|
174
|
+
parallel,
|
175
|
+
bail,
|
176
|
+
grep,
|
177
|
+
}: {
|
178
|
+
testFiles: string[];
|
179
|
+
noCompile: boolean;
|
180
|
+
parallel: boolean;
|
181
|
+
bail: boolean;
|
182
|
+
grep?: string;
|
183
|
+
},
|
184
|
+
{ run, network }
|
185
|
+
) => {
|
186
|
+
if (!noCompile) {
|
187
|
+
await run(TASK_COMPILE, { quiet: true });
|
188
|
+
}
|
189
|
+
|
190
|
+
const files = await run(TASK_TEST_GET_TEST_FILES, { testFiles });
|
191
|
+
|
192
|
+
await run(TASK_TEST_SETUP_TEST_ENVIRONMENT);
|
193
|
+
|
194
|
+
await run(TASK_TEST_RUN_SHOW_FORK_RECOMMENDATIONS);
|
195
|
+
|
196
|
+
const testFailures = await run(TASK_TEST_RUN_MOCHA_TESTS, {
|
197
|
+
testFiles: files,
|
198
|
+
parallel,
|
199
|
+
bail,
|
200
|
+
grep,
|
201
|
+
});
|
202
|
+
|
203
|
+
if (network.name === HARDHAT_NETWORK_NAME) {
|
204
|
+
const stackTracesFailures = await network.provider.send(
|
205
|
+
"hardhat_getStackTraceFailuresCount"
|
206
|
+
);
|
207
|
+
|
208
|
+
if (stackTracesFailures !== 0) {
|
209
|
+
console.warn(
|
210
|
+
chalk.yellow(
|
211
|
+
`Failed to generate ${stackTracesFailures} ${pluralize(
|
212
|
+
stackTracesFailures,
|
213
|
+
"stack trace"
|
214
|
+
)}. Run Hardhat with --verbose to learn more.`
|
215
|
+
)
|
216
|
+
);
|
217
|
+
}
|
218
|
+
}
|
219
|
+
|
220
|
+
process.exitCode = testFailures;
|
221
|
+
return testFailures;
|
222
|
+
}
|
223
|
+
);
|
@@ -0,0 +1,145 @@
|
|
1
|
+
import type { LoDashStatic } from "lodash";
|
2
|
+
import type { ProjectPathsConfig, SolcConfig } from "../../types";
|
3
|
+
|
4
|
+
import debug from "debug";
|
5
|
+
import fsExtra from "fs-extra";
|
6
|
+
import * as t from "io-ts";
|
7
|
+
import * as path from "path";
|
8
|
+
|
9
|
+
import { SOLIDITY_FILES_CACHE_FILENAME } from "../../internal/constants";
|
10
|
+
|
11
|
+
const log = debug("hardhat:core:tasks:compile:cache");
|
12
|
+
|
13
|
+
const FORMAT_VERSION = "hh-sol-cache-2";
|
14
|
+
|
15
|
+
const CacheEntryCodec = t.type({
|
16
|
+
lastModificationDate: t.number,
|
17
|
+
contentHash: t.string,
|
18
|
+
sourceName: t.string,
|
19
|
+
solcConfig: t.any,
|
20
|
+
imports: t.array(t.string),
|
21
|
+
versionPragmas: t.array(t.string),
|
22
|
+
artifacts: t.array(t.string),
|
23
|
+
});
|
24
|
+
|
25
|
+
const CacheCodec = t.type({
|
26
|
+
_format: t.string,
|
27
|
+
files: t.record(t.string, CacheEntryCodec),
|
28
|
+
});
|
29
|
+
|
30
|
+
export interface CacheEntry {
|
31
|
+
lastModificationDate: number;
|
32
|
+
contentHash: string;
|
33
|
+
sourceName: string;
|
34
|
+
solcConfig: SolcConfig;
|
35
|
+
imports: string[];
|
36
|
+
versionPragmas: string[];
|
37
|
+
artifacts: string[];
|
38
|
+
}
|
39
|
+
|
40
|
+
export interface Cache {
|
41
|
+
_format: string;
|
42
|
+
files: Record<string, CacheEntry>;
|
43
|
+
}
|
44
|
+
|
45
|
+
export class SolidityFilesCache {
|
46
|
+
public static createEmpty(): SolidityFilesCache {
|
47
|
+
return new SolidityFilesCache({
|
48
|
+
_format: FORMAT_VERSION,
|
49
|
+
files: {},
|
50
|
+
});
|
51
|
+
}
|
52
|
+
|
53
|
+
public static async readFromFile(
|
54
|
+
solidityFilesCachePath: string
|
55
|
+
): Promise<SolidityFilesCache> {
|
56
|
+
let cacheRaw: Cache = {
|
57
|
+
_format: FORMAT_VERSION,
|
58
|
+
files: {},
|
59
|
+
};
|
60
|
+
if (await fsExtra.pathExists(solidityFilesCachePath)) {
|
61
|
+
cacheRaw = await fsExtra.readJson(solidityFilesCachePath);
|
62
|
+
}
|
63
|
+
|
64
|
+
const result = CacheCodec.decode(cacheRaw);
|
65
|
+
|
66
|
+
if (result.isRight()) {
|
67
|
+
const solidityFilesCache = new SolidityFilesCache(result.value);
|
68
|
+
await solidityFilesCache.removeNonExistingFiles();
|
69
|
+
return solidityFilesCache;
|
70
|
+
}
|
71
|
+
|
72
|
+
log("There was a problem reading the cache");
|
73
|
+
|
74
|
+
return new SolidityFilesCache({
|
75
|
+
_format: FORMAT_VERSION,
|
76
|
+
files: {},
|
77
|
+
});
|
78
|
+
}
|
79
|
+
|
80
|
+
constructor(private _cache: Cache) {}
|
81
|
+
|
82
|
+
public async removeNonExistingFiles() {
|
83
|
+
await Promise.all(
|
84
|
+
Object.keys(this._cache.files).map(async (absolutePath) => {
|
85
|
+
if (!(await fsExtra.pathExists(absolutePath))) {
|
86
|
+
this.removeEntry(absolutePath);
|
87
|
+
}
|
88
|
+
})
|
89
|
+
);
|
90
|
+
}
|
91
|
+
|
92
|
+
public async writeToFile(solidityFilesCachePath: string) {
|
93
|
+
await fsExtra.outputJson(solidityFilesCachePath, this._cache, {
|
94
|
+
spaces: 2,
|
95
|
+
});
|
96
|
+
}
|
97
|
+
|
98
|
+
public addFile(absolutePath: string, entry: CacheEntry) {
|
99
|
+
this._cache.files[absolutePath] = entry;
|
100
|
+
}
|
101
|
+
|
102
|
+
public getEntries(): CacheEntry[] {
|
103
|
+
return Object.values(this._cache.files);
|
104
|
+
}
|
105
|
+
|
106
|
+
public getEntry(file: string): CacheEntry | undefined {
|
107
|
+
return this._cache.files[file];
|
108
|
+
}
|
109
|
+
|
110
|
+
public removeEntry(file: string) {
|
111
|
+
delete this._cache.files[file];
|
112
|
+
}
|
113
|
+
|
114
|
+
public hasFileChanged(
|
115
|
+
absolutePath: string,
|
116
|
+
contentHash: string,
|
117
|
+
solcConfig?: SolcConfig
|
118
|
+
): boolean {
|
119
|
+
const isEqual = require("lodash/isEqual") as LoDashStatic["isEqual"];
|
120
|
+
|
121
|
+
const cacheEntry = this.getEntry(absolutePath);
|
122
|
+
|
123
|
+
if (cacheEntry === undefined) {
|
124
|
+
// new file or no cache available, assume it's new
|
125
|
+
return true;
|
126
|
+
}
|
127
|
+
|
128
|
+
if (cacheEntry.contentHash !== contentHash) {
|
129
|
+
return true;
|
130
|
+
}
|
131
|
+
|
132
|
+
if (
|
133
|
+
solcConfig !== undefined &&
|
134
|
+
!isEqual(solcConfig, cacheEntry.solcConfig)
|
135
|
+
) {
|
136
|
+
return true;
|
137
|
+
}
|
138
|
+
|
139
|
+
return false;
|
140
|
+
}
|
141
|
+
}
|
142
|
+
|
143
|
+
export function getSolidityFilesCachePath(paths: ProjectPathsConfig): string {
|
144
|
+
return path.join(paths.cache, SOLIDITY_FILES_CACHE_FILENAME);
|
145
|
+
}
|
@@ -0,0 +1,64 @@
|
|
1
|
+
import chalk from "chalk";
|
2
|
+
import { FSWatcher } from "chokidar";
|
3
|
+
import debug from "debug";
|
4
|
+
import fsExtra from "fs-extra";
|
5
|
+
import * as path from "path";
|
6
|
+
|
7
|
+
import { BUILD_INFO_DIR_NAME } from "../../internal/constants";
|
8
|
+
import { Reporter } from "../../internal/sentry/reporter";
|
9
|
+
import { EIP1193Provider, ProjectPathsConfig } from "../../types";
|
10
|
+
|
11
|
+
const log = debug("hardhat:core:compilation-watcher");
|
12
|
+
|
13
|
+
export type Watcher = FSWatcher;
|
14
|
+
|
15
|
+
export async function watchCompilerOutput(
|
16
|
+
provider: EIP1193Provider,
|
17
|
+
paths: ProjectPathsConfig
|
18
|
+
): Promise<Watcher> {
|
19
|
+
const chokidar = await import("chokidar");
|
20
|
+
|
21
|
+
const buildInfoDir = path.join(paths.artifacts, BUILD_INFO_DIR_NAME);
|
22
|
+
|
23
|
+
const addCompilationResult = async (buildInfo: string) => {
|
24
|
+
try {
|
25
|
+
log("Adding new compilation result to the node");
|
26
|
+
|
27
|
+
const { input, output, solcVersion } = await fsExtra.readJSON(buildInfo, {
|
28
|
+
encoding: "utf8",
|
29
|
+
});
|
30
|
+
|
31
|
+
await provider.request({
|
32
|
+
method: "hardhat_addCompilationResult",
|
33
|
+
params: [solcVersion, input, output],
|
34
|
+
});
|
35
|
+
} catch (error) {
|
36
|
+
console.warn(
|
37
|
+
chalk.yellow(
|
38
|
+
"There was a problem adding the new compiler result. Run Hardhat with --verbose to learn more."
|
39
|
+
)
|
40
|
+
);
|
41
|
+
|
42
|
+
log(
|
43
|
+
"Last compilation result couldn't be added. Please report this to help us improve Hardhat.\n",
|
44
|
+
error
|
45
|
+
);
|
46
|
+
|
47
|
+
if (error instanceof Error) {
|
48
|
+
Reporter.reportError(error);
|
49
|
+
}
|
50
|
+
}
|
51
|
+
};
|
52
|
+
|
53
|
+
log(`Watching changes on '${buildInfoDir}'`);
|
54
|
+
|
55
|
+
return chokidar
|
56
|
+
.watch(buildInfoDir, {
|
57
|
+
ignoreInitial: true,
|
58
|
+
awaitWriteFinish: {
|
59
|
+
stabilityThreshold: 250,
|
60
|
+
pollInterval: 50,
|
61
|
+
},
|
62
|
+
})
|
63
|
+
.on("add", addCompilationResult);
|
64
|
+
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
import { HardhatError } from "../internal/core/errors";
|
2
|
+
import { scope } from "../internal/core/config/config-env";
|
3
|
+
import { ERRORS } from "../internal/core/errors-list";
|
4
|
+
|
5
|
+
const varsScope = scope("vars", "Manage your configuration variables");
|
6
|
+
|
7
|
+
varsScope
|
8
|
+
.task("set", "Set the value of a configuration variable")
|
9
|
+
.addPositionalParam("var", "The name of the variable")
|
10
|
+
.addOptionalPositionalParam(
|
11
|
+
"value",
|
12
|
+
"The value to store. Omit to be prompted for it."
|
13
|
+
)
|
14
|
+
.setAction(async () => {
|
15
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
16
|
+
});
|
17
|
+
|
18
|
+
varsScope
|
19
|
+
.task("get", "Get the value of a configuration variable")
|
20
|
+
.addPositionalParam("var", "The name of the variable")
|
21
|
+
.setAction(async () => {
|
22
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
23
|
+
});
|
24
|
+
|
25
|
+
varsScope
|
26
|
+
.task("list", "List all the configuration variables")
|
27
|
+
.setAction(async () => {
|
28
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
29
|
+
});
|
30
|
+
|
31
|
+
varsScope
|
32
|
+
.task("delete", "Delete a configuration variable")
|
33
|
+
.addPositionalParam("var", "The name of the variable")
|
34
|
+
.setAction(async () => {
|
35
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
36
|
+
});
|
37
|
+
|
38
|
+
varsScope
|
39
|
+
.task(
|
40
|
+
"path",
|
41
|
+
"Show the path of the file where all the configuration variables are stored"
|
42
|
+
)
|
43
|
+
.setAction(async () => {
|
44
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
45
|
+
});
|
46
|
+
|
47
|
+
varsScope
|
48
|
+
.task(
|
49
|
+
"setup",
|
50
|
+
"Show how to setup the configuration variables used by this project"
|
51
|
+
)
|
52
|
+
.setAction(async () => {
|
53
|
+
throw new HardhatError(ERRORS.VARS.ONLY_MANAGED_IN_CLI);
|
54
|
+
});
|
@@ -0,0 +1,106 @@
|
|
1
|
+
import type { BigNumber as EthersBigNumberType } from "ethers-v5";
|
2
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
3
|
+
import type { BigNumber as BigNumberJsType } from "bignumber.js";
|
4
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
5
|
+
import type { default as BNType } from "bn.js";
|
6
|
+
|
7
|
+
import { HardhatError } from "../internal/core/errors";
|
8
|
+
import { ERRORS } from "../internal/core/errors-list";
|
9
|
+
|
10
|
+
export function normalizeToBigInt(
|
11
|
+
source:
|
12
|
+
| number
|
13
|
+
| bigint
|
14
|
+
| BNType
|
15
|
+
| EthersBigNumberType
|
16
|
+
| BigNumberJsType
|
17
|
+
| string
|
18
|
+
): bigint {
|
19
|
+
switch (typeof source) {
|
20
|
+
case "object":
|
21
|
+
if (isBigNumber(source)) {
|
22
|
+
return BigInt(source.toString());
|
23
|
+
} else {
|
24
|
+
throw new HardhatError(ERRORS.GENERAL.INVALID_BIG_NUMBER, {
|
25
|
+
message: `Value ${JSON.stringify(
|
26
|
+
source
|
27
|
+
)} is of type "object" but is not an instanceof one of the known big number object types.`,
|
28
|
+
});
|
29
|
+
}
|
30
|
+
case "number":
|
31
|
+
if (!Number.isInteger(source)) {
|
32
|
+
throw new HardhatError(ERRORS.GENERAL.INVALID_BIG_NUMBER, {
|
33
|
+
message: `${source} is not an integer`,
|
34
|
+
});
|
35
|
+
}
|
36
|
+
if (!Number.isSafeInteger(source)) {
|
37
|
+
throw new HardhatError(ERRORS.GENERAL.INVALID_BIG_NUMBER, {
|
38
|
+
message: `Integer ${source} is unsafe. Consider using ${source}n instead. For more details, see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isSafeInteger`,
|
39
|
+
});
|
40
|
+
}
|
41
|
+
// `break;` intentionally omitted. fallthrough desired.
|
42
|
+
case "string":
|
43
|
+
case "bigint":
|
44
|
+
return BigInt(source);
|
45
|
+
default:
|
46
|
+
const _exhaustiveCheck: never = source;
|
47
|
+
throw new HardhatError(ERRORS.GENERAL.INVALID_BIG_NUMBER, {
|
48
|
+
message: `Unsupported type ${typeof source}`,
|
49
|
+
});
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
53
|
+
export function isBigNumber(source: any): boolean {
|
54
|
+
return (
|
55
|
+
typeof source === "bigint" ||
|
56
|
+
isEthersBigNumber(source) ||
|
57
|
+
isBN(source) ||
|
58
|
+
isBigNumberJsBigNumber(source)
|
59
|
+
);
|
60
|
+
}
|
61
|
+
|
62
|
+
function isBN(n: any) {
|
63
|
+
try {
|
64
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
65
|
+
const BN: typeof BNType = require("bn.js");
|
66
|
+
return BN.isBN(n);
|
67
|
+
} catch (e) {
|
68
|
+
return false;
|
69
|
+
}
|
70
|
+
}
|
71
|
+
|
72
|
+
function isEthersBigNumber(n: any) {
|
73
|
+
try {
|
74
|
+
const BigNumber: typeof EthersBigNumberType =
|
75
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
76
|
+
require("ethers").ethers.BigNumber;
|
77
|
+
return BigNumber.isBigNumber(n);
|
78
|
+
} catch (e) {
|
79
|
+
return false;
|
80
|
+
}
|
81
|
+
}
|
82
|
+
|
83
|
+
function isBigNumberJsBigNumber(n: any) {
|
84
|
+
try {
|
85
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
86
|
+
const BigNumber: typeof BigNumberJsType = require("bignumber.js").BigNumber;
|
87
|
+
return BigNumber.isBigNumber(n);
|
88
|
+
} catch (e) {
|
89
|
+
return false;
|
90
|
+
}
|
91
|
+
}
|
92
|
+
|
93
|
+
export function formatNumberType(
|
94
|
+
n: string | bigint | BNType | EthersBigNumberType | BigNumberJsType
|
95
|
+
): string {
|
96
|
+
if (typeof n === "object") {
|
97
|
+
if (isBN(n)) {
|
98
|
+
return "BN";
|
99
|
+
} else if (isEthersBigNumber(n)) {
|
100
|
+
return "ethers.BigNumber";
|
101
|
+
} else if (isBigNumberJsBigNumber(n)) {
|
102
|
+
return "bignumber.js";
|
103
|
+
}
|
104
|
+
}
|
105
|
+
return typeof n;
|
106
|
+
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { HardhatError } from "../internal/core/errors";
|
2
|
+
import { ERRORS } from "../internal/core/errors-list";
|
3
|
+
|
4
|
+
export function requireNapiRsModule(id: string): unknown {
|
5
|
+
try {
|
6
|
+
return require(id);
|
7
|
+
} catch (e: any) {
|
8
|
+
if (e.code === "MODULE_NOT_FOUND") {
|
9
|
+
throw new HardhatError(ERRORS.GENERAL.CORRUPTED_LOCKFILE);
|
10
|
+
}
|
11
|
+
|
12
|
+
// eslint-disable-next-line @nomicfoundation/hardhat-internal-rules/only-hardhat-error
|
13
|
+
throw e;
|
14
|
+
}
|
15
|
+
}
|
package/src/config.ts
ADDED