hardhat 2.13.0-dev.2 → 2.13.0-dev.3
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/builtin-tasks/compile.js +16 -6
- package/builtin-tasks/compile.js.map +1 -1
- package/builtin-tasks/flatten.js +1 -1
- package/builtin-tasks/flatten.js.map +1 -1
- package/builtin-tasks/help.js +2 -4
- package/builtin-tasks/help.js.map +1 -1
- package/builtin-tasks/task-names.d.ts +1 -0
- package/builtin-tasks/task-names.d.ts.map +1 -1
- package/builtin-tasks/task-names.js +3 -2
- package/builtin-tasks/task-names.js.map +1 -1
- package/builtin-tasks/test.js +22 -1
- package/builtin-tasks/test.js.map +1 -1
- package/internal/cli/bootstrap.d.ts +1 -0
- package/internal/cli/bootstrap.js +12 -20
- package/internal/cli/bootstrap.js.map +1 -1
- package/internal/cli/cli.d.ts +0 -1
- package/internal/cli/cli.d.ts.map +1 -1
- package/internal/cli/cli.js +20 -29
- package/internal/cli/cli.js.map +1 -1
- package/internal/cli/project-creation.d.ts +1 -2
- package/internal/cli/project-creation.d.ts.map +1 -1
- package/internal/cli/project-creation.js +105 -36
- package/internal/cli/project-creation.js.map +1 -1
- package/internal/cli/prompt.d.ts +2 -2
- package/internal/cli/prompt.d.ts.map +1 -1
- package/internal/cli/prompt.js +1 -2
- package/internal/cli/prompt.js.map +1 -1
- package/internal/cli/types.d.ts +1 -0
- package/internal/cli/types.d.ts.map +1 -1
- package/internal/core/config/config-env.d.ts +5 -11
- package/internal/core/config/config-env.d.ts.map +1 -1
- package/internal/core/config/config-env.js +2 -13
- package/internal/core/config/config-env.js.map +1 -1
- package/internal/core/config/config-loading.d.ts +2 -1
- package/internal/core/config/config-loading.d.ts.map +1 -1
- package/internal/core/config/config-loading.js +25 -7
- package/internal/core/config/config-loading.js.map +1 -1
- package/internal/core/config/config-validation.d.ts +2 -0
- package/internal/core/config/config-validation.d.ts.map +1 -1
- package/internal/core/config/config-validation.js +18 -1
- package/internal/core/config/config-validation.js.map +1 -1
- package/internal/core/config/extenders.d.ts +4 -7
- package/internal/core/config/extenders.d.ts.map +1 -1
- package/internal/core/config/extenders.js +5 -12
- package/internal/core/config/extenders.js.map +1 -1
- package/internal/core/errors-list.d.ts +28 -7
- package/internal/core/errors-list.d.ts.map +1 -1
- package/internal/core/errors-list.js +33 -10
- package/internal/core/errors-list.js.map +1 -1
- package/internal/core/jsonrpc/types/input/blockTag.d.ts +3 -3
- package/internal/core/jsonrpc/types/input/blockTag.d.ts.map +1 -1
- package/internal/core/project-structure.d.ts.map +1 -1
- package/internal/core/project-structure.js +6 -0
- package/internal/core/project-structure.js.map +1 -1
- package/internal/core/providers/construction.d.ts.map +1 -1
- package/internal/core/providers/construction.js +25 -5
- package/internal/core/providers/construction.js.map +1 -1
- package/internal/core/providers/http.d.ts +2 -2
- package/internal/core/providers/http.d.ts.map +1 -1
- package/internal/core/providers/http.js +41 -19
- package/internal/core/providers/http.js.map +1 -1
- package/internal/core/runtime-environment.d.ts +4 -2
- package/internal/core/runtime-environment.d.ts.map +1 -1
- package/internal/core/runtime-environment.js +39 -47
- package/internal/core/runtime-environment.js.map +1 -1
- package/internal/core/tasks/dsl.d.ts +6 -6
- package/internal/core/tasks/dsl.d.ts.map +1 -1
- package/internal/core/tasks/dsl.js.map +1 -1
- package/internal/core/tasks/task-definitions.d.ts +2 -2
- package/internal/core/tasks/task-definitions.d.ts.map +1 -1
- package/internal/core/tasks/task-definitions.js.map +1 -1
- package/internal/hardhat-network/jsonrpc/handler.d.ts +1 -0
- package/internal/hardhat-network/jsonrpc/handler.d.ts.map +1 -1
- package/internal/hardhat-network/jsonrpc/handler.js +13 -18
- package/internal/hardhat-network/jsonrpc/handler.js.map +1 -1
- package/internal/hardhat-network/provider/RethnetState.d.ts +26 -0
- package/internal/hardhat-network/provider/RethnetState.d.ts.map +1 -0
- package/internal/hardhat-network/provider/RethnetState.js +84 -0
- package/internal/hardhat-network/provider/RethnetState.js.map +1 -0
- package/internal/hardhat-network/provider/modules/evm.d.ts +2 -1
- package/internal/hardhat-network/provider/modules/evm.d.ts.map +1 -1
- package/internal/hardhat-network/provider/modules/evm.js +10 -4
- package/internal/hardhat-network/provider/modules/evm.js.map +1 -1
- package/internal/hardhat-network/provider/node-types.d.ts +1 -1
- package/internal/hardhat-network/provider/node-types.d.ts.map +1 -1
- package/internal/hardhat-network/provider/node.d.ts +1 -0
- package/internal/hardhat-network/provider/node.d.ts.map +1 -1
- package/internal/hardhat-network/provider/node.js +6 -4
- package/internal/hardhat-network/provider/node.js.map +1 -1
- package/internal/hardhat-network/provider/provider.d.ts +25 -21
- package/internal/hardhat-network/provider/provider.d.ts.map +1 -1
- package/internal/hardhat-network/provider/provider.js +25 -42
- package/internal/hardhat-network/provider/provider.js.map +1 -1
- package/internal/hardhat-network/provider/return-data.js +2 -2
- package/internal/hardhat-network/provider/return-data.js.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.d.ts.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.js +4 -2
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.js.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.d.ts.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.js +4 -2
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.js.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.d.ts.map +1 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.js +4 -2
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.js.map +1 -1
- package/internal/hardhat-network/provider/utils/bloom.d.ts +32 -0
- package/internal/hardhat-network/provider/utils/bloom.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/bloom.js +79 -0
- package/internal/hardhat-network/provider/utils/bloom.js.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToRethnet.d.ts +12 -0
- package/internal/hardhat-network/provider/utils/convertToRethnet.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToRethnet.js +162 -0
- package/internal/hardhat-network/provider/utils/convertToRethnet.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeFakeSignature.d.ts +7 -0
- package/internal/hardhat-network/provider/utils/makeFakeSignature.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeFakeSignature.js +31 -0
- package/internal/hardhat-network/provider/utils/makeFakeSignature.js.map +1 -0
- package/internal/hardhat-network/provider/utils/putGenesisBlock.d.ts +1 -1
- package/internal/hardhat-network/provider/utils/putGenesisBlock.d.ts.map +1 -1
- package/internal/hardhat-network/provider/utils/putGenesisBlock.js +2 -2
- package/internal/hardhat-network/provider/utils/putGenesisBlock.js.map +1 -1
- package/internal/hardhat-network/provider/vm/block-builder.d.ts +31 -0
- package/internal/hardhat-network/provider/vm/block-builder.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/block-builder.js +151 -0
- package/internal/hardhat-network/provider/vm/block-builder.js.map +1 -0
- package/internal/hardhat-network/provider/vm/creation.d.ts +10 -0
- package/internal/hardhat-network/provider/vm/creation.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/creation.js +29 -0
- package/internal/hardhat-network/provider/vm/creation.js.map +1 -0
- package/internal/hardhat-network/provider/vm/dual.d.ts +43 -0
- package/internal/hardhat-network/provider/vm/dual.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/dual.js +488 -0
- package/internal/hardhat-network/provider/vm/dual.js.map +1 -0
- package/internal/hardhat-network/provider/vm/ethereumjs.d.ts +56 -0
- package/internal/hardhat-network/provider/vm/ethereumjs.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/ethereumjs.js +416 -0
- package/internal/hardhat-network/provider/vm/ethereumjs.js.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts +23 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.js +130 -0
- package/internal/hardhat-network/provider/vm/exit.js.map +1 -0
- package/internal/hardhat-network/provider/vm/rethnet.d.ts +99 -0
- package/internal/hardhat-network/provider/vm/rethnet.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/rethnet.js +284 -0
- package/internal/hardhat-network/provider/vm/rethnet.js.map +1 -0
- package/internal/hardhat-network/provider/vm/vm-adapter.d.ts +52 -0
- package/internal/hardhat-network/provider/vm/vm-adapter.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/vm-adapter.js +3 -0
- package/internal/hardhat-network/provider/vm/vm-adapter.js.map +1 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/compiler-to-model.js +37 -11
- package/internal/hardhat-network/stack-traces/compiler-to-model.js.map +1 -1
- package/internal/hardhat-network/stack-traces/consoleLogger.js.map +1 -1
- package/internal/hardhat-network/stack-traces/constants.d.ts +1 -1
- package/internal/hardhat-network/stack-traces/constants.js +1 -1
- package/internal/hardhat-network/stack-traces/debug.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/debug.js +6 -2
- package/internal/hardhat-network/stack-traces/debug.js.map +1 -1
- package/internal/hardhat-network/stack-traces/error-inferrer.d.ts +1 -0
- package/internal/hardhat-network/stack-traces/error-inferrer.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/error-inferrer.js +85 -55
- package/internal/hardhat-network/stack-traces/error-inferrer.js.map +1 -1
- package/internal/hardhat-network/stack-traces/model.d.ts +3 -1
- package/internal/hardhat-network/stack-traces/model.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/model.js +9 -1
- package/internal/hardhat-network/stack-traces/model.js.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-errors.js +2 -2
- package/internal/hardhat-network/stack-traces/solidity-errors.js.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts +2 -2
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/solidityTracer.js +1 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.js.map +1 -1
- package/internal/lib/hardhat-lib.d.ts.map +1 -1
- package/internal/lib/hardhat-lib.js +1 -4
- package/internal/lib/hardhat-lib.js.map +1 -1
- package/internal/solidity/compiler/downloader.js +2 -2
- package/internal/solidity/compiler/downloader.js.map +1 -1
- package/internal/solidity/compiler/index.js +1 -1
- package/internal/solidity/compiler/index.js.map +1 -1
- package/internal/solidity/resolver.d.ts +4 -3
- package/internal/solidity/resolver.d.ts.map +1 -1
- package/internal/solidity/resolver.js +18 -7
- package/internal/solidity/resolver.js.map +1 -1
- package/internal/util/abi-helpers.d.ts +1 -0
- package/internal/util/abi-helpers.d.ts.map +1 -1
- package/internal/util/abi-helpers.js +9 -0
- package/internal/util/abi-helpers.js.map +1 -1
- package/internal/util/download.d.ts.map +1 -1
- package/internal/util/download.js +12 -11
- package/internal/util/download.js.map +1 -1
- package/internal/util/packageInfo.d.ts +6 -1
- package/internal/util/packageInfo.d.ts.map +1 -1
- package/internal/util/packageInfo.js +14 -11
- package/internal/util/packageInfo.js.map +1 -1
- 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/package.json +9 -10
- package/register.js +1 -4
- package/register.js.map +1 -1
- package/sample-projects/javascript/hardhat.config.js +1 -1
- package/sample-projects/javascript/scripts/deploy.js +2 -2
- 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/scripts/deploy.js +22 -0
- package/sample-projects/javascript-esm/test/Lock.js +123 -0
- package/sample-projects/typescript/hardhat.config.ts +1 -1
- package/sample-projects/typescript/scripts/deploy.ts +2 -2
- package/sample-projects/typescript/tsconfig.json +2 -1
- package/src/builtin-tasks/compile.ts +28 -7
- package/src/builtin-tasks/flatten.ts +4 -1
- package/src/builtin-tasks/help.ts +15 -16
- package/src/builtin-tasks/task-names.ts +2 -0
- package/src/builtin-tasks/test.ts +30 -2
- package/src/internal/artifacts.ts +947 -0
- package/src/internal/cli/bootstrap.ts +14 -36
- package/src/internal/cli/cli.ts +38 -43
- package/src/internal/cli/project-creation.ts +128 -47
- package/src/internal/cli/prompt.ts +2 -4
- package/src/internal/cli/types.ts +2 -0
- package/src/internal/core/config/config-env.ts +15 -27
- package/src/internal/core/config/config-loading.ts +35 -11
- package/src/internal/core/config/config-validation.ts +20 -0
- package/src/internal/core/config/extenders.ts +6 -15
- package/src/internal/core/errors-list.ts +36 -10
- package/src/internal/core/project-structure.ts +8 -0
- package/src/internal/core/providers/construction.ts +29 -24
- package/src/internal/core/providers/http.ts +38 -26
- package/src/internal/core/runtime-environment.ts +65 -60
- package/src/internal/core/tasks/dsl.ts +17 -17
- package/src/internal/core/tasks/task-definitions.ts +6 -2
- package/src/internal/hardhat-network/jsonrpc/handler.ts +31 -28
- package/src/internal/hardhat-network/provider/modules/evm.ts +15 -3
- package/src/internal/hardhat-network/provider/node-types.ts +1 -1
- package/src/internal/hardhat-network/provider/node.ts +5 -1
- package/src/internal/hardhat-network/provider/provider.ts +60 -49
- package/src/internal/hardhat-network/provider/return-data.ts +2 -2
- package/src/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.ts +5 -2
- package/src/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.ts +5 -2
- package/src/internal/hardhat-network/provider/transactions/FakeSenderTransaction.ts +5 -2
- package/src/internal/hardhat-network/provider/utils/makeFakeSignature.ts +46 -0
- package/src/internal/hardhat-network/provider/utils/putGenesisBlock.ts +2 -2
- package/src/internal/hardhat-network/stack-traces/compiler-to-model.ts +71 -9
- package/src/internal/hardhat-network/stack-traces/consoleLogger.ts +1 -1
- package/src/internal/hardhat-network/stack-traces/constants.ts +1 -1
- package/src/internal/hardhat-network/stack-traces/debug.ts +9 -2
- package/src/internal/hardhat-network/stack-traces/error-inferrer.ts +177 -89
- package/src/internal/hardhat-network/stack-traces/model.ts +11 -1
- package/src/internal/hardhat-network/stack-traces/solidity-errors.ts +2 -2
- package/src/internal/hardhat-network/stack-traces/solidity-stack-trace.ts +2 -2
- package/src/internal/hardhat-network/stack-traces/solidityTracer.ts +3 -0
- package/src/internal/lib/hardhat-lib.ts +1 -6
- package/src/internal/solidity/compiler/downloader.ts +2 -2
- package/src/internal/solidity/compiler/index.ts +1 -1
- package/src/internal/solidity/resolver.ts +28 -11
- package/src/internal/util/abi-helpers.ts +9 -0
- package/src/internal/util/download.ts +13 -15
- package/src/internal/util/packageInfo.ts +24 -10
- package/src/internal/util/proxy.ts +18 -0
- package/src/register.ts +1 -6
- package/src/types/artifacts.ts +14 -112
- package/src/types/config.ts +2 -0
- package/src/types/runtime.ts +16 -13
- package/types/artifacts.d.ts +10 -96
- package/types/artifacts.d.ts.map +1 -1
- package/types/config.d.ts +2 -0
- package/types/config.d.ts.map +1 -1
- package/types/runtime.d.ts +9 -10
- package/types/runtime.d.ts.map +1 -1
- package/internal/artifacts/caching.d.ts +0 -28
- package/internal/artifacts/caching.d.ts.map +0 -1
- package/internal/artifacts/caching.js +0 -178
- package/internal/artifacts/caching.js.map +0 -1
- package/internal/artifacts/index.d.ts +0 -45
- package/internal/artifacts/index.d.ts.map +0 -1
- package/internal/artifacts/index.js +0 -191
- package/internal/artifacts/index.js.map +0 -1
- package/internal/artifacts/mutable.d.ts +0 -29
- package/internal/artifacts/mutable.d.ts.map +0 -1
- package/internal/artifacts/mutable.js +0 -226
- package/internal/artifacts/mutable.js.map +0 -1
- package/internal/artifacts/readonly.d.ts +0 -94
- package/internal/artifacts/readonly.d.ts.map +0 -1
- package/internal/artifacts/readonly.js +0 -343
- package/internal/artifacts/readonly.js.map +0 -1
- package/src/internal/artifacts/caching.ts +0 -259
- package/src/internal/artifacts/index.ts +0 -302
- package/src/internal/artifacts/mutable.ts +0 -330
- package/src/internal/artifacts/readonly.ts +0 -470
|
@@ -1,470 +0,0 @@
|
|
|
1
|
-
import * as os from "os";
|
|
2
|
-
import * as path from "path";
|
|
3
|
-
|
|
4
|
-
import fsExtra from "fs-extra";
|
|
5
|
-
|
|
6
|
-
import { Artifact, BuildInfo } from "../../types";
|
|
7
|
-
import {
|
|
8
|
-
getFullyQualifiedName,
|
|
9
|
-
isFullyQualifiedName,
|
|
10
|
-
parseFullyQualifiedName,
|
|
11
|
-
findDistance,
|
|
12
|
-
} from "../../utils/contract-names";
|
|
13
|
-
import { replaceBackslashes } from "../../utils/source-names";
|
|
14
|
-
|
|
15
|
-
import { BUILD_INFO_DIR_NAME, EDIT_DISTANCE_THRESHOLD } from "../constants";
|
|
16
|
-
import { HardhatError } from "../core/errors";
|
|
17
|
-
import { ERRORS } from "../core/errors-list";
|
|
18
|
-
import {
|
|
19
|
-
FileNotFoundError,
|
|
20
|
-
getAllFilesMatching,
|
|
21
|
-
getAllFilesMatchingSync,
|
|
22
|
-
getFileTrueCase,
|
|
23
|
-
getFileTrueCaseSync,
|
|
24
|
-
} from "../util/fs-utils";
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* The purpose of this class is to encapsulate JSON file I/O. It assumes that
|
|
28
|
-
* all input strings are simply paths, not contract names nor fully-qualified
|
|
29
|
-
* contract names like other interfaces around here accept.
|
|
30
|
-
*/
|
|
31
|
-
class ReadOnlyByPath {
|
|
32
|
-
protected async _readArtifactByPath(artifactPath: string): Promise<Artifact> {
|
|
33
|
-
return fsExtra.readJson(artifactPath);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
protected _readArtifactByPathSync(artifactPath: string): Artifact {
|
|
37
|
-
return fsExtra.readJsonSync(artifactPath);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
protected async _artifactPathExists(artifactPath: string): Promise<boolean> {
|
|
41
|
-
return fsExtra.pathExists(artifactPath);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
protected async _getBuildInfoByPath(
|
|
45
|
-
buildInfoPath: string
|
|
46
|
-
): Promise<BuildInfo | undefined> {
|
|
47
|
-
return fsExtra.readJSON(buildInfoPath);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
protected _getBuildInfoByPathSync(
|
|
51
|
-
buildInfoPath: string
|
|
52
|
-
): BuildInfo | undefined {
|
|
53
|
-
return fsExtra.readJSONSync(buildInfoPath);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Given the path to a debug file, returns the absolute path to its
|
|
58
|
-
* corresponding build info file if it exists, or undefined otherwise.
|
|
59
|
-
*/
|
|
60
|
-
protected static async _getBuildInfoFromDebugFile(
|
|
61
|
-
debugFilePath: string
|
|
62
|
-
): Promise<string | undefined> {
|
|
63
|
-
if (await fsExtra.pathExists(debugFilePath)) {
|
|
64
|
-
const { buildInfo } = await fsExtra.readJson(debugFilePath);
|
|
65
|
-
return path.resolve(path.dirname(debugFilePath), buildInfo);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return undefined;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Synchronous version of _getBuildInfoFromDebugFile
|
|
73
|
-
*/
|
|
74
|
-
protected static _getBuildInfoFromDebugFileSync(
|
|
75
|
-
debugFilePath: string
|
|
76
|
-
): string | undefined {
|
|
77
|
-
if (fsExtra.pathExistsSync(debugFilePath)) {
|
|
78
|
-
const { buildInfo } = fsExtra.readJsonSync(debugFilePath);
|
|
79
|
-
return path.resolve(path.dirname(debugFilePath), buildInfo);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
return undefined;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
protected _getDebugFilePath(artifactPath: string): string {
|
|
86
|
-
return artifactPath.replace(/\.json$/, ".dbg.json");
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* This class takes responsibility for the mappings between contract names,
|
|
92
|
-
* fully-qualified contract names, and file paths.
|
|
93
|
-
*/
|
|
94
|
-
export class ReadOnlySource extends ReadOnlyByPath {
|
|
95
|
-
constructor(protected _artifactsPath: string) {
|
|
96
|
-
super();
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
public async artifactExists(name: string): Promise<boolean> {
|
|
100
|
-
const artifactPath = await this._getArtifactPath(name);
|
|
101
|
-
|
|
102
|
-
if (artifactPath === undefined) {
|
|
103
|
-
return false;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
return super._artifactPathExists(artifactPath);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
public async getArtifactPaths(): Promise<string[]> {
|
|
110
|
-
const buildInfosDir = path.join(this._artifactsPath, BUILD_INFO_DIR_NAME);
|
|
111
|
-
|
|
112
|
-
const paths = await getAllFilesMatching(
|
|
113
|
-
this._artifactsPath,
|
|
114
|
-
(f) =>
|
|
115
|
-
f.endsWith(".json") &&
|
|
116
|
-
!f.startsWith(buildInfosDir) &&
|
|
117
|
-
!f.endsWith(".dbg.json")
|
|
118
|
-
);
|
|
119
|
-
|
|
120
|
-
return paths.sort();
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* Returns the absolute path to the given artifact
|
|
125
|
-
*/
|
|
126
|
-
public formArtifactPathFromFullyQualifiedName(
|
|
127
|
-
fullyQualifiedName: string
|
|
128
|
-
): string {
|
|
129
|
-
const { sourceName, contractName } =
|
|
130
|
-
parseFullyQualifiedName(fullyQualifiedName);
|
|
131
|
-
|
|
132
|
-
return path.join(this._artifactsPath, sourceName, `${contractName}.json`);
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
public async getAllFullyQualifiedNames(): Promise<string[]> {
|
|
136
|
-
const paths = await this.getArtifactPaths();
|
|
137
|
-
return paths.map((p) => this._getFullyQualifiedNameFromPath(p)).sort();
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
public async getBuildInfo(
|
|
141
|
-
fullyQualifiedName: string
|
|
142
|
-
): Promise<BuildInfo | undefined> {
|
|
143
|
-
const buildInfoPath = await this._getBuildInfoPath(fullyQualifiedName);
|
|
144
|
-
|
|
145
|
-
if (buildInfoPath === undefined) {
|
|
146
|
-
return undefined;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
return super._getBuildInfoByPath(buildInfoPath);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
public async getBuildInfoPaths(): Promise<string[]> {
|
|
153
|
-
const paths = await getAllFilesMatching(
|
|
154
|
-
path.join(this._artifactsPath, BUILD_INFO_DIR_NAME),
|
|
155
|
-
(f) => f.endsWith(".json")
|
|
156
|
-
);
|
|
157
|
-
|
|
158
|
-
return paths.sort();
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
public async getDebugFilePaths(): Promise<string[]> {
|
|
162
|
-
const paths = await getAllFilesMatching(
|
|
163
|
-
path.join(this._artifactsPath),
|
|
164
|
-
(f) => f.endsWith(".dbg.json")
|
|
165
|
-
);
|
|
166
|
-
|
|
167
|
-
return paths.sort();
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
public async readArtifact(name: string): Promise<Artifact | undefined> {
|
|
171
|
-
const artifactPath = await this._getArtifactPath(name);
|
|
172
|
-
if (artifactPath === undefined) {
|
|
173
|
-
return undefined;
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
return super._readArtifactByPath(artifactPath);
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
public readArtifactSync(name: string): Artifact | undefined {
|
|
180
|
-
const artifactPath = this._getArtifactPathSync(name);
|
|
181
|
-
if (artifactPath === undefined) {
|
|
182
|
-
return undefined;
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
return super._readArtifactByPathSync(artifactPath);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
public getSuggestions(name: string): string[] {
|
|
189
|
-
if (isFullyQualifiedName(name)) {
|
|
190
|
-
const fqns = this._getAllFullyQualifiedNamesSync();
|
|
191
|
-
|
|
192
|
-
return ReadOnlySource._getSimilarContractNames(name, fqns);
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
const files = this._getArtifactPathsSync();
|
|
196
|
-
const names = this._getAllContractNamesFromFiles(files);
|
|
197
|
-
|
|
198
|
-
let similarNames = ReadOnlySource._getSimilarContractNames(name, names);
|
|
199
|
-
|
|
200
|
-
if (similarNames.length > 1) {
|
|
201
|
-
similarNames = this._filterDuplicatesAsFullyQualifiedNames(
|
|
202
|
-
files,
|
|
203
|
-
similarNames
|
|
204
|
-
);
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
return similarNames;
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
/**
|
|
211
|
-
* If the project has these contracts:
|
|
212
|
-
* - 'contracts/Greeter.sol:Greeter'
|
|
213
|
-
* - 'contracts/Meeter.sol:Greeter'
|
|
214
|
-
* - 'contracts/Greater.sol:Greater'
|
|
215
|
-
* And the user tries to get an artifact with the name 'Greter', then
|
|
216
|
-
* the suggestions will be 'Greeter', 'Greeter', and 'Greater'.
|
|
217
|
-
*
|
|
218
|
-
* We don't want to show duplicates here, so we use FQNs for those. The
|
|
219
|
-
* suggestions will then be:
|
|
220
|
-
* - 'contracts/Greeter.sol:Greeter'
|
|
221
|
-
* - 'contracts/Meeter.sol:Greeter'
|
|
222
|
-
* - 'Greater'
|
|
223
|
-
*/
|
|
224
|
-
private _filterDuplicatesAsFullyQualifiedNames(
|
|
225
|
-
files: string[],
|
|
226
|
-
similarNames: string[]
|
|
227
|
-
): string[] {
|
|
228
|
-
const outputNames = [];
|
|
229
|
-
const groups = similarNames.reduce((obj, cur) => {
|
|
230
|
-
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions
|
|
231
|
-
obj[cur] = obj[cur] ? obj[cur] + 1 : 1;
|
|
232
|
-
return obj;
|
|
233
|
-
}, {} as { [k: string]: number });
|
|
234
|
-
|
|
235
|
-
for (const [name, occurrences] of Object.entries(groups)) {
|
|
236
|
-
if (occurrences > 1) {
|
|
237
|
-
for (const file of files) {
|
|
238
|
-
if (path.basename(file) === `${name}.json`) {
|
|
239
|
-
outputNames.push(this._getFullyQualifiedNameFromPath(file));
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
continue;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
outputNames.push(name);
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
return outputNames;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
private _getAllContractNamesFromFiles(files: string[]): string[] {
|
|
252
|
-
return files.map((file) => {
|
|
253
|
-
const fqn = this._getFullyQualifiedNameFromPath(file);
|
|
254
|
-
return parseFullyQualifiedName(fqn).contractName;
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
private _getAllFullyQualifiedNamesSync(): string[] {
|
|
259
|
-
const paths = this._getArtifactPathsSync();
|
|
260
|
-
return paths.map((p) => this._getFullyQualifiedNameFromPath(p)).sort();
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
/**
|
|
264
|
-
* Returns the absolute path to the artifact that corresponds to the given
|
|
265
|
-
* name.
|
|
266
|
-
*
|
|
267
|
-
* If the name is fully qualified, the path is computed from it. If not, an
|
|
268
|
-
* artifact that matches the given name is searched in the existing artifacts.
|
|
269
|
-
* If there is an ambiguity, an error is thrown.
|
|
270
|
-
*/
|
|
271
|
-
protected async _getArtifactPath(name: string): Promise<string | undefined> {
|
|
272
|
-
let result: string | undefined;
|
|
273
|
-
if (isFullyQualifiedName(name)) {
|
|
274
|
-
result = await this._getValidArtifactPathFromFullyQualifiedName(name);
|
|
275
|
-
} else {
|
|
276
|
-
const files = await this.getArtifactPaths();
|
|
277
|
-
result = this._getArtifactPathFromFiles(name, files);
|
|
278
|
-
}
|
|
279
|
-
return result;
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
protected _getArtifactPathSync(name: string): string | undefined {
|
|
283
|
-
let result: string | undefined;
|
|
284
|
-
if (isFullyQualifiedName(name)) {
|
|
285
|
-
result = this._getValidArtifactPathFromFullyQualifiedNameSync(name);
|
|
286
|
-
} else {
|
|
287
|
-
const files = this._getArtifactPathsSync();
|
|
288
|
-
result = this._getArtifactPathFromFiles(name, files);
|
|
289
|
-
}
|
|
290
|
-
return result;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
private _getArtifactPathFromFiles(
|
|
294
|
-
contractName: string,
|
|
295
|
-
files: string[]
|
|
296
|
-
): string | undefined {
|
|
297
|
-
const matchingFiles = files.filter((file) => {
|
|
298
|
-
return path.basename(file) === `${contractName}.json`;
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
if (matchingFiles.length === 0) {
|
|
302
|
-
return undefined;
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
if (matchingFiles.length > 1) {
|
|
306
|
-
const candidates = matchingFiles.map((file) =>
|
|
307
|
-
this._getFullyQualifiedNameFromPath(file)
|
|
308
|
-
);
|
|
309
|
-
|
|
310
|
-
throw new HardhatError(ERRORS.ARTIFACTS.MULTIPLE_FOUND, {
|
|
311
|
-
contractName,
|
|
312
|
-
candidates: candidates.join(os.EOL),
|
|
313
|
-
});
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
return matchingFiles[0];
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
protected _getArtifactPathsSync(): string[] {
|
|
320
|
-
const buildInfosDir = path.join(this._artifactsPath, BUILD_INFO_DIR_NAME);
|
|
321
|
-
|
|
322
|
-
const paths = getAllFilesMatchingSync(
|
|
323
|
-
this._artifactsPath,
|
|
324
|
-
(f) =>
|
|
325
|
-
f.endsWith(".json") &&
|
|
326
|
-
!f.startsWith(buildInfosDir) &&
|
|
327
|
-
!f.endsWith(".dbg.json")
|
|
328
|
-
);
|
|
329
|
-
|
|
330
|
-
return paths.sort();
|
|
331
|
-
}
|
|
332
|
-
|
|
333
|
-
protected async _getBuildInfoPath(
|
|
334
|
-
fullyQualifiedName: string
|
|
335
|
-
): Promise<string | undefined> {
|
|
336
|
-
const artifactPath =
|
|
337
|
-
this.formArtifactPathFromFullyQualifiedName(fullyQualifiedName);
|
|
338
|
-
|
|
339
|
-
const debugFilePath = this._getDebugFilePath(artifactPath);
|
|
340
|
-
const buildInfoPath = await ReadOnlySource._getBuildInfoFromDebugFile(
|
|
341
|
-
debugFilePath
|
|
342
|
-
);
|
|
343
|
-
return buildInfoPath;
|
|
344
|
-
}
|
|
345
|
-
|
|
346
|
-
protected _getBuildInfoPathSync(
|
|
347
|
-
fullyQualifiedName: string
|
|
348
|
-
): string | undefined {
|
|
349
|
-
const artifactPath =
|
|
350
|
-
this.formArtifactPathFromFullyQualifiedName(fullyQualifiedName);
|
|
351
|
-
|
|
352
|
-
const debugFilePath = this._getDebugFilePath(artifactPath);
|
|
353
|
-
const buildInfoPath =
|
|
354
|
-
ReadOnlySource._getBuildInfoFromDebugFileSync(debugFilePath);
|
|
355
|
-
return buildInfoPath;
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
/**
|
|
359
|
-
* Returns the FQN of a contract giving the absolute path to its artifact.
|
|
360
|
-
*
|
|
361
|
-
* For example, given a path like
|
|
362
|
-
* `/path/to/project/artifacts/contracts/Foo.sol/Bar.json`, it'll return the
|
|
363
|
-
* FQN `contracts/Foo.sol:Bar`
|
|
364
|
-
*/
|
|
365
|
-
private _getFullyQualifiedNameFromPath(absolutePath: string): string {
|
|
366
|
-
const sourceName = replaceBackslashes(
|
|
367
|
-
path.relative(this._artifactsPath, path.dirname(absolutePath))
|
|
368
|
-
);
|
|
369
|
-
|
|
370
|
-
const contractName = path.basename(absolutePath).replace(".json", "");
|
|
371
|
-
|
|
372
|
-
return getFullyQualifiedName(sourceName, contractName);
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
/**
|
|
376
|
-
*
|
|
377
|
-
* @param givenName can be FQN or contract name
|
|
378
|
-
* @param names MUST match type of givenName (i.e. array of FQN's if givenName is FQN)
|
|
379
|
-
* @returns
|
|
380
|
-
*/
|
|
381
|
-
private static _getSimilarContractNames(
|
|
382
|
-
givenName: string,
|
|
383
|
-
names: string[]
|
|
384
|
-
): string[] {
|
|
385
|
-
let shortestDistance = EDIT_DISTANCE_THRESHOLD;
|
|
386
|
-
let mostSimilarNames: string[] = [];
|
|
387
|
-
for (const name of names) {
|
|
388
|
-
const distance = findDistance(givenName, name);
|
|
389
|
-
|
|
390
|
-
if (distance < shortestDistance) {
|
|
391
|
-
shortestDistance = distance;
|
|
392
|
-
mostSimilarNames = [name];
|
|
393
|
-
continue;
|
|
394
|
-
}
|
|
395
|
-
|
|
396
|
-
if (distance === shortestDistance) {
|
|
397
|
-
mostSimilarNames.push(name);
|
|
398
|
-
continue;
|
|
399
|
-
}
|
|
400
|
-
}
|
|
401
|
-
|
|
402
|
-
return mostSimilarNames;
|
|
403
|
-
}
|
|
404
|
-
|
|
405
|
-
private async _getValidArtifactPathFromFullyQualifiedName(
|
|
406
|
-
fullyQualifiedName: string
|
|
407
|
-
): Promise<string | undefined> {
|
|
408
|
-
const artifactPath =
|
|
409
|
-
this.formArtifactPathFromFullyQualifiedName(fullyQualifiedName);
|
|
410
|
-
|
|
411
|
-
try {
|
|
412
|
-
const trueCasePath = path.join(
|
|
413
|
-
this._artifactsPath,
|
|
414
|
-
await getFileTrueCase(
|
|
415
|
-
this._artifactsPath,
|
|
416
|
-
path.relative(this._artifactsPath, artifactPath)
|
|
417
|
-
)
|
|
418
|
-
);
|
|
419
|
-
|
|
420
|
-
if (artifactPath !== trueCasePath) {
|
|
421
|
-
throw new HardhatError(ERRORS.ARTIFACTS.WRONG_CASING, {
|
|
422
|
-
correct: this._getFullyQualifiedNameFromPath(trueCasePath),
|
|
423
|
-
incorrect: fullyQualifiedName,
|
|
424
|
-
});
|
|
425
|
-
}
|
|
426
|
-
|
|
427
|
-
return trueCasePath;
|
|
428
|
-
} catch (e) {
|
|
429
|
-
if (e instanceof FileNotFoundError) {
|
|
430
|
-
return undefined;
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
// eslint-disable-next-line @nomiclabs/hardhat-internal-rules/only-hardhat-error
|
|
434
|
-
throw e;
|
|
435
|
-
}
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
private _getValidArtifactPathFromFullyQualifiedNameSync(
|
|
439
|
-
fullyQualifiedName: string
|
|
440
|
-
): string | undefined {
|
|
441
|
-
const artifactPath =
|
|
442
|
-
this.formArtifactPathFromFullyQualifiedName(fullyQualifiedName);
|
|
443
|
-
|
|
444
|
-
try {
|
|
445
|
-
const trueCasePath = path.join(
|
|
446
|
-
this._artifactsPath,
|
|
447
|
-
getFileTrueCaseSync(
|
|
448
|
-
this._artifactsPath,
|
|
449
|
-
path.relative(this._artifactsPath, artifactPath)
|
|
450
|
-
)
|
|
451
|
-
);
|
|
452
|
-
|
|
453
|
-
if (artifactPath !== trueCasePath) {
|
|
454
|
-
throw new HardhatError(ERRORS.ARTIFACTS.WRONG_CASING, {
|
|
455
|
-
correct: this._getFullyQualifiedNameFromPath(trueCasePath),
|
|
456
|
-
incorrect: fullyQualifiedName,
|
|
457
|
-
});
|
|
458
|
-
}
|
|
459
|
-
|
|
460
|
-
return trueCasePath;
|
|
461
|
-
} catch (e) {
|
|
462
|
-
if (e instanceof FileNotFoundError) {
|
|
463
|
-
return undefined;
|
|
464
|
-
}
|
|
465
|
-
|
|
466
|
-
// eslint-disable-next-line @nomiclabs/hardhat-internal-rules/only-hardhat-error
|
|
467
|
-
throw e;
|
|
468
|
-
}
|
|
469
|
-
}
|
|
470
|
-
}
|