@atlaspack/core 2.16.2-canary.48 → 2.16.2-canary.481
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/CHANGELOG.md +1324 -0
- package/dist/AssetGraph.js +523 -0
- package/dist/Atlaspack.js +701 -0
- package/dist/AtlaspackConfig.js +324 -0
- package/dist/AtlaspackConfig.schema.js +117 -0
- package/dist/BundleGraph.js +1906 -0
- package/dist/CommittedAsset.js +142 -0
- package/dist/Dependency.js +125 -0
- package/dist/Environment.js +132 -0
- package/dist/EnvironmentManager.js +108 -0
- package/dist/IdentifierRegistry.js +38 -0
- package/dist/InternalConfig.js +37 -0
- package/dist/PackagerRunner.js +470 -0
- package/dist/ReporterRunner.js +151 -0
- package/dist/RequestTracker.js +1297 -0
- package/dist/SymbolPropagation.js +624 -0
- package/dist/TargetDescriptor.schema.js +146 -0
- package/dist/Transformation.js +514 -0
- package/dist/UncommittedAsset.js +310 -0
- package/dist/Validation.js +196 -0
- package/dist/applyRuntimes.js +384 -0
- package/dist/assetUtils.js +169 -0
- package/dist/atlaspack-v3/AtlaspackV3.js +83 -0
- package/dist/atlaspack-v3/NapiWorkerPool.js +114 -0
- package/dist/atlaspack-v3/fs.js +53 -0
- package/dist/atlaspack-v3/index.js +25 -0
- package/dist/atlaspack-v3/jsCallable.js +16 -0
- package/dist/atlaspack-v3/worker/compat/asset-symbols.js +190 -0
- package/dist/atlaspack-v3/worker/compat/bitflags.js +98 -0
- package/dist/atlaspack-v3/worker/compat/dependency.js +43 -0
- package/dist/atlaspack-v3/worker/compat/environment.js +57 -0
- package/dist/atlaspack-v3/worker/compat/index.js +24 -0
- package/dist/atlaspack-v3/worker/compat/mutable-asset.js +152 -0
- package/dist/atlaspack-v3/worker/compat/plugin-config.js +64 -0
- package/dist/atlaspack-v3/worker/compat/plugin-options.js +137 -0
- package/dist/atlaspack-v3/worker/compat/plugin-tracer.js +10 -0
- package/dist/atlaspack-v3/worker/compat/target.js +14 -0
- package/dist/atlaspack-v3/worker/side-effect-detector.js +243 -0
- package/dist/atlaspack-v3/worker/worker.js +398 -0
- package/dist/constants.js +17 -0
- package/dist/dumpGraphToGraphViz.js +281 -0
- package/dist/index.js +62 -0
- package/dist/loadAtlaspackPlugin.js +128 -0
- package/dist/loadDotEnv.js +41 -0
- package/dist/projectPath.js +83 -0
- package/dist/public/Asset.js +279 -0
- package/dist/public/Bundle.js +224 -0
- package/dist/public/BundleGraph.js +371 -0
- package/dist/public/BundleGroup.js +53 -0
- package/dist/public/Config.js +286 -0
- package/dist/public/Dependency.js +138 -0
- package/dist/public/Environment.js +278 -0
- package/dist/public/MutableBundleGraph.js +277 -0
- package/dist/public/PluginOptions.js +80 -0
- package/dist/public/Symbols.js +248 -0
- package/dist/public/Target.js +69 -0
- package/dist/registerCoreWithSerializer.js +38 -0
- package/dist/requests/AssetGraphRequest.js +430 -0
- package/dist/requests/AssetGraphRequestRust.js +471 -0
- package/dist/requests/AssetRequest.js +130 -0
- package/dist/requests/AtlaspackBuildRequest.js +98 -0
- package/dist/requests/AtlaspackConfigRequest.js +493 -0
- package/dist/requests/BundleGraphRequest.js +381 -0
- package/dist/requests/BundleGraphRequestRust.js +324 -0
- package/dist/requests/BundleGraphRequestUtils.js +262 -0
- package/dist/requests/ConfigRequest.js +246 -0
- package/dist/requests/DevDepRequest.js +204 -0
- package/dist/requests/EntryRequest.js +314 -0
- package/dist/requests/PackageRequest.js +89 -0
- package/dist/requests/PathRequest.js +349 -0
- package/dist/requests/TargetRequest.js +1316 -0
- package/dist/requests/ValidationRequest.js +49 -0
- package/dist/requests/WriteBundleRequest.js +522 -0
- package/dist/requests/WriteBundlesRequest.js +190 -0
- package/dist/requests/asset-graph-diff.js +128 -0
- package/dist/requests/asset-graph-dot.js +131 -0
- package/dist/resolveOptions.js +267 -0
- package/dist/rustWorkerThreadDylibHack.js +19 -0
- package/dist/serializerCore.browser.js +43 -0
- package/dist/summarizeRequest.js +39 -0
- package/dist/types.js +31 -0
- package/dist/utils.js +172 -0
- package/dist/worker.js +123 -0
- package/lib/AssetGraph.js +53 -15
- package/lib/Atlaspack.js +140 -56
- package/lib/AtlaspackConfig.js +17 -6
- package/lib/AtlaspackConfig.schema.js +16 -5
- package/lib/BundleGraph.js +390 -43
- package/lib/CommittedAsset.js +8 -2
- package/lib/Dependency.js +9 -3
- package/lib/Environment.js +16 -10
- package/lib/EnvironmentManager.js +143 -0
- package/lib/IdentifierRegistry.js +2 -4
- package/lib/InternalConfig.js +3 -2
- package/lib/PackagerRunner.js +46 -82
- package/lib/ReporterRunner.js +8 -12
- package/lib/RequestTracker.js +191 -152
- package/lib/SymbolPropagation.js +52 -29
- package/lib/TargetDescriptor.schema.js +10 -1
- package/lib/Transformation.js +68 -19
- package/lib/UncommittedAsset.js +17 -24
- package/lib/Validation.js +20 -5
- package/lib/applyRuntimes.js +98 -7
- package/lib/assetUtils.js +16 -6
- package/lib/atlaspack-v3/AtlaspackV3.js +58 -15
- package/lib/atlaspack-v3/NapiWorkerPool.js +63 -2
- package/lib/atlaspack-v3/fs.js +4 -1
- package/lib/atlaspack-v3/index.js +28 -1
- package/lib/atlaspack-v3/jsCallable.js +0 -2
- package/lib/atlaspack-v3/worker/compat/asset-symbols.js +7 -4
- package/lib/atlaspack-v3/worker/compat/bitflags.js +31 -25
- package/lib/atlaspack-v3/worker/compat/dependency.js +4 -1
- package/lib/atlaspack-v3/worker/compat/environment.js +10 -7
- package/lib/atlaspack-v3/worker/compat/index.js +0 -11
- package/lib/atlaspack-v3/worker/compat/mutable-asset.js +16 -11
- package/lib/atlaspack-v3/worker/compat/plugin-config.js +14 -35
- package/lib/atlaspack-v3/worker/compat/plugin-options.js +16 -2
- package/lib/atlaspack-v3/worker/compat/plugin-tracer.js +3 -0
- package/lib/atlaspack-v3/worker/compat/target.js +2 -0
- package/lib/atlaspack-v3/worker/index.js +3 -0
- package/lib/atlaspack-v3/worker/side-effect-detector.js +214 -0
- package/lib/atlaspack-v3/worker/worker.js +231 -79
- package/lib/constants.js +0 -1
- package/lib/dumpGraphToGraphViz.js +72 -17
- package/lib/index.js +46 -3
- package/lib/loadAtlaspackPlugin.js +2 -3
- package/lib/loadDotEnv.js +5 -2
- package/lib/projectPath.js +6 -1
- package/lib/public/Asset.js +22 -12
- package/lib/public/Bundle.js +16 -18
- package/lib/public/BundleGraph.js +27 -25
- package/lib/public/BundleGroup.js +5 -6
- package/lib/public/Config.js +118 -18
- package/lib/public/Dependency.js +9 -7
- package/lib/public/Environment.js +13 -8
- package/lib/public/MutableBundleGraph.js +56 -15
- package/lib/public/PluginOptions.js +2 -2
- package/lib/public/Symbols.js +12 -12
- package/lib/public/Target.js +8 -7
- package/lib/registerCoreWithSerializer.js +7 -4
- package/lib/requests/AssetGraphRequest.js +61 -40
- package/lib/requests/AssetGraphRequestRust.js +314 -82
- package/lib/requests/AssetRequest.js +24 -7
- package/lib/requests/AtlaspackBuildRequest.js +53 -7
- package/lib/requests/AtlaspackConfigRequest.js +29 -19
- package/lib/requests/BundleGraphRequest.js +61 -130
- package/lib/requests/BundleGraphRequestRust.js +381 -0
- package/lib/requests/BundleGraphRequestUtils.js +280 -0
- package/lib/requests/ConfigRequest.js +55 -7
- package/lib/requests/DevDepRequest.js +32 -6
- package/lib/requests/EntryRequest.js +4 -3
- package/lib/requests/PackageRequest.js +56 -12
- package/lib/requests/PathRequest.js +26 -6
- package/lib/requests/TargetRequest.js +129 -60
- package/lib/requests/ValidationRequest.js +6 -2
- package/lib/requests/WriteBundleRequest.js +329 -20
- package/lib/requests/WriteBundlesRequest.js +64 -10
- package/lib/requests/asset-graph-diff.js +13 -8
- package/lib/requests/asset-graph-dot.js +2 -8
- package/lib/resolveOptions.js +37 -14
- package/lib/rustWorkerThreadDylibHack.js +0 -1
- package/lib/serializerCore.browser.js +1 -2
- package/lib/summarizeRequest.js +1 -1
- package/lib/types/AssetGraph.d.ts +55 -0
- package/lib/types/Atlaspack.d.ts +52 -0
- package/lib/types/AtlaspackConfig.d.ts +65 -0
- package/lib/types/AtlaspackConfig.schema.d.ts +53 -0
- package/lib/types/BundleGraph.d.ts +232 -0
- package/lib/types/CommittedAsset.d.ts +23 -0
- package/lib/types/Dependency.d.ts +44 -0
- package/lib/types/Environment.d.ts +11 -0
- package/lib/types/EnvironmentManager.d.ts +37 -0
- package/lib/types/IdentifierRegistry.d.ts +6 -0
- package/lib/types/InternalConfig.d.ts +23 -0
- package/lib/types/PackagerRunner.d.ts +85 -0
- package/lib/types/ReporterRunner.d.ts +25 -0
- package/lib/types/RequestTracker.d.ts +385 -0
- package/lib/types/SymbolPropagation.d.ts +11 -0
- package/lib/types/TargetDescriptor.schema.d.ts +5 -0
- package/lib/types/Transformation.d.ts +72 -0
- package/lib/types/UncommittedAsset.d.ts +61 -0
- package/lib/types/Validation.d.ts +37 -0
- package/lib/types/applyRuntimes.d.ts +25 -0
- package/lib/types/assetUtils.d.ts +42 -0
- package/lib/types/atlaspack-v3/AtlaspackV3.d.ts +35 -0
- package/lib/types/atlaspack-v3/NapiWorkerPool.d.ts +13 -0
- package/lib/types/atlaspack-v3/fs.d.ts +13 -0
- package/lib/types/atlaspack-v3/index.d.ts +6 -0
- package/lib/types/atlaspack-v3/jsCallable.d.ts +1 -0
- package/lib/types/atlaspack-v3/worker/compat/asset-symbols.d.ts +51 -0
- package/lib/types/atlaspack-v3/worker/compat/bitflags.d.ts +14 -0
- package/lib/types/atlaspack-v3/worker/compat/dependency.d.ts +25 -0
- package/lib/types/atlaspack-v3/worker/compat/environment.d.ts +27 -0
- package/{src/atlaspack-v3/worker/compat/index.js → lib/types/atlaspack-v3/worker/compat/index.d.ts} +0 -2
- package/lib/types/atlaspack-v3/worker/compat/mutable-asset.d.ts +49 -0
- package/lib/types/atlaspack-v3/worker/compat/plugin-config.d.ts +29 -0
- package/lib/types/atlaspack-v3/worker/compat/plugin-options.d.ts +23 -0
- package/lib/types/atlaspack-v3/worker/compat/plugin-tracer.d.ts +5 -0
- package/lib/types/atlaspack-v3/worker/compat/target.d.ts +11 -0
- package/lib/types/atlaspack-v3/worker/side-effect-detector.d.ts +76 -0
- package/lib/types/atlaspack-v3/worker/worker.d.ts +81 -0
- package/lib/types/constants.d.ts +13 -0
- package/lib/types/dumpGraphToGraphViz.d.ts +10 -0
- package/lib/types/index.d.ts +8 -0
- package/lib/types/loadAtlaspackPlugin.d.ts +8 -0
- package/lib/types/loadDotEnv.d.ts +3 -0
- package/lib/types/projectPath.d.ts +19 -0
- package/lib/types/public/Asset.d.ts +74 -0
- package/lib/types/public/Bundle.d.ts +45 -0
- package/lib/types/public/BundleGraph.d.ts +72 -0
- package/lib/types/public/BundleGroup.d.ts +12 -0
- package/lib/types/public/Config.d.ts +75 -0
- package/lib/types/public/Dependency.d.ts +32 -0
- package/lib/types/public/Environment.d.ts +34 -0
- package/lib/types/public/MutableBundleGraph.d.ts +26 -0
- package/lib/types/public/PluginOptions.d.ts +25 -0
- package/lib/types/public/Symbols.d.ts +81 -0
- package/lib/types/public/Target.d.ts +16 -0
- package/lib/types/registerCoreWithSerializer.d.ts +2 -0
- package/lib/types/requests/AssetGraphRequest.d.ts +76 -0
- package/lib/types/requests/AssetGraphRequestRust.d.ts +21 -0
- package/lib/types/requests/AssetRequest.d.ts +16 -0
- package/lib/types/requests/AtlaspackBuildRequest.d.ts +33 -0
- package/lib/types/requests/AtlaspackConfigRequest.d.ts +45 -0
- package/lib/types/requests/BundleGraphRequest.d.ts +28 -0
- package/lib/types/requests/BundleGraphRequestRust.d.ts +34 -0
- package/lib/types/requests/BundleGraphRequestUtils.d.ts +38 -0
- package/lib/types/requests/ConfigRequest.d.ts +67 -0
- package/lib/types/requests/DevDepRequest.d.ts +30 -0
- package/lib/types/requests/EntryRequest.d.ts +36 -0
- package/lib/types/requests/PackageRequest.d.ts +27 -0
- package/lib/types/requests/PathRequest.d.ts +48 -0
- package/lib/types/requests/TargetRequest.d.ts +48 -0
- package/lib/types/requests/ValidationRequest.d.ts +20 -0
- package/lib/types/requests/WriteBundleRequest.d.ts +80 -0
- package/lib/types/requests/WriteBundlesRequest.d.ts +32 -0
- package/lib/types/requests/asset-graph-diff.d.ts +1 -0
- package/lib/types/requests/asset-graph-dot.d.ts +9 -0
- package/lib/types/resolveOptions.d.ts +3 -0
- package/lib/types/rustWorkerThreadDylibHack.d.ts +9 -0
- package/lib/types/serializerCore.browser.d.ts +3 -0
- package/lib/types/summarizeRequest.d.ts +10 -0
- package/lib/types/types.d.ts +496 -0
- package/lib/types/utils.d.ts +23 -0
- package/lib/types/worker.d.ts +44 -0
- package/lib/types.js +8 -1
- package/lib/utils.js +18 -3
- package/lib/worker.js +32 -15
- package/package.json +26 -36
- package/src/{AssetGraph.js → AssetGraph.ts} +87 -51
- package/src/{Atlaspack.js → Atlaspack.ts} +181 -72
- package/src/{AtlaspackConfig.schema.js → AtlaspackConfig.schema.ts} +25 -19
- package/src/{AtlaspackConfig.js → AtlaspackConfig.ts} +78 -54
- package/src/{BundleGraph.js → BundleGraph.ts} +575 -145
- package/src/{CommittedAsset.js → CommittedAsset.ts} +15 -13
- package/src/{Dependency.js → Dependency.ts} +59 -42
- package/src/{Environment.js → Environment.ts} +24 -15
- package/src/EnvironmentManager.ts +154 -0
- package/src/{IdentifierRegistry.js → IdentifierRegistry.ts} +1 -4
- package/src/{InternalConfig.js → InternalConfig.ts} +22 -23
- package/src/{PackagerRunner.js → PackagerRunner.ts} +114 -159
- package/src/{ReporterRunner.js → ReporterRunner.ts} +13 -18
- package/src/{RequestTracker.js → RequestTracker.ts} +444 -355
- package/src/{SymbolPropagation.js → SymbolPropagation.ts} +178 -61
- package/src/{TargetDescriptor.schema.js → TargetDescriptor.schema.ts} +10 -1
- package/src/{Transformation.js → Transformation.ts} +110 -65
- package/src/{UncommittedAsset.js → UncommittedAsset.ts} +45 -49
- package/src/{Validation.js → Validation.ts} +32 -17
- package/src/{applyRuntimes.js → applyRuntimes.ts} +135 -26
- package/src/{assetUtils.js → assetUtils.ts} +49 -36
- package/src/atlaspack-v3/AtlaspackV3.ts +183 -0
- package/src/atlaspack-v3/NapiWorkerPool.ts +129 -0
- package/src/atlaspack-v3/{fs.js → fs.ts} +8 -4
- package/src/atlaspack-v3/{index.js → index.ts} +3 -4
- package/src/atlaspack-v3/jsCallable.ts +14 -0
- package/src/atlaspack-v3/worker/compat/{asset-symbols.js → asset-symbols.ts} +40 -30
- package/src/atlaspack-v3/worker/compat/bitflags.ts +102 -0
- package/src/atlaspack-v3/worker/compat/{dependency.js → dependency.ts} +13 -13
- package/src/atlaspack-v3/worker/compat/{environment.js → environment.ts} +13 -9
- package/src/atlaspack-v3/worker/compat/index.ts +8 -0
- package/src/atlaspack-v3/worker/compat/{mutable-asset.js → mutable-asset.ts} +21 -20
- package/src/atlaspack-v3/worker/compat/{plugin-config.js → plugin-config.ts} +25 -56
- package/src/atlaspack-v3/worker/compat/{plugin-options.js → plugin-options.ts} +19 -5
- package/src/atlaspack-v3/worker/compat/{plugin-tracer.js → plugin-tracer.ts} +2 -2
- package/src/atlaspack-v3/worker/compat/{target.js → target.ts} +3 -4
- package/src/atlaspack-v3/worker/index.js +2 -1
- package/src/atlaspack-v3/worker/side-effect-detector.ts +298 -0
- package/src/atlaspack-v3/worker/worker.ts +548 -0
- package/src/{constants.js → constants.ts} +0 -3
- package/src/{dumpGraphToGraphViz.js → dumpGraphToGraphViz.ts} +73 -28
- package/src/index.ts +18 -0
- package/src/{loadAtlaspackPlugin.js → loadAtlaspackPlugin.ts} +8 -9
- package/src/{loadDotEnv.js → loadDotEnv.ts} +2 -2
- package/src/{projectPath.js → projectPath.ts} +20 -9
- package/src/public/{Asset.js → Asset.ts} +41 -28
- package/src/public/{Bundle.js → Bundle.ts} +28 -29
- package/src/public/{BundleGraph.js → BundleGraph.ts} +103 -68
- package/src/public/{BundleGroup.js → BundleGroup.ts} +7 -10
- package/src/public/{Config.js → Config.ts} +171 -33
- package/src/public/{Dependency.js → Dependency.ts} +20 -17
- package/src/public/{Environment.js → Environment.ts} +28 -17
- package/src/public/{MutableBundleGraph.js → MutableBundleGraph.ts} +55 -24
- package/src/public/{PluginOptions.js → PluginOptions.ts} +6 -6
- package/src/public/{Symbols.js → Symbols.ts} +75 -36
- package/src/public/{Target.js → Target.ts} +10 -8
- package/src/{registerCoreWithSerializer.js → registerCoreWithSerializer.ts} +9 -7
- package/src/requests/{AssetGraphRequest.js → AssetGraphRequest.ts} +117 -90
- package/src/requests/AssetGraphRequestRust.ts +557 -0
- package/src/requests/{AssetRequest.js → AssetRequest.ts} +24 -18
- package/src/requests/AtlaspackBuildRequest.ts +168 -0
- package/src/requests/{AtlaspackConfigRequest.js → AtlaspackConfigRequest.ts} +72 -58
- package/src/requests/{BundleGraphRequest.js → BundleGraphRequest.ts} +119 -199
- package/src/requests/BundleGraphRequestRust.ts +470 -0
- package/src/requests/BundleGraphRequestUtils.ts +323 -0
- package/src/requests/{ConfigRequest.js → ConfigRequest.ts} +110 -50
- package/src/requests/{DevDepRequest.js → DevDepRequest.ts} +60 -35
- package/src/requests/{EntryRequest.js → EntryRequest.ts} +36 -31
- package/src/requests/{PackageRequest.js → PackageRequest.ts} +52 -25
- package/src/requests/{PathRequest.js → PathRequest.ts} +47 -37
- package/src/requests/{TargetRequest.js → TargetRequest.ts} +265 -179
- package/src/requests/{ValidationRequest.js → ValidationRequest.ts} +18 -17
- package/src/requests/WriteBundleRequest.ts +734 -0
- package/src/requests/{WriteBundlesRequest.js → WriteBundlesRequest.ts} +134 -50
- package/src/requests/{asset-graph-diff.js → asset-graph-diff.ts} +25 -21
- package/src/requests/{asset-graph-dot.js → asset-graph-dot.ts} +8 -12
- package/src/{resolveOptions.js → resolveOptions.ts} +57 -27
- package/src/{rustWorkerThreadDylibHack.js → rustWorkerThreadDylibHack.ts} +1 -4
- package/src/{serializerCore.browser.js → serializerCore.browser.ts} +2 -3
- package/src/{summarizeRequest.js → summarizeRequest.ts} +17 -5
- package/src/types.ts +651 -0
- package/src/{utils.js → utils.ts} +52 -21
- package/src/{worker.js → worker.ts} +50 -42
- package/test/{AssetGraph.test.js → AssetGraph.test.ts} +5 -8
- package/test/{Atlaspack.test.js → Atlaspack.test.ts} +5 -10
- package/test/{AtlaspackConfig.test.js → AtlaspackConfig.test.ts} +0 -5
- package/test/{AtlaspackConfigRequest.test.js → AtlaspackConfigRequest.test.ts} +76 -16
- package/test/{BundleGraph.test.js → BundleGraph.test.ts} +8 -13
- package/test/{Dependency.test.js → Dependency.test.ts} +2 -3
- package/test/{EntryRequest.test.js → EntryRequest.test.ts} +1 -6
- package/test/Environment.test.ts +153 -0
- package/test/EnvironmentManager.test.ts +188 -0
- package/test/{IdentifierRegistry.test.js → IdentifierRegistry.test.ts} +2 -4
- package/test/{InternalAsset.test.js → InternalAsset.test.ts} +2 -7
- package/test/PackagerRunner.test.ts +0 -0
- package/test/{PublicAsset.test.js → PublicAsset.test.ts} +2 -7
- package/test/{PublicBundle.test.js → PublicBundle.test.ts} +1 -2
- package/test/{PublicDependency.test.js → PublicDependency.test.ts} +0 -2
- package/test/PublicEnvironment.test.ts +49 -0
- package/test/{PublicMutableBundleGraph.test.js → PublicMutableBundleGraph.test.ts} +6 -11
- package/test/{RequestTracker.test.js → RequestTracker.test.ts} +136 -58
- package/test/{SymbolPropagation.test.js → SymbolPropagation.test.ts} +124 -74
- package/test/{TargetRequest.test.js → TargetRequest.test.ts} +91 -92
- package/test/fixtures/config-with-reporters/.parcelrc +7 -0
- package/test/fixtures/custom-targets/package.json +6 -0
- package/test/public/Config.test.ts +104 -0
- package/test/requests/AssetGraphRequestRust.test.ts +443 -0
- package/test/requests/{ConfigRequest.test.js → ConfigRequest.test.ts} +202 -13
- package/test/requests/{DevDepRequest.test.js → DevDepRequest.test.ts} +0 -2
- package/test/requests/WriteBundleRequest.test.ts +602 -0
- package/test/{test-utils.js → test-utils.ts} +3 -4
- package/test/{utils.test.js → utils.test.ts} +1 -3
- package/tsconfig.json +60 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/index.d.ts +0 -30
- package/lib/atlaspack-v3/worker/compat/plugin-logger.js +0 -29
- package/src/atlaspack-v3/AtlaspackV3.js +0 -87
- package/src/atlaspack-v3/NapiWorkerPool.js +0 -53
- package/src/atlaspack-v3/jsCallable.js +0 -18
- package/src/atlaspack-v3/worker/compat/bitflags.js +0 -100
- package/src/atlaspack-v3/worker/compat/plugin-logger.js +0 -47
- package/src/atlaspack-v3/worker/worker.js +0 -369
- package/src/index.js +0 -13
- package/src/requests/AssetGraphRequestRust.js +0 -263
- package/src/requests/AtlaspackBuildRequest.js +0 -111
- package/src/requests/WriteBundleRequest.js +0 -369
- package/src/types.js +0 -600
- package/test/Environment.test.js +0 -119
- package/test/PackagerRunner.test.js +0 -27
- package/test/PublicEnvironment.test.js +0 -27
- package/test/requests/AssetGraphRequestRust.test.js +0 -411
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
import type {ContentKey} from '@atlaspack/graph';
|
|
2
|
+
import type {Async} from '@atlaspack/types';
|
|
3
|
+
import type {SharedReference} from '@atlaspack/workers';
|
|
4
|
+
|
|
5
|
+
import type {StaticRunOpts} from '../RequestTracker';
|
|
6
|
+
import type {Asset, AssetGroup, PackagedBundleInfo} from '../types';
|
|
7
|
+
import type BundleGraph from '../BundleGraph';
|
|
8
|
+
|
|
9
|
+
import createBundleGraphRequest, {
|
|
10
|
+
BundleGraphResult,
|
|
11
|
+
} from './BundleGraphRequest';
|
|
12
|
+
import createBundleGraphRequestRust from './BundleGraphRequestRust';
|
|
13
|
+
import createWriteBundlesRequest from './WriteBundlesRequest';
|
|
14
|
+
import {assertSignalNotAborted} from '../utils';
|
|
15
|
+
import dumpGraphToGraphViz from '../dumpGraphToGraphViz';
|
|
16
|
+
import {bundleGraphEdgeTypes} from '../BundleGraph';
|
|
17
|
+
import {report} from '../ReporterRunner';
|
|
18
|
+
import IBundleGraph from '../public/BundleGraph';
|
|
19
|
+
import {NamedBundle} from '../public/Bundle';
|
|
20
|
+
import {assetFromValue} from '../public/Asset';
|
|
21
|
+
|
|
22
|
+
import {tracer} from '@atlaspack/profiler';
|
|
23
|
+
import {requestTypes} from '../RequestTracker';
|
|
24
|
+
import {getFeatureFlag} from '@atlaspack/feature-flags';
|
|
25
|
+
import {fromEnvironmentId} from '../EnvironmentManager';
|
|
26
|
+
import {tracer as atlaspackTracer} from '@atlaspack/logger';
|
|
27
|
+
|
|
28
|
+
type AtlaspackBuildRequestInput = {
|
|
29
|
+
optionsRef: SharedReference;
|
|
30
|
+
requestedAssetIds: Set<string>;
|
|
31
|
+
signal?: AbortSignal;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
export type AtlaspackBuildRequestResult = {
|
|
35
|
+
bundleGraph: BundleGraph;
|
|
36
|
+
bundleInfo: Map<string, PackagedBundleInfo>;
|
|
37
|
+
changedAssets: Map<string, Asset>;
|
|
38
|
+
assetRequests: Array<AssetGroup>;
|
|
39
|
+
scopeHoistingStats?: {
|
|
40
|
+
totalAssets: number;
|
|
41
|
+
wrappedAssets: number;
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
type RunInput<TResult> = {
|
|
46
|
+
input: AtlaspackBuildRequestInput;
|
|
47
|
+
} & StaticRunOpts<TResult>;
|
|
48
|
+
|
|
49
|
+
export type AtlaspackBuildRequest = {
|
|
50
|
+
id: ContentKey;
|
|
51
|
+
readonly type: typeof requestTypes.atlaspack_build_request;
|
|
52
|
+
run: (
|
|
53
|
+
arg1: RunInput<AtlaspackBuildRequestResult>,
|
|
54
|
+
) => Async<AtlaspackBuildRequestResult>;
|
|
55
|
+
input: AtlaspackBuildRequestInput;
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
export default function createAtlaspackBuildRequest(
|
|
59
|
+
input: AtlaspackBuildRequestInput,
|
|
60
|
+
): AtlaspackBuildRequest {
|
|
61
|
+
return {
|
|
62
|
+
type: requestTypes.atlaspack_build_request,
|
|
63
|
+
id: 'atlaspack_build_request',
|
|
64
|
+
run,
|
|
65
|
+
input,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
async function run({
|
|
70
|
+
input,
|
|
71
|
+
api,
|
|
72
|
+
options,
|
|
73
|
+
rustAtlaspack,
|
|
74
|
+
}: RunInput<AtlaspackBuildRequestResult>) {
|
|
75
|
+
let {optionsRef, requestedAssetIds, signal} = input;
|
|
76
|
+
|
|
77
|
+
let bundleGraphRequest =
|
|
78
|
+
getFeatureFlag('nativeBundling') && rustAtlaspack
|
|
79
|
+
? createBundleGraphRequestRust({
|
|
80
|
+
optionsRef,
|
|
81
|
+
requestedAssetIds,
|
|
82
|
+
signal,
|
|
83
|
+
})
|
|
84
|
+
: createBundleGraphRequest({
|
|
85
|
+
optionsRef,
|
|
86
|
+
requestedAssetIds,
|
|
87
|
+
signal,
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
let {
|
|
91
|
+
bundleGraph,
|
|
92
|
+
changedAssets,
|
|
93
|
+
assetRequests,
|
|
94
|
+
didIncrementallyBundle,
|
|
95
|
+
}: BundleGraphResult = await api.runRequest(bundleGraphRequest, {
|
|
96
|
+
force:
|
|
97
|
+
Boolean(rustAtlaspack) ||
|
|
98
|
+
(options.shouldBuildLazily && requestedAssetIds.size > 0),
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
if (
|
|
102
|
+
getFeatureFlag('nativePackager') &&
|
|
103
|
+
getFeatureFlag('nativePackagerSSRDev') &&
|
|
104
|
+
rustAtlaspack
|
|
105
|
+
) {
|
|
106
|
+
let hasSupportedTarget = false;
|
|
107
|
+
bundleGraph.traverseBundles((bundle, ctx, actions) => {
|
|
108
|
+
if (
|
|
109
|
+
fromEnvironmentId(bundle.env).context === 'tesseract' &&
|
|
110
|
+
bundle.type === 'js'
|
|
111
|
+
) {
|
|
112
|
+
hasSupportedTarget = true;
|
|
113
|
+
actions.stop();
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
if (hasSupportedTarget) {
|
|
117
|
+
if (didIncrementallyBundle) {
|
|
118
|
+
const changedAssetIds = Array.from(changedAssets.keys());
|
|
119
|
+
await rustAtlaspack.updateBundleGraph(bundleGraph, changedAssetIds);
|
|
120
|
+
} else {
|
|
121
|
+
await rustAtlaspack.loadBundleGraph(bundleGraph);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
// @ts-expect-error TS2345
|
|
127
|
+
dumpGraphToGraphViz(bundleGraph._graph, 'BundleGraph', bundleGraphEdgeTypes);
|
|
128
|
+
|
|
129
|
+
await report({
|
|
130
|
+
type: 'buildProgress',
|
|
131
|
+
phase: 'bundled',
|
|
132
|
+
bundleGraph: new IBundleGraph(
|
|
133
|
+
bundleGraph,
|
|
134
|
+
// @ts-expect-error TS2304
|
|
135
|
+
(bundle: Bundle, bundleGraph: BundleGraph, options: AtlaspackOptions) =>
|
|
136
|
+
NamedBundle.get(bundle, bundleGraph, options),
|
|
137
|
+
options,
|
|
138
|
+
),
|
|
139
|
+
changedAssets: new Map(
|
|
140
|
+
Array.from(changedAssets).map(([id, asset]: [any, any]) => [
|
|
141
|
+
id,
|
|
142
|
+
assetFromValue(asset, options),
|
|
143
|
+
]),
|
|
144
|
+
),
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
let packagingMeasurement = tracer.createMeasurement('packaging');
|
|
148
|
+
const span = atlaspackTracer.enter('writeBundles');
|
|
149
|
+
|
|
150
|
+
let writeBundlesRequest = createWriteBundlesRequest({
|
|
151
|
+
bundleGraph,
|
|
152
|
+
optionsRef,
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
let {bundleInfo, scopeHoistingStats} =
|
|
156
|
+
await api.runRequest(writeBundlesRequest);
|
|
157
|
+
packagingMeasurement && packagingMeasurement.end();
|
|
158
|
+
atlaspackTracer.exit(span);
|
|
159
|
+
assertSignalNotAborted(signal);
|
|
160
|
+
|
|
161
|
+
return {
|
|
162
|
+
bundleGraph,
|
|
163
|
+
bundleInfo,
|
|
164
|
+
changedAssets,
|
|
165
|
+
assetRequests,
|
|
166
|
+
scopeHoistingStats,
|
|
167
|
+
};
|
|
168
|
+
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
// @flow strict-local
|
|
2
1
|
import type {
|
|
3
2
|
Async,
|
|
4
3
|
FilePath,
|
|
@@ -13,6 +12,7 @@ import type {
|
|
|
13
12
|
PureAtlaspackConfigPipeline,
|
|
14
13
|
AtlaspackOptions,
|
|
15
14
|
ProcessedAtlaspackConfig,
|
|
15
|
+
AtlaspackPluginNode,
|
|
16
16
|
} from '../types';
|
|
17
17
|
|
|
18
18
|
import {createBuildCache} from '@atlaspack/build-cache';
|
|
@@ -40,33 +40,33 @@ import {toProjectPath} from '../projectPath';
|
|
|
40
40
|
import {requestTypes} from '../RequestTracker';
|
|
41
41
|
import {optionsProxy} from '../utils';
|
|
42
42
|
|
|
43
|
-
|
|
43
|
+
// @ts-expect-error TS2344
|
|
44
|
+
type ConfigMap<K, V> = Partial<Record<K, V>>;
|
|
44
45
|
|
|
45
|
-
export type ConfigAndCachePath = {
|
|
46
|
-
config: ProcessedAtlaspackConfig
|
|
47
|
-
cachePath: string
|
|
48
|
-
|
|
46
|
+
export type ConfigAndCachePath = {
|
|
47
|
+
config: ProcessedAtlaspackConfig;
|
|
48
|
+
cachePath: string;
|
|
49
|
+
};
|
|
49
50
|
|
|
50
|
-
type RunOpts<TResult> = {
|
|
51
|
-
input: null
|
|
52
|
-
|
|
53
|
-
|};
|
|
51
|
+
type RunOpts<TResult> = {
|
|
52
|
+
input: null;
|
|
53
|
+
} & StaticRunOpts<TResult>;
|
|
54
54
|
|
|
55
|
-
export type AtlaspackConfigRequest = {
|
|
56
|
-
id: string
|
|
57
|
-
type: typeof requestTypes.atlaspack_config_request
|
|
58
|
-
input: null
|
|
55
|
+
export type AtlaspackConfigRequest = {
|
|
56
|
+
id: string;
|
|
57
|
+
type: typeof requestTypes.atlaspack_config_request;
|
|
58
|
+
input: null;
|
|
59
59
|
run: (
|
|
60
|
-
RunOpts<AtlaspackConfigRequestResult>,
|
|
61
|
-
) => Async<AtlaspackConfigRequestResult
|
|
62
|
-
|
|
60
|
+
arg1: RunOpts<AtlaspackConfigRequestResult>,
|
|
61
|
+
) => Async<AtlaspackConfigRequestResult>;
|
|
62
|
+
};
|
|
63
63
|
|
|
64
64
|
export type AtlaspackConfigRequestResult = ConfigAndCachePath;
|
|
65
65
|
|
|
66
|
-
type AtlaspackConfigChain = {
|
|
67
|
-
config: ProcessedAtlaspackConfig
|
|
68
|
-
extendedFiles: Array<FilePath
|
|
69
|
-
|
|
66
|
+
type AtlaspackConfigChain = {
|
|
67
|
+
config: ProcessedAtlaspackConfig;
|
|
68
|
+
extendedFiles: Array<FilePath>;
|
|
69
|
+
};
|
|
70
70
|
|
|
71
71
|
const type = 'atlaspack_config_request';
|
|
72
72
|
|
|
@@ -79,10 +79,9 @@ export default function createAtlaspackConfigRequest(): AtlaspackConfigRequest {
|
|
|
79
79
|
config,
|
|
80
80
|
extendedFiles,
|
|
81
81
|
usedDefault,
|
|
82
|
-
}: {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|} = await loadAtlaspackConfig(
|
|
82
|
+
}: AtlaspackConfigChain & {
|
|
83
|
+
usedDefault: boolean;
|
|
84
|
+
} = await loadAtlaspackConfig(
|
|
86
85
|
optionsProxy(options, api.invalidateOnOptionChange),
|
|
87
86
|
);
|
|
88
87
|
|
|
@@ -122,18 +121,22 @@ export function getCachedAtlaspackConfig(
|
|
|
122
121
|
let {config: processedConfig, cachePath} = result;
|
|
123
122
|
let config = atlaspackConfigCache.get(cachePath);
|
|
124
123
|
if (config) {
|
|
124
|
+
// @ts-expect-error TS2740
|
|
125
125
|
return config;
|
|
126
126
|
}
|
|
127
127
|
|
|
128
128
|
config = new AtlaspackConfig(processedConfig, options);
|
|
129
129
|
|
|
130
130
|
atlaspackConfigCache.set(cachePath, config);
|
|
131
|
+
// @ts-expect-error TS2322
|
|
131
132
|
return config;
|
|
132
133
|
}
|
|
133
134
|
|
|
134
|
-
export async function loadAtlaspackConfig(
|
|
135
|
-
|
|
136
|
-
|
|
135
|
+
export async function loadAtlaspackConfig(options: AtlaspackOptions): Promise<
|
|
136
|
+
AtlaspackConfigChain & {
|
|
137
|
+
usedDefault: boolean;
|
|
138
|
+
}
|
|
139
|
+
> {
|
|
137
140
|
let atlaspackConfig = await resolveAtlaspackConfig(options);
|
|
138
141
|
|
|
139
142
|
if (!atlaspackConfig) {
|
|
@@ -145,7 +148,13 @@ export async function loadAtlaspackConfig(
|
|
|
145
148
|
|
|
146
149
|
export async function resolveAtlaspackConfig(
|
|
147
150
|
options: AtlaspackOptions,
|
|
148
|
-
): Promise
|
|
151
|
+
): Promise<
|
|
152
|
+
| (AtlaspackConfigChain & {
|
|
153
|
+
usedDefault: boolean;
|
|
154
|
+
})
|
|
155
|
+
| null
|
|
156
|
+
| undefined
|
|
157
|
+
> {
|
|
149
158
|
let resolveFrom = getResolveFrom(options.inputFS, options.projectRoot);
|
|
150
159
|
let configPath =
|
|
151
160
|
options.config != null
|
|
@@ -173,7 +182,7 @@ export async function resolveAtlaspackConfig(
|
|
|
173
182
|
let contents;
|
|
174
183
|
try {
|
|
175
184
|
contents = await options.inputFS.readFile(configPath, 'utf8');
|
|
176
|
-
} catch (e) {
|
|
185
|
+
} catch (e: any) {
|
|
177
186
|
throw new ThrowableDiagnostic({
|
|
178
187
|
diagnostic: {
|
|
179
188
|
message: md`Could not find parcel config at ${path.relative(
|
|
@@ -189,13 +198,19 @@ export async function resolveAtlaspackConfig(
|
|
|
189
198
|
await parseAndProcessConfig(configPath, contents, options);
|
|
190
199
|
|
|
191
200
|
if (options.additionalReporters.length > 0) {
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
201
|
+
const reporterMap = new Map<PackageName, AtlaspackPluginNode>();
|
|
202
|
+
|
|
203
|
+
options.additionalReporters.forEach(({packageName, resolveFrom}) => {
|
|
204
|
+
reporterMap.set(packageName, {packageName, resolveFrom});
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
config.reporters?.forEach((reporter) => {
|
|
208
|
+
if (!reporterMap.has(reporter.packageName)) {
|
|
209
|
+
reporterMap.set(reporter.packageName, reporter);
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
config.reporters = Array.from(reporterMap.values());
|
|
199
214
|
}
|
|
200
215
|
|
|
201
216
|
return {config, extendedFiles, usedDefault};
|
|
@@ -217,7 +232,7 @@ export async function parseAndProcessConfig(
|
|
|
217
232
|
let config: RawAtlaspackConfig;
|
|
218
233
|
try {
|
|
219
234
|
config = parse(contents);
|
|
220
|
-
} catch (e) {
|
|
235
|
+
} catch (e: any) {
|
|
221
236
|
let pos = {
|
|
222
237
|
line: e.lineNumber,
|
|
223
238
|
column: e.columnNumber,
|
|
@@ -249,13 +264,12 @@ export async function parseAndProcessConfig(
|
|
|
249
264
|
|
|
250
265
|
function processPipeline(
|
|
251
266
|
options: AtlaspackOptions,
|
|
252
|
-
pipeline:
|
|
267
|
+
pipeline: Array<PackageName> | null | undefined,
|
|
253
268
|
keyPath: string,
|
|
254
269
|
filePath: FilePath,
|
|
255
270
|
) {
|
|
256
271
|
if (pipeline) {
|
|
257
272
|
return pipeline.map((pkg, i) => {
|
|
258
|
-
// $FlowFixMe
|
|
259
273
|
if (pkg === '...') return pkg;
|
|
260
274
|
|
|
261
275
|
return {
|
|
@@ -278,16 +292,13 @@ const RESERVED_PIPELINES = new Set([
|
|
|
278
292
|
]);
|
|
279
293
|
|
|
280
294
|
async function processMap(
|
|
281
|
-
|
|
282
|
-
map: ?ConfigMap<any, any>,
|
|
295
|
+
map: ConfigMap<any, any> | null | undefined,
|
|
283
296
|
keyPath: string,
|
|
284
297
|
filePath: FilePath,
|
|
285
298
|
options: AtlaspackOptions,
|
|
286
|
-
// $FlowFixMe
|
|
287
299
|
): Promise<ConfigMap<any, any> | typeof undefined> {
|
|
288
300
|
if (!map) return undefined;
|
|
289
301
|
|
|
290
|
-
// $FlowFixMe
|
|
291
302
|
let res: ConfigMap<any, any> = {};
|
|
292
303
|
for (let k in map) {
|
|
293
304
|
let i = k.indexOf(':');
|
|
@@ -346,6 +357,7 @@ export async function processConfig(
|
|
|
346
357
|
: {
|
|
347
358
|
/*::...null*/
|
|
348
359
|
}),
|
|
360
|
+
// @ts-expect-error TS2322
|
|
349
361
|
resolvers: processPipeline(
|
|
350
362
|
options,
|
|
351
363
|
configFile.resolvers,
|
|
@@ -369,12 +381,14 @@ export async function processConfig(
|
|
|
369
381
|
keyPath: '/bundler',
|
|
370
382
|
}
|
|
371
383
|
: undefined,
|
|
384
|
+
// @ts-expect-error TS2322
|
|
372
385
|
namers: processPipeline(
|
|
373
386
|
options,
|
|
374
387
|
configFile.namers,
|
|
375
388
|
'/namers',
|
|
376
389
|
configFile.filePath,
|
|
377
390
|
),
|
|
391
|
+
// @ts-expect-error TS2322
|
|
378
392
|
runtimes: processPipeline(
|
|
379
393
|
options,
|
|
380
394
|
configFile.runtimes,
|
|
@@ -399,6 +413,7 @@ export async function processConfig(
|
|
|
399
413
|
configFile.filePath,
|
|
400
414
|
options,
|
|
401
415
|
),
|
|
416
|
+
// @ts-expect-error TS2322
|
|
402
417
|
reporters: processPipeline(
|
|
403
418
|
options,
|
|
404
419
|
configFile.reporters,
|
|
@@ -437,7 +452,7 @@ export async function processConfigChain(
|
|
|
437
452
|
let exts = Array.isArray(configFile.extends)
|
|
438
453
|
? configFile.extends
|
|
439
454
|
: [configFile.extends];
|
|
440
|
-
let errors = [];
|
|
455
|
+
let errors: Array<any> = [];
|
|
441
456
|
if (exts.length !== 0) {
|
|
442
457
|
let extStartConfig;
|
|
443
458
|
let i = 0;
|
|
@@ -454,7 +469,7 @@ export async function processConfigChain(
|
|
|
454
469
|
extStartConfig = extStartConfig
|
|
455
470
|
? mergeConfigs(extStartConfig, nextConfig)
|
|
456
471
|
: nextConfig;
|
|
457
|
-
} catch (err) {
|
|
472
|
+
} catch (err: any) {
|
|
458
473
|
errors.push(err);
|
|
459
474
|
}
|
|
460
475
|
|
|
@@ -491,7 +506,7 @@ export async function resolveExtends(
|
|
|
491
506
|
try {
|
|
492
507
|
let {resolved} = await options.packageManager.resolve(ext, configPath);
|
|
493
508
|
return options.inputFS.realpath(resolved);
|
|
494
|
-
} catch (err) {
|
|
509
|
+
} catch (err: any) {
|
|
495
510
|
let parentContents = await options.inputFS.readFile(configPath, 'utf8');
|
|
496
511
|
let alternatives = await findAlternativeNodeModules(
|
|
497
512
|
options.inputFS,
|
|
@@ -539,7 +554,7 @@ async function processExtendedConfig(
|
|
|
539
554
|
resolvedExtendedConfigPath,
|
|
540
555
|
'utf8',
|
|
541
556
|
);
|
|
542
|
-
} catch (e) {
|
|
557
|
+
} catch (e: any) {
|
|
543
558
|
let parentContents = await options.inputFS.readFile(configPath, 'utf8');
|
|
544
559
|
let alternatives = await findAlternativeFiles(
|
|
545
560
|
options.inputFS,
|
|
@@ -580,7 +595,7 @@ export function validateConfigFile(
|
|
|
580
595
|
) {
|
|
581
596
|
try {
|
|
582
597
|
validateNotEmpty(config, relativePath);
|
|
583
|
-
} catch (e) {
|
|
598
|
+
} catch (e: any) {
|
|
584
599
|
throw new ThrowableDiagnostic({
|
|
585
600
|
diagnostic: {
|
|
586
601
|
message: e.message,
|
|
@@ -650,8 +665,8 @@ function assertPurePipeline(
|
|
|
650
665
|
}
|
|
651
666
|
|
|
652
667
|
export function mergePipelines(
|
|
653
|
-
base
|
|
654
|
-
ext
|
|
668
|
+
base?: ExtendableAtlaspackConfigPipeline | null,
|
|
669
|
+
ext?: ExtendableAtlaspackConfigPipeline | null,
|
|
655
670
|
): ExtendableAtlaspackConfigPipeline {
|
|
656
671
|
if (ext == null) {
|
|
657
672
|
return base ?? [];
|
|
@@ -676,9 +691,9 @@ export function mergePipelines(
|
|
|
676
691
|
}
|
|
677
692
|
}
|
|
678
693
|
|
|
679
|
-
export function mergeMaps<K
|
|
680
|
-
base
|
|
681
|
-
ext
|
|
694
|
+
export function mergeMaps<K extends string, V>(
|
|
695
|
+
base?: ConfigMap<K, V> | null,
|
|
696
|
+
ext?: ConfigMap<K, V> | null,
|
|
682
697
|
merger?: (a: V, b: V) => V,
|
|
683
698
|
): ConfigMap<K, V> {
|
|
684
699
|
if (!ext || Object.keys(ext).length === 0) {
|
|
@@ -692,16 +707,15 @@ export function mergeMaps<K: string, V>(
|
|
|
692
707
|
let res: ConfigMap<K, V> = {};
|
|
693
708
|
// Add the extension options first so they have higher precedence in the output glob map
|
|
694
709
|
for (let k in ext) {
|
|
695
|
-
|
|
696
|
-
let key: K = (k: any);
|
|
710
|
+
let key: K = k as any;
|
|
697
711
|
res[key] =
|
|
712
|
+
// @ts-expect-error TS2345
|
|
698
713
|
merger && base[key] != null ? merger(base[key], ext[key]) : ext[key];
|
|
699
714
|
}
|
|
700
715
|
|
|
701
716
|
// Add base options that aren't defined in the extension
|
|
702
717
|
for (let k in base) {
|
|
703
|
-
|
|
704
|
-
let key: K = (k: any);
|
|
718
|
+
let key: K = k as any;
|
|
705
719
|
if (res[key] == null) {
|
|
706
720
|
res[key] = base[key];
|
|
707
721
|
}
|