@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
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
atlaspackNapiCreate,
|
|
5
|
-
atlaspackNapiBuildAssetGraph,
|
|
6
|
-
atlaspackNapiRespondToFsEvents,
|
|
7
|
-
type AtlaspackNapi,
|
|
8
|
-
type Lmdb,
|
|
9
|
-
type AtlaspackNapiOptions,
|
|
10
|
-
} from '@atlaspack/rust';
|
|
11
|
-
import {NapiWorkerPool} from './NapiWorkerPool';
|
|
12
|
-
import ThrowableDiagnostic from '@atlaspack/diagnostic';
|
|
13
|
-
import type {Event} from '@parcel/watcher';
|
|
14
|
-
import type {NapiWorkerPool as INapiWorkerPool} from '@atlaspack/types';
|
|
15
|
-
|
|
16
|
-
export type AtlaspackV3Options = {|
|
|
17
|
-
fs?: AtlaspackNapiOptions['fs'],
|
|
18
|
-
packageManager?: AtlaspackNapiOptions['packageManager'],
|
|
19
|
-
threads?: number,
|
|
20
|
-
/**
|
|
21
|
-
* A reference to LMDB lite's rust object
|
|
22
|
-
*/
|
|
23
|
-
lmdb: Lmdb,
|
|
24
|
-
featureFlags?: {[string]: string | boolean},
|
|
25
|
-
napiWorkerPool?: INapiWorkerPool,
|
|
26
|
-
...AtlaspackNapiOptions['options'],
|
|
27
|
-
|};
|
|
28
|
-
|
|
29
|
-
export class AtlaspackV3 {
|
|
30
|
-
_atlaspack_napi: AtlaspackNapi;
|
|
31
|
-
|
|
32
|
-
constructor(atlaspack_napi: AtlaspackNapi) {
|
|
33
|
-
this._atlaspack_napi = atlaspack_napi;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
static async create({
|
|
37
|
-
fs,
|
|
38
|
-
packageManager,
|
|
39
|
-
threads,
|
|
40
|
-
lmdb,
|
|
41
|
-
napiWorkerPool = new NapiWorkerPool(),
|
|
42
|
-
...options
|
|
43
|
-
}: AtlaspackV3Options): Promise<AtlaspackV3> {
|
|
44
|
-
options.logLevel = options.logLevel || 'error';
|
|
45
|
-
options.defaultTargetOptions = options.defaultTargetOptions || {};
|
|
46
|
-
// $FlowFixMe "engines" are readonly
|
|
47
|
-
options.defaultTargetOptions.engines =
|
|
48
|
-
options.defaultTargetOptions.engines || {};
|
|
49
|
-
|
|
50
|
-
const [internal, error] = await atlaspackNapiCreate(
|
|
51
|
-
{
|
|
52
|
-
fs,
|
|
53
|
-
packageManager,
|
|
54
|
-
threads,
|
|
55
|
-
options,
|
|
56
|
-
napiWorkerPool,
|
|
57
|
-
},
|
|
58
|
-
lmdb,
|
|
59
|
-
);
|
|
60
|
-
|
|
61
|
-
if (error !== null) {
|
|
62
|
-
throw new ThrowableDiagnostic({
|
|
63
|
-
diagnostic: error,
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
return new AtlaspackV3(internal);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
async buildAssetGraph(): Promise<any> {
|
|
71
|
-
let [graph, error] = await atlaspackNapiBuildAssetGraph(
|
|
72
|
-
this._atlaspack_napi,
|
|
73
|
-
);
|
|
74
|
-
|
|
75
|
-
if (error !== null) {
|
|
76
|
-
throw new ThrowableDiagnostic({
|
|
77
|
-
diagnostic: error,
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return graph;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
respondToFsEvents(events: Array<Event>): boolean {
|
|
85
|
-
return atlaspackNapiRespondToFsEvents(this._atlaspack_napi, events);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import type {NapiWorkerPool as INapiWorkerPool} from '@atlaspack/types';
|
|
3
|
-
import {Worker} from 'worker_threads';
|
|
4
|
-
import path from 'path';
|
|
5
|
-
import process from 'process';
|
|
6
|
-
import type {Transferable} from '@atlaspack/rust';
|
|
7
|
-
import {getAvailableThreads} from '@atlaspack/rust';
|
|
8
|
-
|
|
9
|
-
const WORKER_PATH = path.join(__dirname, 'worker', 'index.js');
|
|
10
|
-
const ATLASPACK_NAPI_WORKERS =
|
|
11
|
-
process.env.ATLASPACK_NAPI_WORKERS &&
|
|
12
|
-
parseInt(process.env.ATLASPACK_NAPI_WORKERS, 10);
|
|
13
|
-
|
|
14
|
-
export type NapiWorkerPoolOptions = {|
|
|
15
|
-
workerCount?: number,
|
|
16
|
-
|};
|
|
17
|
-
|
|
18
|
-
export class NapiWorkerPool implements INapiWorkerPool {
|
|
19
|
-
#workers: Worker[];
|
|
20
|
-
#napiWorkers: Array<Promise<Transferable>>;
|
|
21
|
-
#workerCount: number;
|
|
22
|
-
|
|
23
|
-
constructor({workerCount}: NapiWorkerPoolOptions = {workerCount: undefined}) {
|
|
24
|
-
this.#workerCount =
|
|
25
|
-
workerCount ?? ATLASPACK_NAPI_WORKERS ?? getAvailableThreads();
|
|
26
|
-
if (!this.#workerCount) {
|
|
27
|
-
// TODO use main thread if workerCount is 0
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
this.#workers = [];
|
|
31
|
-
this.#napiWorkers = [];
|
|
32
|
-
|
|
33
|
-
for (let i = 0; i < this.#workerCount; i++) {
|
|
34
|
-
let worker = new Worker(WORKER_PATH);
|
|
35
|
-
this.#workers.push(worker);
|
|
36
|
-
this.#napiWorkers.push(new Promise((res) => worker.once('message', res)));
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
workerCount(): number {
|
|
41
|
-
return this.#workerCount;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
getWorkers(): Promise<Array<Transferable>> {
|
|
45
|
-
return Promise.all(this.#napiWorkers);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
shutdown(): void {
|
|
49
|
-
for (const worker of this.#workers) {
|
|
50
|
-
worker.terminate();
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// @flow strict-local
|
|
2
|
-
|
|
3
|
-
export function jsCallable<Args: $ReadOnlyArray<mixed>, Return>(
|
|
4
|
-
fn: (...Args) => Return | Promise<Return>,
|
|
5
|
-
): (...Args) => Promise<Return> {
|
|
6
|
-
return async (...args: Args): Promise<Return> => {
|
|
7
|
-
try {
|
|
8
|
-
// $FlowFixMe "await" is needed to log the error from
|
|
9
|
-
// Promises and is safe to use on non-promises
|
|
10
|
-
return await fn(...args);
|
|
11
|
-
// $FlowFixMe
|
|
12
|
-
} catch (error) {
|
|
13
|
-
// eslint-disable-next-line no-console
|
|
14
|
-
console.error(error);
|
|
15
|
-
throw error;
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import type {
|
|
4
|
-
BundleBehavior,
|
|
5
|
-
DependencyPriority,
|
|
6
|
-
SpecifierType,
|
|
7
|
-
} from '@atlaspack/types';
|
|
8
|
-
|
|
9
|
-
/// BitFlags is used to map number/string types from napi types
|
|
10
|
-
export class BitFlags<K, V> {
|
|
11
|
-
#kv: {[key: K]: V};
|
|
12
|
-
#vk: {[key: V]: K};
|
|
13
|
-
|
|
14
|
-
constructor(source: {[key: K]: V}) {
|
|
15
|
-
this.#kv = source;
|
|
16
|
-
this.#vk = Object.fromEntries(
|
|
17
|
-
// $FlowFixMe
|
|
18
|
-
Object.entries(source).map((a) => a.reverse()),
|
|
19
|
-
);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
into(key: K): V {
|
|
23
|
-
const found = this.#kv[key];
|
|
24
|
-
if (found === undefined) {
|
|
25
|
-
// $FlowFixMe
|
|
26
|
-
throw new Error(`Invalid BundleBehavior(${key})`);
|
|
27
|
-
}
|
|
28
|
-
return found;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
intoNullable(key: ?K): ?V {
|
|
32
|
-
if (key === undefined || key === null) {
|
|
33
|
-
return undefined;
|
|
34
|
-
}
|
|
35
|
-
return this.into(key);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
intoArray(keys: K[]): V[] {
|
|
39
|
-
return keys.map((key) => this.into(key));
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
from(key: V): K {
|
|
43
|
-
const found = this.#vk[key];
|
|
44
|
-
if (found === undefined) {
|
|
45
|
-
// $FlowFixMe
|
|
46
|
-
throw new Error(`Invalid BundleBehavior(${key})`);
|
|
47
|
-
}
|
|
48
|
-
return found;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
fromNullable(key: ?V): ?K {
|
|
52
|
-
if (key === undefined || key === null) {
|
|
53
|
-
return undefined;
|
|
54
|
-
}
|
|
55
|
-
return this.from(key);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
fromArray(keys: V[]): K[] {
|
|
59
|
-
return keys.map((key) => this.from(key));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export const bundleBehaviorMap: BitFlags<BundleBehavior, number> = new BitFlags(
|
|
64
|
-
{
|
|
65
|
-
inline: 0,
|
|
66
|
-
isolated: 1,
|
|
67
|
-
},
|
|
68
|
-
);
|
|
69
|
-
|
|
70
|
-
export const dependencyPriorityMap: BitFlags<DependencyPriority, number> =
|
|
71
|
-
new BitFlags({
|
|
72
|
-
sync: 0,
|
|
73
|
-
parallel: 1,
|
|
74
|
-
lazy: 2,
|
|
75
|
-
conditional: 3,
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
export const packageConditionsMap: BitFlags<string, number> = new BitFlags({
|
|
79
|
-
import: 0,
|
|
80
|
-
require: 1,
|
|
81
|
-
module: 2,
|
|
82
|
-
node: 3,
|
|
83
|
-
browser: 4,
|
|
84
|
-
worker: 5,
|
|
85
|
-
worklet: 6,
|
|
86
|
-
electron: 7,
|
|
87
|
-
development: 8,
|
|
88
|
-
production: 9,
|
|
89
|
-
types: 10,
|
|
90
|
-
default: 11,
|
|
91
|
-
style: 12,
|
|
92
|
-
sass: 13,
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
export const specifierTypeMap: BitFlags<SpecifierType, number> = new BitFlags({
|
|
96
|
-
esm: 0,
|
|
97
|
-
commonjs: 1,
|
|
98
|
-
url: 2,
|
|
99
|
-
custom: 3,
|
|
100
|
-
});
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import type {PluginLogger as IPlguinLogger} from '@atlaspack/types';
|
|
4
|
-
import type {
|
|
5
|
-
Diagnostifiable,
|
|
6
|
-
DiagnosticWithoutOrigin,
|
|
7
|
-
} from '@atlaspack/diagnostic';
|
|
8
|
-
|
|
9
|
-
export class PluginLogger implements IPlguinLogger {
|
|
10
|
-
verbose(
|
|
11
|
-
diagnostic: DiagnosticWithoutOrigin | Array<DiagnosticWithoutOrigin>,
|
|
12
|
-
): void {
|
|
13
|
-
// eslint-disable-next-line no-console
|
|
14
|
-
console.log(diagnostic);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
info(
|
|
18
|
-
diagnostic: DiagnosticWithoutOrigin | Array<DiagnosticWithoutOrigin>,
|
|
19
|
-
): void {
|
|
20
|
-
// eslint-disable-next-line no-console
|
|
21
|
-
console.info(diagnostic);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
log(
|
|
25
|
-
diagnostic: DiagnosticWithoutOrigin | Array<DiagnosticWithoutOrigin>,
|
|
26
|
-
): void {
|
|
27
|
-
// eslint-disable-next-line no-console
|
|
28
|
-
console.log(diagnostic);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
warn(
|
|
32
|
-
diagnostic: DiagnosticWithoutOrigin | Array<DiagnosticWithoutOrigin>,
|
|
33
|
-
): void {
|
|
34
|
-
// eslint-disable-next-line no-console
|
|
35
|
-
console.warn(diagnostic);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
error(
|
|
39
|
-
input:
|
|
40
|
-
| Diagnostifiable
|
|
41
|
-
| DiagnosticWithoutOrigin
|
|
42
|
-
| Array<DiagnosticWithoutOrigin>,
|
|
43
|
-
): void {
|
|
44
|
-
// eslint-disable-next-line no-console
|
|
45
|
-
console.error(input);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
@@ -1,369 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import assert from 'assert';
|
|
3
|
-
import * as napi from '@atlaspack/rust';
|
|
4
|
-
import type {JsCallable} from '@atlaspack/rust';
|
|
5
|
-
import {NodeFS} from '@atlaspack/fs';
|
|
6
|
-
import {NodePackageManager} from '@atlaspack/package-manager';
|
|
7
|
-
import type {
|
|
8
|
-
Resolver,
|
|
9
|
-
Transformer,
|
|
10
|
-
FilePath,
|
|
11
|
-
FileSystem,
|
|
12
|
-
} from '@atlaspack/types';
|
|
13
|
-
import {parentPort} from 'worker_threads';
|
|
14
|
-
import * as module from 'module';
|
|
15
|
-
|
|
16
|
-
import {jsCallable} from '../jsCallable';
|
|
17
|
-
import {
|
|
18
|
-
Environment,
|
|
19
|
-
Dependency,
|
|
20
|
-
PluginConfig,
|
|
21
|
-
PluginLogger,
|
|
22
|
-
PluginTracer,
|
|
23
|
-
PluginOptions,
|
|
24
|
-
MutableAsset,
|
|
25
|
-
bundleBehaviorMap,
|
|
26
|
-
dependencyPriorityMap,
|
|
27
|
-
} from './compat';
|
|
28
|
-
|
|
29
|
-
const CONFIG = Symbol.for('parcel-plugin-config');
|
|
30
|
-
|
|
31
|
-
export class AtlaspackWorker {
|
|
32
|
-
#resolvers: Map<string, ResolverState<any>>;
|
|
33
|
-
#transformers: Map<string, TransformerState<any>>;
|
|
34
|
-
#fs: FileSystem;
|
|
35
|
-
|
|
36
|
-
constructor() {
|
|
37
|
-
this.#resolvers = new Map();
|
|
38
|
-
this.#transformers = new Map();
|
|
39
|
-
this.#fs = new NodeFS();
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
loadPlugin: JsCallable<[LoadPluginOptions], Promise<void>> = jsCallable(
|
|
43
|
-
async ({kind, specifier, resolveFrom}) => {
|
|
44
|
-
let customRequire = module.createRequire(resolveFrom);
|
|
45
|
-
let resolvedPath = customRequire.resolve(specifier);
|
|
46
|
-
// $FlowFixMe
|
|
47
|
-
let resolvedModule = await import(resolvedPath);
|
|
48
|
-
|
|
49
|
-
let instance = undefined;
|
|
50
|
-
if (resolvedModule.default && resolvedModule.default[CONFIG]) {
|
|
51
|
-
instance = resolvedModule.default[CONFIG];
|
|
52
|
-
} else if (
|
|
53
|
-
resolvedModule.default &&
|
|
54
|
-
resolvedModule.default.default &&
|
|
55
|
-
resolvedModule.default.default[CONFIG]
|
|
56
|
-
) {
|
|
57
|
-
instance = resolvedModule.default.default[CONFIG];
|
|
58
|
-
} else {
|
|
59
|
-
throw new Error(
|
|
60
|
-
`Plugin could not be resolved\n\t${kind}\n\t${resolveFrom}\n\t${specifier}`,
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
switch (kind) {
|
|
65
|
-
case 'resolver':
|
|
66
|
-
this.#resolvers.set(specifier, {resolver: instance});
|
|
67
|
-
break;
|
|
68
|
-
case 'transformer':
|
|
69
|
-
this.#transformers.set(specifier, {transformer: instance});
|
|
70
|
-
break;
|
|
71
|
-
}
|
|
72
|
-
},
|
|
73
|
-
);
|
|
74
|
-
|
|
75
|
-
runResolverResolve: JsCallable<
|
|
76
|
-
[RunResolverResolveOptions],
|
|
77
|
-
Promise<RunResolverResolveResult>,
|
|
78
|
-
> = jsCallable(
|
|
79
|
-
async ({
|
|
80
|
-
key,
|
|
81
|
-
dependency: napiDependency,
|
|
82
|
-
specifier,
|
|
83
|
-
pipeline,
|
|
84
|
-
pluginOptions,
|
|
85
|
-
}) => {
|
|
86
|
-
const state = this.#resolvers.get(key);
|
|
87
|
-
if (!state) {
|
|
88
|
-
throw new Error(`Resolver not found: ${key}`);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
let packageManager = state.packageManager;
|
|
92
|
-
if (!packageManager) {
|
|
93
|
-
packageManager = new NodePackageManager(
|
|
94
|
-
this.#fs,
|
|
95
|
-
pluginOptions.projectRoot,
|
|
96
|
-
);
|
|
97
|
-
state.packageManager = packageManager;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
const env = new Environment(napiDependency.env);
|
|
101
|
-
const dependency = new Dependency(napiDependency, env);
|
|
102
|
-
|
|
103
|
-
const defaultOptions = {
|
|
104
|
-
logger: new PluginLogger(),
|
|
105
|
-
tracer: new PluginTracer(),
|
|
106
|
-
options: new PluginOptions({
|
|
107
|
-
...pluginOptions,
|
|
108
|
-
packageManager,
|
|
109
|
-
shouldAutoInstall: false,
|
|
110
|
-
inputFS: this.#fs,
|
|
111
|
-
outputFS: this.#fs,
|
|
112
|
-
}),
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
if (!('config' in state)) {
|
|
116
|
-
state.config = await state.resolver.loadConfig?.({
|
|
117
|
-
config: new PluginConfig({
|
|
118
|
-
env,
|
|
119
|
-
isSource: true,
|
|
120
|
-
searchPath: specifier,
|
|
121
|
-
projectRoot: pluginOptions.projectRoot,
|
|
122
|
-
fs: this.#fs,
|
|
123
|
-
packageManager,
|
|
124
|
-
}),
|
|
125
|
-
...defaultOptions,
|
|
126
|
-
});
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const result = await state.resolver.resolve({
|
|
130
|
-
specifier,
|
|
131
|
-
dependency,
|
|
132
|
-
pipeline,
|
|
133
|
-
config: state.config,
|
|
134
|
-
...defaultOptions,
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
if (!result) {
|
|
138
|
-
return {
|
|
139
|
-
invalidations: [],
|
|
140
|
-
resolution: {type: 'unresolved'},
|
|
141
|
-
};
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (result.isExcluded) {
|
|
145
|
-
return {
|
|
146
|
-
invalidations: [],
|
|
147
|
-
resolution: {type: 'excluded'},
|
|
148
|
-
};
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
return {
|
|
152
|
-
invalidations: [],
|
|
153
|
-
resolution: {
|
|
154
|
-
type: 'resolved',
|
|
155
|
-
filePath: result.filePath || '',
|
|
156
|
-
canDefer: result.canDefer || false,
|
|
157
|
-
sideEffects: result.sideEffects || false,
|
|
158
|
-
code: result.code || undefined,
|
|
159
|
-
meta: result.meta || undefined,
|
|
160
|
-
pipeline: result.pipeline || undefined,
|
|
161
|
-
priority: dependencyPriorityMap.intoNullable(result.priority),
|
|
162
|
-
query: result.query && result.query.toString(),
|
|
163
|
-
},
|
|
164
|
-
};
|
|
165
|
-
},
|
|
166
|
-
);
|
|
167
|
-
|
|
168
|
-
runTransformerTransform: JsCallable<
|
|
169
|
-
[RunTransformerTransformOptions, Buffer, ?string],
|
|
170
|
-
Promise<RunTransformerTransformResult>,
|
|
171
|
-
> = jsCallable(
|
|
172
|
-
async ({key, env: napiEnv, options, asset: innerAsset}, contents, map) => {
|
|
173
|
-
const state = this.#transformers.get(key);
|
|
174
|
-
if (!state) {
|
|
175
|
-
throw new Error(`Transformer not found: ${key}`);
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
let packageManager = state.packageManager;
|
|
179
|
-
if (!packageManager) {
|
|
180
|
-
packageManager = new NodePackageManager(this.#fs, options.projectRoot);
|
|
181
|
-
state.packageManager = packageManager;
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
const transformer: Transformer<any> = state.transformer;
|
|
185
|
-
const resolveFunc = (from: string, to: string): Promise<any> => {
|
|
186
|
-
let customRequire = module.createRequire(from);
|
|
187
|
-
let resolvedPath = customRequire.resolve(to);
|
|
188
|
-
|
|
189
|
-
return Promise.resolve(resolvedPath);
|
|
190
|
-
};
|
|
191
|
-
|
|
192
|
-
const env = new Environment(napiEnv);
|
|
193
|
-
const mutableAsset = new MutableAsset(
|
|
194
|
-
innerAsset,
|
|
195
|
-
contents,
|
|
196
|
-
env,
|
|
197
|
-
this.#fs,
|
|
198
|
-
map,
|
|
199
|
-
options.projectRoot,
|
|
200
|
-
);
|
|
201
|
-
|
|
202
|
-
const defaultOptions = {
|
|
203
|
-
logger: new PluginLogger(),
|
|
204
|
-
tracer: new PluginTracer(),
|
|
205
|
-
options: new PluginOptions({
|
|
206
|
-
...options,
|
|
207
|
-
packageManager,
|
|
208
|
-
shouldAutoInstall: false,
|
|
209
|
-
inputFS: this.#fs,
|
|
210
|
-
outputFS: this.#fs,
|
|
211
|
-
}),
|
|
212
|
-
};
|
|
213
|
-
|
|
214
|
-
const config = await transformer.loadConfig?.({
|
|
215
|
-
config: new PluginConfig({
|
|
216
|
-
env,
|
|
217
|
-
isSource: true,
|
|
218
|
-
searchPath: innerAsset.filePath,
|
|
219
|
-
projectRoot: options.projectRoot,
|
|
220
|
-
fs: this.#fs,
|
|
221
|
-
packageManager,
|
|
222
|
-
}),
|
|
223
|
-
...defaultOptions,
|
|
224
|
-
});
|
|
225
|
-
|
|
226
|
-
if (transformer.parse) {
|
|
227
|
-
const ast = await transformer.parse({
|
|
228
|
-
asset: mutableAsset,
|
|
229
|
-
config,
|
|
230
|
-
resolve: resolveFunc,
|
|
231
|
-
...defaultOptions,
|
|
232
|
-
});
|
|
233
|
-
if (ast) {
|
|
234
|
-
mutableAsset.setAST(ast);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
const result = await state.transformer.transform({
|
|
239
|
-
asset: mutableAsset,
|
|
240
|
-
config,
|
|
241
|
-
resolve: resolveFunc,
|
|
242
|
-
...defaultOptions,
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
if (transformer.generate) {
|
|
246
|
-
const ast = await mutableAsset.getAST();
|
|
247
|
-
if (ast) {
|
|
248
|
-
// $FlowFixMe "Cannot call `transformer.generate` because undefined [1] is not a function." 🤷♀️
|
|
249
|
-
const output = await transformer.generate({
|
|
250
|
-
asset: mutableAsset,
|
|
251
|
-
ast,
|
|
252
|
-
...defaultOptions,
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
if (typeof output.content === 'string') {
|
|
256
|
-
mutableAsset.setCode(output.content);
|
|
257
|
-
} else if (output.content instanceof Buffer) {
|
|
258
|
-
mutableAsset.setBuffer(output.content);
|
|
259
|
-
} else {
|
|
260
|
-
mutableAsset.setStream(output.content);
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
if (output.map) {
|
|
264
|
-
mutableAsset.setMap(output.map);
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
assert(
|
|
270
|
-
result.length === 1,
|
|
271
|
-
'[V3] Unimplemented: Multiple asset return from Node transformer',
|
|
272
|
-
);
|
|
273
|
-
|
|
274
|
-
assert(
|
|
275
|
-
result[0] === mutableAsset,
|
|
276
|
-
'[V3] Unimplemented: New asset returned from Node transformer',
|
|
277
|
-
);
|
|
278
|
-
|
|
279
|
-
return [
|
|
280
|
-
{
|
|
281
|
-
id: mutableAsset.id,
|
|
282
|
-
bundleBehavior: bundleBehaviorMap.intoNullable(
|
|
283
|
-
mutableAsset.bundleBehavior,
|
|
284
|
-
),
|
|
285
|
-
code: [],
|
|
286
|
-
filePath: mutableAsset.filePath,
|
|
287
|
-
isBundleSplittable: mutableAsset.isBundleSplittable,
|
|
288
|
-
isSource: mutableAsset.isSource,
|
|
289
|
-
meta: mutableAsset.meta,
|
|
290
|
-
pipeline: mutableAsset.pipeline,
|
|
291
|
-
// Query should be undefined if it's empty
|
|
292
|
-
query: mutableAsset.query.toString() || undefined,
|
|
293
|
-
sideEffects: mutableAsset.sideEffects,
|
|
294
|
-
symbols: mutableAsset.symbols.intoNapi(),
|
|
295
|
-
type: mutableAsset.type,
|
|
296
|
-
uniqueKey: mutableAsset.uniqueKey,
|
|
297
|
-
},
|
|
298
|
-
await mutableAsset.getBuffer(),
|
|
299
|
-
// Only send back the map if it has changed
|
|
300
|
-
mutableAsset.isMapDirty
|
|
301
|
-
? // $FlowFixMe A dirty map means this will be valid
|
|
302
|
-
JSON.stringify((await mutableAsset.getMap()).toVLQ())
|
|
303
|
-
: '',
|
|
304
|
-
];
|
|
305
|
-
},
|
|
306
|
-
);
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
// Create napi worker and send it back to main thread
|
|
310
|
-
const worker = new AtlaspackWorker();
|
|
311
|
-
const napiWorker = napi.newNodejsWorker(worker);
|
|
312
|
-
parentPort?.postMessage(napiWorker);
|
|
313
|
-
|
|
314
|
-
type ResolverState<T> = {|
|
|
315
|
-
resolver: Resolver<T>,
|
|
316
|
-
config?: T,
|
|
317
|
-
packageManager?: NodePackageManager,
|
|
318
|
-
|};
|
|
319
|
-
|
|
320
|
-
type TransformerState<T> = {|
|
|
321
|
-
packageManager?: NodePackageManager,
|
|
322
|
-
transformer: Transformer<T>,
|
|
323
|
-
|};
|
|
324
|
-
|
|
325
|
-
type LoadPluginOptions = {|
|
|
326
|
-
kind: 'resolver' | 'transformer',
|
|
327
|
-
specifier: string,
|
|
328
|
-
resolveFrom: string,
|
|
329
|
-
|};
|
|
330
|
-
|
|
331
|
-
type RpcPluginOptions = {|
|
|
332
|
-
projectRoot: string,
|
|
333
|
-
mode: string,
|
|
334
|
-
|};
|
|
335
|
-
|
|
336
|
-
type RunResolverResolveOptions = {|
|
|
337
|
-
key: string,
|
|
338
|
-
dependency: napi.Dependency,
|
|
339
|
-
specifier: FilePath,
|
|
340
|
-
pipeline: ?string,
|
|
341
|
-
pluginOptions: RpcPluginOptions,
|
|
342
|
-
|};
|
|
343
|
-
|
|
344
|
-
type RunResolverResolveResult = {|
|
|
345
|
-
invalidations: Array<*>,
|
|
346
|
-
resolution:
|
|
347
|
-
| {|type: 'unresolved'|}
|
|
348
|
-
| {|type: 'excluded'|}
|
|
349
|
-
| {|
|
|
350
|
-
type: 'resolved',
|
|
351
|
-
canDefer: boolean,
|
|
352
|
-
filePath: string,
|
|
353
|
-
sideEffects: boolean,
|
|
354
|
-
code?: string,
|
|
355
|
-
meta?: mixed,
|
|
356
|
-
pipeline?: string,
|
|
357
|
-
priority?: ?number,
|
|
358
|
-
query?: string,
|
|
359
|
-
|},
|
|
360
|
-
|};
|
|
361
|
-
|
|
362
|
-
type RunTransformerTransformOptions = {|
|
|
363
|
-
key: string,
|
|
364
|
-
env: napi.Environment,
|
|
365
|
-
options: RpcPluginOptions,
|
|
366
|
-
asset: napi.Asset,
|
|
367
|
-
|};
|
|
368
|
-
|
|
369
|
-
type RunTransformerTransformResult = [napi.RpcAssetResult, Buffer, string];
|