@wyw-in-js/transform 1.0.8 → 2.0.0-alpha.0
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/esm/cache.js +426 -289
- package/esm/cache.js.map +1 -1
- package/esm/debug/fileReporter.js +137 -134
- package/esm/debug/fileReporter.js.map +1 -1
- package/esm/eval/broker.js +2134 -0
- package/esm/eval/broker.js.map +1 -0
- package/esm/eval/lru.js +36 -0
- package/esm/eval/lru.js.map +1 -0
- package/esm/eval/prepareModuleOnDemand.js +21 -0
- package/esm/eval/prepareModuleOnDemand.js.map +1 -0
- package/esm/eval/protocol.js +2 -0
- package/esm/eval/protocol.js.map +1 -0
- package/esm/eval/resolverStrategy.js +51 -0
- package/esm/eval/resolverStrategy.js.map +1 -0
- package/esm/eval/runner.js +1759 -0
- package/esm/eval/runner.js.map +1 -0
- package/esm/eval/serialize.js +333 -0
- package/esm/eval/serialize.js.map +1 -0
- package/esm/eval/writeQueue.js +81 -0
- package/esm/eval/writeQueue.js.map +1 -0
- package/esm/evaluators/index.js +11 -12
- package/esm/evaluators/index.js.map +1 -1
- package/esm/index.js +25 -28
- package/esm/index.js.map +1 -1
- package/esm/module.js +896 -520
- package/esm/module.js.map +1 -1
- package/esm/shaker.js +14 -80
- package/esm/shaker.js.map +1 -1
- package/esm/transform/BaseEntrypoint.js +162 -164
- package/esm/transform/BaseEntrypoint.js.map +1 -1
- package/esm/transform/Entrypoint.helpers.js +96 -253
- package/esm/transform/Entrypoint.helpers.js.map +1 -1
- package/esm/transform/Entrypoint.js +336 -270
- package/esm/transform/Entrypoint.js.map +1 -1
- package/esm/transform/Entrypoint.types.js +1 -1
- package/esm/transform/Entrypoint.types.js.map +1 -1
- package/esm/transform/EvaluatedEntrypoint.js +10 -4
- package/esm/transform/EvaluatedEntrypoint.js.map +1 -1
- package/esm/transform/actions/AbortError.js +6 -6
- package/esm/transform/actions/AbortError.js.map +1 -1
- package/esm/transform/actions/BaseAction.js +140 -136
- package/esm/transform/actions/BaseAction.js.map +1 -1
- package/esm/transform/actions/UnprocessedEntrypointError.js +6 -6
- package/esm/transform/actions/UnprocessedEntrypointError.js.map +1 -1
- package/esm/transform/actions/actionRunner.js +63 -66
- package/esm/transform/actions/actionRunner.js.map +1 -1
- package/esm/transform/actions/types.js +1 -1
- package/esm/transform/actions/types.js.map +1 -1
- package/esm/transform/barrelManifest.types.js +2 -0
- package/esm/transform/barrelManifest.types.js.map +1 -0
- package/esm/transform/generators/baseProcessingHandlers.js +15 -17
- package/esm/transform/generators/baseProcessingHandlers.js.map +1 -1
- package/esm/transform/generators/collect.js +27 -55
- package/esm/transform/generators/collect.js.map +1 -1
- package/esm/transform/generators/createStylisPreprocessor.js +353 -321
- package/esm/transform/generators/createStylisPreprocessor.js.map +1 -1
- package/esm/transform/generators/evalFile.js +48 -47
- package/esm/transform/generators/evalFile.js.map +1 -1
- package/esm/transform/generators/extract.js +78 -90
- package/esm/transform/generators/extract.js.map +1 -1
- package/esm/transform/generators/getExports.js +57 -74
- package/esm/transform/generators/getExports.js.map +1 -1
- package/esm/transform/generators/index.js +11 -11
- package/esm/transform/generators/index.js.map +1 -1
- package/esm/transform/generators/processEntrypoint.js +78 -67
- package/esm/transform/generators/processEntrypoint.js.map +1 -1
- package/esm/transform/generators/processImports.js +102 -67
- package/esm/transform/generators/processImports.js.map +1 -1
- package/esm/transform/generators/resolveImports.js +165 -196
- package/esm/transform/generators/resolveImports.js.map +1 -1
- package/esm/transform/generators/resolveStaticOxcValues.js +2911 -0
- package/esm/transform/generators/resolveStaticOxcValues.js.map +1 -0
- package/esm/transform/generators/rewriteOxcBarrelImports.js +822 -0
- package/esm/transform/generators/rewriteOxcBarrelImports.js.map +1 -0
- package/esm/transform/generators/transform.js +239 -248
- package/esm/transform/generators/transform.js.map +1 -1
- package/esm/transform/generators/workflow.js +87 -79
- package/esm/transform/generators/workflow.js.map +1 -1
- package/esm/transform/helpers/loadWywOptions.js +154 -73
- package/esm/transform/helpers/loadWywOptions.js.map +1 -1
- package/esm/transform/helpers/withDefaultServices.js +13 -22
- package/esm/transform/helpers/withDefaultServices.js.map +1 -1
- package/esm/transform/isStaticallyEvaluatableModule.js +140 -152
- package/esm/transform/isStaticallyEvaluatableModule.js.map +1 -1
- package/esm/transform/oxcBarrelManifest.js +349 -0
- package/esm/transform/oxcBarrelManifest.js.map +1 -0
- package/esm/transform/rootLog.js +3 -3
- package/esm/transform/rootLog.js.map +1 -1
- package/esm/transform/syntax.js +2 -0
- package/esm/transform/syntax.js.map +1 -0
- package/esm/transform/types.js +2 -2
- package/esm/transform/types.js.map +1 -1
- package/esm/transform.js +123 -147
- package/esm/transform.js.map +1 -1
- package/esm/types.js +4 -1
- package/esm/types.js.map +1 -1
- package/esm/utils/EventEmitter.js +46 -48
- package/esm/utils/EventEmitter.js.map +1 -1
- package/esm/utils/ShakerMetadata.js +2 -2
- package/esm/utils/ShakerMetadata.js.map +1 -1
- package/esm/utils/TransformDiagnostics.js +10 -0
- package/esm/utils/TransformDiagnostics.js.map +1 -0
- package/esm/utils/TransformMetadata.js +28 -10
- package/esm/utils/TransformMetadata.js.map +1 -1
- package/esm/utils/applyOxcProcessors.js +1217 -0
- package/esm/utils/applyOxcProcessors.js.map +1 -0
- package/esm/utils/collectOxcExportsAndImports.js +934 -0
- package/esm/utils/collectOxcExportsAndImports.js.map +1 -0
- package/esm/utils/collectOxcRuntime.js +220 -0
- package/esm/utils/collectOxcRuntime.js.map +1 -0
- package/esm/utils/collectOxcTemplateDependencies.js +1398 -0
- package/esm/utils/collectOxcTemplateDependencies.js.map +1 -0
- package/esm/utils/dispose-polyfill.js +3 -4
- package/esm/utils/dispose-polyfill.js.map +1 -1
- package/esm/utils/getFileIdx.js +6 -6
- package/esm/utils/getFileIdx.js.map +1 -1
- package/esm/utils/getPluginKey.js +12 -12
- package/esm/utils/getPluginKey.js.map +1 -1
- package/esm/utils/getVisitorKeys.js +9 -3
- package/esm/utils/getVisitorKeys.js.map +1 -1
- package/esm/utils/hasCachedWywPrevalExport.js +23 -0
- package/esm/utils/hasCachedWywPrevalExport.js.map +1 -0
- package/esm/utils/hasWywPreval.js +5 -5
- package/esm/utils/hasWywPreval.js.map +1 -1
- package/esm/utils/importOverrides.js +75 -90
- package/esm/utils/importOverrides.js.map +1 -1
- package/esm/utils/isNode.js +2 -2
- package/esm/utils/isNode.js.map +1 -1
- package/esm/utils/isNotNull.js +2 -2
- package/esm/utils/isNotNull.js.map +1 -1
- package/esm/utils/isSerializable.js +11 -11
- package/esm/utils/isSerializable.js.map +1 -1
- package/esm/utils/oxcAstService.js +121 -0
- package/esm/utils/oxcAstService.js.map +1 -0
- package/esm/utils/oxcEmit.js +447 -0
- package/esm/utils/oxcEmit.js.map +1 -0
- package/esm/utils/oxcPreevalStage.js +97 -0
- package/esm/utils/oxcPreevalStage.js.map +1 -0
- package/esm/utils/oxcPreevalTransforms.js +1054 -0
- package/esm/utils/oxcPreevalTransforms.js.map +1 -0
- package/esm/utils/oxcShaker.js +662 -0
- package/esm/utils/oxcShaker.js.map +1 -0
- package/esm/utils/parseOxc.js +37 -0
- package/esm/utils/parseOxc.js.map +1 -0
- package/esm/utils/parseRequest.js +27 -27
- package/esm/utils/parseRequest.js.map +1 -1
- package/esm/utils/peek.js +1 -1
- package/esm/utils/peek.js.map +1 -1
- package/esm/utils/processorLookup.js +125 -0
- package/esm/utils/processorLookup.js.map +1 -0
- package/esm/utils/resolveWithConditions.js +99 -0
- package/esm/utils/resolveWithConditions.js.map +1 -0
- package/esm/vm/createVmContext.js +140 -141
- package/esm/vm/createVmContext.js.map +1 -1
- package/esm/vm/process.js +11 -13
- package/esm/vm/process.js.map +1 -1
- package/package.json +18 -26
- package/types/cache.d.ts +17 -8
- package/types/cache.js +237 -95
- package/types/debug/fileReporter.js +22 -22
- package/types/eval/broker.d.ts +88 -0
- package/types/eval/broker.js +2262 -0
- package/types/eval/lru.d.ts +10 -0
- package/types/eval/lru.js +36 -0
- package/types/eval/prepareModuleOnDemand.d.ts +7 -0
- package/types/eval/prepareModuleOnDemand.js +24 -0
- package/types/eval/protocol.d.ts +97 -0
- package/types/eval/protocol.js +1 -0
- package/types/eval/resolverStrategy.d.ts +13 -0
- package/types/eval/resolverStrategy.js +46 -0
- package/types/eval/serialize.d.ts +78 -0
- package/types/eval/serialize.js +357 -0
- package/types/eval/writeQueue.d.ts +13 -0
- package/types/eval/writeQueue.js +80 -0
- package/types/evaluators/index.d.ts +2 -2
- package/types/evaluators/index.js +6 -9
- package/types/index.d.ts +7 -8
- package/types/index.js +24 -77
- package/types/module.d.ts +35 -7
- package/types/module.js +535 -163
- package/types/shaker.d.ts +2 -10
- package/types/shaker.js +10 -100
- package/types/transform/BaseEntrypoint.js +6 -11
- package/types/transform/Entrypoint.d.ts +15 -15
- package/types/transform/Entrypoint.helpers.d.ts +2 -5
- package/types/transform/Entrypoint.helpers.js +43 -203
- package/types/transform/Entrypoint.js +130 -53
- package/types/transform/Entrypoint.types.d.ts +28 -6
- package/types/transform/Entrypoint.types.js +1 -2
- package/types/transform/EvaluatedEntrypoint.d.ts +13 -2
- package/types/transform/EvaluatedEntrypoint.js +7 -6
- package/types/transform/actions/AbortError.js +2 -7
- package/types/transform/actions/BaseAction.js +4 -8
- package/types/transform/actions/UnprocessedEntrypointError.js +2 -7
- package/types/transform/actions/actionRunner.js +8 -12
- package/types/transform/actions/types.d.ts +6 -2
- package/types/transform/actions/types.js +1 -2
- package/types/transform/{barrelManifest.d.ts → barrelManifest.types.d.ts} +0 -2
- package/types/transform/barrelManifest.types.js +1 -0
- package/types/transform/generators/baseProcessingHandlers.d.ts +4 -5
- package/types/transform/generators/baseProcessingHandlers.js +10 -14
- package/types/transform/generators/collect.js +13 -39
- package/types/transform/generators/createStylisPreprocessor.js +19 -60
- package/types/transform/generators/evalFile.d.ts +2 -2
- package/types/transform/generators/evalFile.js +26 -28
- package/types/transform/generators/extract.js +5 -8
- package/types/transform/generators/getExports.js +23 -30
- package/types/transform/generators/index.d.ts +2 -2
- package/types/transform/generators/index.js +11 -14
- package/types/transform/generators/processEntrypoint.d.ts +2 -2
- package/types/transform/generators/processEntrypoint.js +60 -26
- package/types/transform/generators/processImports.d.ts +0 -3
- package/types/transform/generators/processImports.js +60 -20
- package/types/transform/generators/resolveImports.js +18 -22
- package/types/transform/generators/resolveStaticOxcValues.d.ts +2 -0
- package/types/transform/generators/resolveStaticOxcValues.js +3235 -0
- package/types/transform/generators/{rewriteBarrelImports.d.ts → rewriteOxcBarrelImports.d.ts} +2 -3
- package/types/transform/generators/{rewriteBarrelImports.js → rewriteOxcBarrelImports.js} +282 -225
- package/types/transform/generators/transform.d.ts +3 -7
- package/types/transform/generators/transform.js +203 -199
- package/types/transform/generators/workflow.js +62 -37
- package/types/transform/helpers/loadWywOptions.js +95 -20
- package/types/transform/helpers/withDefaultServices.d.ts +1 -1
- package/types/transform/helpers/withDefaultServices.js +6 -44
- package/types/transform/isStaticallyEvaluatableModule.d.ts +1 -2
- package/types/transform/isStaticallyEvaluatableModule.js +125 -126
- package/types/transform/oxcBarrelManifest.d.ts +2 -0
- package/types/transform/{barrelManifest.js → oxcBarrelManifest.js} +156 -97
- package/types/transform/rootLog.js +2 -5
- package/types/transform/syntax.d.ts +38 -0
- package/types/transform/syntax.js +1 -0
- package/types/transform/types.d.ts +9 -6
- package/types/transform/types.js +1 -4
- package/types/transform.d.ts +2 -2
- package/types/transform.js +88 -101
- package/types/types.d.ts +4 -24
- package/types/types.js +1 -2
- package/types/utils/EventEmitter.js +3 -9
- package/types/utils/ShakerMetadata.js +1 -5
- package/types/utils/TransformDiagnostics.d.ts +9 -0
- package/types/utils/TransformDiagnostics.js +11 -0
- package/types/utils/TransformMetadata.d.ts +22 -4
- package/types/utils/TransformMetadata.js +23 -8
- package/types/utils/applyOxcProcessors.d.ts +16 -0
- package/types/utils/applyOxcProcessors.js +1391 -0
- package/types/utils/collectOxcExportsAndImports.d.ts +35 -0
- package/types/utils/collectOxcExportsAndImports.js +957 -0
- package/types/utils/collectOxcRuntime.d.ts +14 -0
- package/types/utils/collectOxcRuntime.js +250 -0
- package/types/utils/collectOxcTemplateDependencies.d.ts +38 -0
- package/types/utils/collectOxcTemplateDependencies.js +1580 -0
- package/types/utils/getFileIdx.js +1 -4
- package/types/utils/getPluginKey.d.ts +5 -2
- package/types/utils/getPluginKey.js +2 -6
- package/types/utils/getVisitorKeys.d.ts +4 -4
- package/types/utils/getVisitorKeys.js +9 -6
- package/types/utils/hasCachedWywPrevalExport.d.ts +14 -0
- package/types/utils/hasCachedWywPrevalExport.js +30 -0
- package/types/utils/hasWywPreval.js +1 -4
- package/types/utils/importOverrides.js +17 -27
- package/types/utils/isNode.d.ts +2 -2
- package/types/utils/isNode.js +2 -6
- package/types/utils/isNotNull.js +1 -4
- package/types/utils/isSerializable.js +3 -6
- package/types/utils/oxcAstService.d.ts +11 -0
- package/types/utils/oxcAstService.js +79 -0
- package/types/utils/oxcEmit.d.ts +19 -0
- package/types/utils/oxcEmit.js +506 -0
- package/types/utils/oxcPreevalStage.d.ts +20 -0
- package/types/utils/oxcPreevalStage.js +102 -0
- package/types/utils/oxcPreevalTransforms.d.ts +13 -0
- package/types/utils/oxcPreevalTransforms.js +1179 -0
- package/types/utils/oxcShaker.d.ts +13 -0
- package/types/utils/oxcShaker.js +751 -0
- package/types/utils/parseOxc.d.ts +11 -0
- package/types/utils/parseOxc.js +38 -0
- package/types/utils/parseRequest.js +2 -7
- package/types/utils/peek.js +1 -5
- package/types/utils/processorLookup.d.ts +8 -0
- package/types/utils/processorLookup.js +135 -0
- package/types/utils/resolveWithConditions.d.ts +12 -0
- package/types/utils/resolveWithConditions.js +103 -0
- package/types/vm/createVmContext.d.ts +2 -2
- package/types/vm/createVmContext.js +25 -62
- package/types/vm/process.js +20 -26
- package/esm/babel.js +0 -2
- package/esm/babel.js.map +0 -1
- package/esm/options/buildOptions.js +0 -168
- package/esm/options/buildOptions.js.map +0 -1
- package/esm/options/buildOptions.test.js +0 -138
- package/esm/options/buildOptions.test.js.map +0 -1
- package/esm/options/loadBabelOptions.js +0 -24
- package/esm/options/loadBabelOptions.js.map +0 -1
- package/esm/plugins/babel-transform.js +0 -53
- package/esm/plugins/babel-transform.js.map +0 -1
- package/esm/plugins/collector.js +0 -60
- package/esm/plugins/collector.js.map +0 -1
- package/esm/plugins/dynamic-import.js +0 -56
- package/esm/plugins/dynamic-import.js.map +0 -1
- package/esm/plugins/preeval.js +0 -73
- package/esm/plugins/preeval.js.map +0 -1
- package/esm/plugins/shaker.js +0 -680
- package/esm/plugins/shaker.js.map +0 -1
- package/esm/transform/barrelManifest.js +0 -291
- package/esm/transform/barrelManifest.js.map +0 -1
- package/esm/transform/generators/explodeReexports.js +0 -64
- package/esm/transform/generators/explodeReexports.js.map +0 -1
- package/esm/transform/generators/rewriteBarrelImports.js +0 -733
- package/esm/transform/generators/rewriteBarrelImports.js.map +0 -1
- package/esm/utils/addIdentifierToWywPreval.js +0 -68
- package/esm/utils/addIdentifierToWywPreval.js.map +0 -1
- package/esm/utils/collectExportsAndImports.js +0 -1157
- package/esm/utils/collectExportsAndImports.js.map +0 -1
- package/esm/utils/collectTemplateDependencies.js +0 -228
- package/esm/utils/collectTemplateDependencies.js.map +0 -1
- package/esm/utils/createId.js +0 -6
- package/esm/utils/createId.js.map +0 -1
- package/esm/utils/findIdentifiers.js +0 -62
- package/esm/utils/findIdentifiers.js.map +0 -1
- package/esm/utils/getConstantStringValue.js +0 -58
- package/esm/utils/getConstantStringValue.js.map +0 -1
- package/esm/utils/getMemberExpressionPropertyName.js +0 -11
- package/esm/utils/getMemberExpressionPropertyName.js.map +0 -1
- package/esm/utils/getScope.js +0 -6
- package/esm/utils/getScope.js.map +0 -1
- package/esm/utils/getSource.js +0 -15
- package/esm/utils/getSource.js.map +0 -1
- package/esm/utils/getTagProcessor.js +0 -404
- package/esm/utils/getTagProcessor.js.map +0 -1
- package/esm/utils/isExports.js +0 -22
- package/esm/utils/isExports.js.map +0 -1
- package/esm/utils/isGlobal.js +0 -6
- package/esm/utils/isGlobal.js.map +0 -1
- package/esm/utils/isNodePath.js +0 -4
- package/esm/utils/isNodePath.js.map +0 -1
- package/esm/utils/isRemoved.js +0 -46
- package/esm/utils/isRemoved.js.map +0 -1
- package/esm/utils/isRequire.js +0 -13
- package/esm/utils/isRequire.js.map +0 -1
- package/esm/utils/isTypedNode.js +0 -6
- package/esm/utils/isTypedNode.js.map +0 -1
- package/esm/utils/isUnnecessaryReactCall.js +0 -72
- package/esm/utils/isUnnecessaryReactCall.js.map +0 -1
- package/esm/utils/removeDangerousCode.js +0 -276
- package/esm/utils/removeDangerousCode.js.map +0 -1
- package/esm/utils/replaceImportMetaEnv.js +0 -44
- package/esm/utils/replaceImportMetaEnv.js.map +0 -1
- package/esm/utils/scopeHelpers.js +0 -527
- package/esm/utils/scopeHelpers.js.map +0 -1
- package/esm/utils/traversalCache.js +0 -23
- package/esm/utils/traversalCache.js.map +0 -1
- package/esm/utils/unwrapExpression.js +0 -18
- package/esm/utils/unwrapExpression.js.map +0 -1
- package/esm/utils/unwrapSequence.js +0 -14
- package/esm/utils/unwrapSequence.js.map +0 -1
- package/esm/utils/valueToLiteral.js +0 -59
- package/esm/utils/valueToLiteral.js.map +0 -1
- package/esm/utils/visitors/JSXElementsRemover.js +0 -51
- package/esm/utils/visitors/JSXElementsRemover.js.map +0 -1
- package/lib/babel.js +0 -2
- package/lib/babel.js.map +0 -1
- package/lib/cache.js +0 -308
- package/lib/cache.js.map +0 -1
- package/lib/debug/fileReporter.js +0 -153
- package/lib/debug/fileReporter.js.map +0 -1
- package/lib/evaluators/index.js +0 -20
- package/lib/evaluators/index.js.map +0 -1
- package/lib/index.js +0 -257
- package/lib/index.js.map +0 -1
- package/lib/module.js +0 -552
- package/lib/module.js.map +0 -1
- package/lib/options/buildOptions.js +0 -176
- package/lib/options/buildOptions.js.map +0 -1
- package/lib/options/buildOptions.test.js +0 -141
- package/lib/options/buildOptions.test.js.map +0 -1
- package/lib/options/loadBabelOptions.js +0 -31
- package/lib/options/loadBabelOptions.js.map +0 -1
- package/lib/plugins/babel-transform.js +0 -60
- package/lib/plugins/babel-transform.js.map +0 -1
- package/lib/plugins/collector.js +0 -70
- package/lib/plugins/collector.js.map +0 -1
- package/lib/plugins/dynamic-import.js +0 -61
- package/lib/plugins/dynamic-import.js.map +0 -1
- package/lib/plugins/preeval.js +0 -81
- package/lib/plugins/preeval.js.map +0 -1
- package/lib/plugins/shaker.js +0 -691
- package/lib/plugins/shaker.js.map +0 -1
- package/lib/shaker.js +0 -95
- package/lib/shaker.js.map +0 -1
- package/lib/transform/BaseEntrypoint.js +0 -179
- package/lib/transform/BaseEntrypoint.js.map +0 -1
- package/lib/transform/Entrypoint.helpers.js +0 -279
- package/lib/transform/Entrypoint.helpers.js.map +0 -1
- package/lib/transform/Entrypoint.js +0 -289
- package/lib/transform/Entrypoint.js.map +0 -1
- package/lib/transform/Entrypoint.types.js +0 -2
- package/lib/transform/Entrypoint.types.js.map +0 -1
- package/lib/transform/EvaluatedEntrypoint.js +0 -13
- package/lib/transform/EvaluatedEntrypoint.js.map +0 -1
- package/lib/transform/actions/AbortError.js +0 -16
- package/lib/transform/actions/AbortError.js.map +0 -1
- package/lib/transform/actions/BaseAction.js +0 -150
- package/lib/transform/actions/BaseAction.js.map +0 -1
- package/lib/transform/actions/UnprocessedEntrypointError.js +0 -16
- package/lib/transform/actions/UnprocessedEntrypointError.js.map +0 -1
- package/lib/transform/actions/actionRunner.js +0 -82
- package/lib/transform/actions/actionRunner.js.map +0 -1
- package/lib/transform/actions/types.js +0 -2
- package/lib/transform/actions/types.js.map +0 -1
- package/lib/transform/barrelManifest.js +0 -300
- package/lib/transform/barrelManifest.js.map +0 -1
- package/lib/transform/generators/baseProcessingHandlers.js +0 -27
- package/lib/transform/generators/baseProcessingHandlers.js.map +0 -1
- package/lib/transform/generators/collect.js +0 -66
- package/lib/transform/generators/collect.js.map +0 -1
- package/lib/transform/generators/createStylisPreprocessor.js +0 -372
- package/lib/transform/generators/createStylisPreprocessor.js.map +0 -1
- package/lib/transform/generators/evalFile.js +0 -57
- package/lib/transform/generators/evalFile.js.map +0 -1
- package/lib/transform/generators/explodeReexports.js +0 -71
- package/lib/transform/generators/explodeReexports.js.map +0 -1
- package/lib/transform/generators/extract.js +0 -102
- package/lib/transform/generators/extract.js.map +0 -1
- package/lib/transform/generators/getExports.js +0 -85
- package/lib/transform/generators/getExports.js.map +0 -1
- package/lib/transform/generators/index.js +0 -19
- package/lib/transform/generators/index.js.map +0 -1
- package/lib/transform/generators/processEntrypoint.js +0 -76
- package/lib/transform/generators/processEntrypoint.js.map +0 -1
- package/lib/transform/generators/processImports.js +0 -82
- package/lib/transform/generators/processImports.js.map +0 -1
- package/lib/transform/generators/resolveImports.js +0 -221
- package/lib/transform/generators/resolveImports.js.map +0 -1
- package/lib/transform/generators/rewriteBarrelImports.js +0 -743
- package/lib/transform/generators/rewriteBarrelImports.js.map +0 -1
- package/lib/transform/generators/transform.js +0 -272
- package/lib/transform/generators/transform.js.map +0 -1
- package/lib/transform/generators/workflow.js +0 -90
- package/lib/transform/generators/workflow.js.map +0 -1
- package/lib/transform/helpers/loadWywOptions.js +0 -87
- package/lib/transform/helpers/loadWywOptions.js.map +0 -1
- package/lib/transform/helpers/withDefaultServices.js +0 -31
- package/lib/transform/helpers/withDefaultServices.js.map +0 -1
- package/lib/transform/isStaticallyEvaluatableModule.js +0 -159
- package/lib/transform/isStaticallyEvaluatableModule.js.map +0 -1
- package/lib/transform/rootLog.js +0 -9
- package/lib/transform/rootLog.js.map +0 -1
- package/lib/transform/types.js +0 -8
- package/lib/transform/types.js.map +0 -1
- package/lib/transform.js +0 -160
- package/lib/transform.js.map +0 -1
- package/lib/types.js +0 -2
- package/lib/types.js.map +0 -1
- package/lib/utils/EventEmitter.js +0 -61
- package/lib/utils/EventEmitter.js.map +0 -1
- package/lib/utils/ShakerMetadata.js +0 -9
- package/lib/utils/ShakerMetadata.js.map +0 -1
- package/lib/utils/TransformMetadata.js +0 -19
- package/lib/utils/TransformMetadata.js.map +0 -1
- package/lib/utils/addIdentifierToWywPreval.js +0 -75
- package/lib/utils/addIdentifierToWywPreval.js.map +0 -1
- package/lib/utils/collectExportsAndImports.js +0 -1173
- package/lib/utils/collectExportsAndImports.js.map +0 -1
- package/lib/utils/collectTemplateDependencies.js +0 -242
- package/lib/utils/collectTemplateDependencies.js.map +0 -1
- package/lib/utils/createId.js +0 -13
- package/lib/utils/createId.js.map +0 -1
- package/lib/utils/dispose-polyfill.js +0 -9
- package/lib/utils/dispose-polyfill.js.map +0 -1
- package/lib/utils/findIdentifiers.js +0 -73
- package/lib/utils/findIdentifiers.js.map +0 -1
- package/lib/utils/getConstantStringValue.js +0 -66
- package/lib/utils/getConstantStringValue.js.map +0 -1
- package/lib/utils/getFileIdx.js +0 -16
- package/lib/utils/getFileIdx.js.map +0 -1
- package/lib/utils/getMemberExpressionPropertyName.js +0 -18
- package/lib/utils/getMemberExpressionPropertyName.js.map +0 -1
- package/lib/utils/getPluginKey.js +0 -21
- package/lib/utils/getPluginKey.js.map +0 -1
- package/lib/utils/getScope.js +0 -12
- package/lib/utils/getScope.js.map +0 -1
- package/lib/utils/getSource.js +0 -24
- package/lib/utils/getSource.js.map +0 -1
- package/lib/utils/getTagProcessor.js +0 -424
- package/lib/utils/getTagProcessor.js.map +0 -1
- package/lib/utils/getVisitorKeys.js +0 -11
- package/lib/utils/getVisitorKeys.js.map +0 -1
- package/lib/utils/hasWywPreval.js +0 -13
- package/lib/utils/hasWywPreval.js.map +0 -1
- package/lib/utils/importOverrides.js +0 -119
- package/lib/utils/importOverrides.js.map +0 -1
- package/lib/utils/isExports.js +0 -27
- package/lib/utils/isExports.js.map +0 -1
- package/lib/utils/isGlobal.js +0 -13
- package/lib/utils/isGlobal.js.map +0 -1
- package/lib/utils/isNode.js +0 -9
- package/lib/utils/isNode.js.map +0 -1
- package/lib/utils/isNodePath.js +0 -10
- package/lib/utils/isNodePath.js.map +0 -1
- package/lib/utils/isNotNull.js +0 -10
- package/lib/utils/isNotNull.js.map +0 -1
- package/lib/utils/isRemoved.js +0 -52
- package/lib/utils/isRemoved.js.map +0 -1
- package/lib/utils/isRequire.js +0 -18
- package/lib/utils/isRequire.js.map +0 -1
- package/lib/utils/isSerializable.js +0 -19
- package/lib/utils/isSerializable.js.map +0 -1
- package/lib/utils/isTypedNode.js +0 -13
- package/lib/utils/isTypedNode.js.map +0 -1
- package/lib/utils/isUnnecessaryReactCall.js +0 -81
- package/lib/utils/isUnnecessaryReactCall.js.map +0 -1
- package/lib/utils/parseRequest.js +0 -37
- package/lib/utils/parseRequest.js.map +0 -1
- package/lib/utils/peek.js +0 -9
- package/lib/utils/peek.js.map +0 -1
- package/lib/utils/removeDangerousCode.js +0 -284
- package/lib/utils/removeDangerousCode.js.map +0 -1
- package/lib/utils/replaceImportMetaEnv.js +0 -50
- package/lib/utils/replaceImportMetaEnv.js.map +0 -1
- package/lib/utils/scopeHelpers.js +0 -557
- package/lib/utils/scopeHelpers.js.map +0 -1
- package/lib/utils/traversalCache.js +0 -31
- package/lib/utils/traversalCache.js.map +0 -1
- package/lib/utils/unwrapExpression.js +0 -25
- package/lib/utils/unwrapExpression.js.map +0 -1
- package/lib/utils/unwrapSequence.js +0 -20
- package/lib/utils/unwrapSequence.js.map +0 -1
- package/lib/utils/valueToLiteral.js +0 -65
- package/lib/utils/valueToLiteral.js.map +0 -1
- package/lib/utils/visitors/JSXElementsRemover.js +0 -57
- package/lib/utils/visitors/JSXElementsRemover.js.map +0 -1
- package/lib/vm/createVmContext.js +0 -166
- package/lib/vm/createVmContext.js.map +0 -1
- package/lib/vm/process.js +0 -38
- package/lib/vm/process.js.map +0 -1
- package/types/babel.d.ts +0 -2
- package/types/babel.js +0 -2
- package/types/options/buildOptions.d.ts +0 -6
- package/types/options/buildOptions.js +0 -178
- package/types/options/loadBabelOptions.d.ts +0 -3
- package/types/options/loadBabelOptions.js +0 -26
- package/types/plugins/babel-transform.d.ts +0 -4
- package/types/plugins/babel-transform.js +0 -49
- package/types/plugins/collector.d.ts +0 -20
- package/types/plugins/collector.js +0 -62
- package/types/plugins/dynamic-import.d.ts +0 -6
- package/types/plugins/dynamic-import.js +0 -60
- package/types/plugins/preeval.d.ts +0 -16
- package/types/plugins/preeval.js +0 -69
- package/types/plugins/shaker.d.ts +0 -14
- package/types/plugins/shaker.js +0 -724
- package/types/transform/generators/explodeReexports.d.ts +0 -7
- package/types/transform/generators/explodeReexports.js +0 -65
- package/types/utils/addIdentifierToWywPreval.d.ts +0 -4
- package/types/utils/addIdentifierToWywPreval.js +0 -74
- package/types/utils/collectExportsAndImports.d.ts +0 -31
- package/types/utils/collectExportsAndImports.js +0 -1147
- package/types/utils/collectTemplateDependencies.d.ts +0 -17
- package/types/utils/collectTemplateDependencies.js +0 -220
- package/types/utils/createId.d.ts +0 -2
- package/types/utils/createId.js +0 -9
- package/types/utils/findIdentifiers.d.ts +0 -6
- package/types/utils/findIdentifiers.js +0 -67
- package/types/utils/getConstantStringValue.d.ts +0 -2
- package/types/utils/getConstantStringValue.js +0 -94
- package/types/utils/getMemberExpressionPropertyName.d.ts +0 -2
- package/types/utils/getMemberExpressionPropertyName.js +0 -46
- package/types/utils/getScope.d.ts +0 -2
- package/types/utils/getScope.js +0 -10
- package/types/utils/getSource.d.ts +0 -2
- package/types/utils/getSource.js +0 -22
- package/types/utils/getTagProcessor.d.ts +0 -13
- package/types/utils/getTagProcessor.js +0 -411
- package/types/utils/isExports.d.ts +0 -6
- package/types/utils/isExports.js +0 -19
- package/types/utils/isGlobal.d.ts +0 -2
- package/types/utils/isGlobal.js +0 -9
- package/types/utils/isNodePath.d.ts +0 -3
- package/types/utils/isNodePath.js +0 -6
- package/types/utils/isRemoved.d.ts +0 -5
- package/types/utils/isRemoved.js +0 -41
- package/types/utils/isRequire.d.ts +0 -6
- package/types/utils/isRequire.js +0 -14
- package/types/utils/isTypedNode.d.ts +0 -5
- package/types/utils/isTypedNode.js +0 -9
- package/types/utils/isUnnecessaryReactCall.d.ts +0 -3
- package/types/utils/isUnnecessaryReactCall.js +0 -75
- package/types/utils/removeDangerousCode.d.ts +0 -4
- package/types/utils/removeDangerousCode.js +0 -326
- package/types/utils/replaceImportMetaEnv.d.ts +0 -3
- package/types/utils/replaceImportMetaEnv.js +0 -39
- package/types/utils/scopeHelpers.d.ts +0 -12
- package/types/utils/scopeHelpers.js +0 -580
- package/types/utils/traversalCache.d.ts +0 -4
- package/types/utils/traversalCache.js +0 -27
- package/types/utils/unwrapExpression.d.ts +0 -2
- package/types/utils/unwrapExpression.js +0 -57
- package/types/utils/unwrapSequence.d.ts +0 -8
- package/types/utils/unwrapSequence.js +0 -16
- package/types/utils/valueToLiteral.d.ts +0 -3
- package/types/utils/valueToLiteral.js +0 -63
- package/types/utils/visitors/JSXElementsRemover.d.ts +0 -3
- package/types/utils/visitors/JSXElementsRemover.js +0 -51
package/esm/plugins/shaker.js
DELETED
|
@@ -1,680 +0,0 @@
|
|
|
1
|
-
import pathLib from 'path';
|
|
2
|
-
import { logger, syncResolve } from '@wyw-in-js/shared';
|
|
3
|
-
import { collectExportsAndImports, sideEffectImport } from '../utils/collectExportsAndImports';
|
|
4
|
-
import { getFileIdx } from '../utils/getFileIdx';
|
|
5
|
-
import { isRemoved } from '../utils/isRemoved';
|
|
6
|
-
import { applyAction, dereference, findActionForNode, reference, removeWithRelated } from '../utils/scopeHelpers';
|
|
7
|
-
import { invalidateTraversalCache } from '../utils/traversalCache';
|
|
8
|
-
import { stripQueryAndHash } from '../utils/parseRequest';
|
|
9
|
-
import { getImportOverride, toImportKey } from '../utils/importOverrides';
|
|
10
|
-
const warnedDynamicImportFiles = new Set();
|
|
11
|
-
function getNonParamBinding(exportPath, name) {
|
|
12
|
-
const binding = exportPath.scope.getBinding(name);
|
|
13
|
-
if (binding && binding.kind !== 'param') {
|
|
14
|
-
return binding;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
// When `exportPath` is inside a function scope, a parameter can shadow
|
|
18
|
-
// the actual export binding (e.g. `export function fallback(fallback) {}`).
|
|
19
|
-
// In such cases we need the binding from the declaration scope.
|
|
20
|
-
return exportPath.scope.parent?.getBinding(name) ?? binding;
|
|
21
|
-
}
|
|
22
|
-
function getBindingForExport(exportPath) {
|
|
23
|
-
if (exportPath.isIdentifier()) {
|
|
24
|
-
return getNonParamBinding(exportPath, exportPath.node.name);
|
|
25
|
-
}
|
|
26
|
-
const variableDeclarator = exportPath.findParent(p => p.isVariableDeclarator());
|
|
27
|
-
if (variableDeclarator) {
|
|
28
|
-
const id = variableDeclarator.get('id');
|
|
29
|
-
if (id.isIdentifier()) {
|
|
30
|
-
return variableDeclarator.scope.getBinding(id.node.name);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
if (exportPath.isAssignmentExpression()) {
|
|
34
|
-
const left = exportPath.get('left');
|
|
35
|
-
if (left.isIdentifier()) {
|
|
36
|
-
return getNonParamBinding(exportPath, left.node.name);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
if (exportPath.isFunctionDeclaration() || exportPath.isClassDeclaration()) {
|
|
40
|
-
const {
|
|
41
|
-
id
|
|
42
|
-
} = exportPath.node;
|
|
43
|
-
if (!id) {
|
|
44
|
-
// `export default function() {}` / `export default class {}` (anonymous)
|
|
45
|
-
return undefined;
|
|
46
|
-
}
|
|
47
|
-
return getNonParamBinding(exportPath, id.name);
|
|
48
|
-
}
|
|
49
|
-
if (exportPath.isTSEnumDeclaration()) {
|
|
50
|
-
return getNonParamBinding(exportPath, exportPath.node.id.name);
|
|
51
|
-
}
|
|
52
|
-
return undefined;
|
|
53
|
-
}
|
|
54
|
-
const withoutRemoved = items => items.filter(({
|
|
55
|
-
local
|
|
56
|
-
}) => !isRemoved(local));
|
|
57
|
-
function rearrangeExports({
|
|
58
|
-
types: t
|
|
59
|
-
}, root, exportRefs, exports) {
|
|
60
|
-
const rearranged = {
|
|
61
|
-
...exports
|
|
62
|
-
};
|
|
63
|
-
const rootScope = root.scope;
|
|
64
|
-
exportRefs.forEach((refs, name) => {
|
|
65
|
-
if (refs.length <= 1) {
|
|
66
|
-
if (refs.length === 1) {
|
|
67
|
-
// Maybe exports is assigned to another variable?
|
|
68
|
-
const declarator = refs[0].findParent(p => p.isVariableDeclarator());
|
|
69
|
-
if (!declarator) {
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
} else {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
const uid = rootScope.generateUid(name);
|
|
77
|
-
// Define variable in the beginning
|
|
78
|
-
const [declaration] = root.unshiftContainer('body', [t.variableDeclaration('var', [t.variableDeclarator(t.identifier(uid))])]);
|
|
79
|
-
rootScope.registerDeclaration(declaration);
|
|
80
|
-
const constantViolations = [];
|
|
81
|
-
// Replace every reference with defined variable
|
|
82
|
-
refs.forEach(ref => {
|
|
83
|
-
const [replaced] = ref.replaceWith(t.identifier(uid));
|
|
84
|
-
if (replaced.isBindingIdentifier()) {
|
|
85
|
-
constantViolations.push(replaced);
|
|
86
|
-
} else {
|
|
87
|
-
reference(replaced);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
constantViolations.forEach(id => {
|
|
91
|
-
rootScope.registerConstantViolation(id);
|
|
92
|
-
});
|
|
93
|
-
const assigmentToExport = t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.identifier('exports'), t.identifier(name)), t.identifier(uid)));
|
|
94
|
-
|
|
95
|
-
// export.foo = _foo will be inserted either after the last _foo assigment or in the end of the file
|
|
96
|
-
const body = root.get('body');
|
|
97
|
-
const lastViolation = constantViolations[constantViolations.length - 1] ?? body[body.length - 1];
|
|
98
|
-
const pathInRoot = root.get('body').find(n => lastViolation.isDescendant(n));
|
|
99
|
-
const [pushed] = pathInRoot.insertAfter(assigmentToExport);
|
|
100
|
-
const local = pushed.get('expression.right');
|
|
101
|
-
reference(local);
|
|
102
|
-
rearranged[name] = local;
|
|
103
|
-
});
|
|
104
|
-
return rearranged;
|
|
105
|
-
}
|
|
106
|
-
const getPropertyAssignmentStatement = (ref, bindingName) => {
|
|
107
|
-
const assignment = ref.findParent(parent => parent.isAssignmentExpression());
|
|
108
|
-
if (!assignment?.isAssignmentExpression()) return null;
|
|
109
|
-
const left = assignment.get('left');
|
|
110
|
-
if (!left.isMemberExpression()) return null;
|
|
111
|
-
const object = left.get('object');
|
|
112
|
-
if (!object.isIdentifier({
|
|
113
|
-
name: bindingName
|
|
114
|
-
})) return null;
|
|
115
|
-
const statement = assignment.parentPath;
|
|
116
|
-
return statement?.isExpressionStatement() ? statement : null;
|
|
117
|
-
};
|
|
118
|
-
const isWithinAliveExport = (ref, aliveExports) => [...aliveExports].some(alive => alive === ref || alive.isAncestor(ref));
|
|
119
|
-
function getExportPathsForVariableDeclaration(declaration, exports) {
|
|
120
|
-
const exportPaths = [];
|
|
121
|
-
declaration.get('declarations').forEach(declarator => {
|
|
122
|
-
Object.keys(declarator.getOuterBindingIdentifiers()).forEach(name => {
|
|
123
|
-
const exportPath = exports[name];
|
|
124
|
-
if (exportPath && !exportPaths.includes(exportPath)) {
|
|
125
|
-
exportPaths.push(exportPath);
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
});
|
|
129
|
-
return exportPaths;
|
|
130
|
-
}
|
|
131
|
-
function getDeclaratorExportLiveness(declarator, exports, aliveExports) {
|
|
132
|
-
const bindingNames = Object.keys(declarator.getOuterBindingIdentifiers());
|
|
133
|
-
if (bindingNames.length === 0) {
|
|
134
|
-
return null;
|
|
135
|
-
}
|
|
136
|
-
let liveness = null;
|
|
137
|
-
for (const name of bindingNames) {
|
|
138
|
-
const exportPath = exports[name];
|
|
139
|
-
if (!exportPath) {
|
|
140
|
-
return null;
|
|
141
|
-
}
|
|
142
|
-
const isAlive = aliveExports.has(exportPath);
|
|
143
|
-
if (liveness === null) {
|
|
144
|
-
liveness = isAlive;
|
|
145
|
-
} else if (liveness !== isAlive) {
|
|
146
|
-
return null;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return liveness;
|
|
150
|
-
}
|
|
151
|
-
function hasRuntimeReferencesToEnum(path) {
|
|
152
|
-
if (!path.isTSEnumDeclaration()) {
|
|
153
|
-
return false;
|
|
154
|
-
}
|
|
155
|
-
const enumId = path.get('id');
|
|
156
|
-
const bindingName = enumId.node.name;
|
|
157
|
-
const program = path.scope.getProgramParent().path;
|
|
158
|
-
let hasReference = false;
|
|
159
|
-
program.traverse({
|
|
160
|
-
Identifier(identifier) {
|
|
161
|
-
if (hasReference || identifier.node.name !== bindingName) {
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
if (identifier.findParent(ancestor => ancestor === path)) {
|
|
165
|
-
return;
|
|
166
|
-
}
|
|
167
|
-
if (identifier.find(ancestor => ancestor.isTSType() || ancestor.isFlowType())) {
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
|
-
if (!identifier.isReferencedIdentifier()) {
|
|
171
|
-
return;
|
|
172
|
-
}
|
|
173
|
-
const localBinding = identifier.scope.getBinding(bindingName);
|
|
174
|
-
if (localBinding && localBinding.path !== enumId) {
|
|
175
|
-
return;
|
|
176
|
-
}
|
|
177
|
-
hasReference = true;
|
|
178
|
-
identifier.stop();
|
|
179
|
-
}
|
|
180
|
-
});
|
|
181
|
-
return hasReference;
|
|
182
|
-
}
|
|
183
|
-
function stripExportKeepDeclaration(path, exports, aliveExports, t) {
|
|
184
|
-
const exportDeclaration = path.findParent(p => p.isExportNamedDeclaration());
|
|
185
|
-
if (!exportDeclaration) return null;
|
|
186
|
-
const declaration = exportDeclaration.get('declaration');
|
|
187
|
-
if (!declaration.node) return null;
|
|
188
|
-
if (declaration.isFunctionDeclaration() || declaration.isClassDeclaration() || declaration.isTSEnumDeclaration()) {
|
|
189
|
-
exportDeclaration.replaceWith(t.cloneNode(declaration.node, true));
|
|
190
|
-
return [path];
|
|
191
|
-
}
|
|
192
|
-
if (declaration.isVariableDeclaration()) {
|
|
193
|
-
const declarators = declaration.get('declarations');
|
|
194
|
-
const staleExportPaths = getExportPathsForVariableDeclaration(declaration, exports);
|
|
195
|
-
if (declarators.length === 1) {
|
|
196
|
-
exportDeclaration.replaceWith(t.cloneNode(declaration.node, true));
|
|
197
|
-
return staleExportPaths.length > 0 ? staleExportPaths : [path];
|
|
198
|
-
}
|
|
199
|
-
const segments = [];
|
|
200
|
-
for (const declarator of declarators) {
|
|
201
|
-
const isAlive = getDeclaratorExportLiveness(declarator, exports, aliveExports);
|
|
202
|
-
if (isAlive === null) {
|
|
203
|
-
return null;
|
|
204
|
-
}
|
|
205
|
-
const clonedDeclarator = t.cloneNode(declarator.node, true);
|
|
206
|
-
const currentSegment = segments[segments.length - 1];
|
|
207
|
-
if (currentSegment && currentSegment.alive === isAlive) {
|
|
208
|
-
currentSegment.declarators.push(clonedDeclarator);
|
|
209
|
-
} else {
|
|
210
|
-
segments.push({
|
|
211
|
-
alive: isAlive,
|
|
212
|
-
declarators: [clonedDeclarator]
|
|
213
|
-
});
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
exportDeclaration.replaceWithMultiple(segments.map(({
|
|
217
|
-
alive,
|
|
218
|
-
declarators: groupedDeclarators
|
|
219
|
-
}) => {
|
|
220
|
-
const groupedDeclaration = t.variableDeclaration(declaration.node.kind, groupedDeclarators);
|
|
221
|
-
return alive ? t.exportNamedDeclaration(groupedDeclaration, []) : groupedDeclaration;
|
|
222
|
-
}));
|
|
223
|
-
return staleExportPaths.length > 0 ? staleExportPaths : [path];
|
|
224
|
-
}
|
|
225
|
-
return null;
|
|
226
|
-
}
|
|
227
|
-
export default function shakerPlugin(babel, {
|
|
228
|
-
keepSideEffects = false,
|
|
229
|
-
ifUnknownExport = 'skip-shaking',
|
|
230
|
-
importOverrides,
|
|
231
|
-
onlyExports,
|
|
232
|
-
root
|
|
233
|
-
}) {
|
|
234
|
-
const shakerLogger = logger.extend('shaker');
|
|
235
|
-
return {
|
|
236
|
-
name: '@wyw-in-js/transform/shaker',
|
|
237
|
-
pre(file) {
|
|
238
|
-
this.filename = file.opts.filename;
|
|
239
|
-
const log = shakerLogger.extend(getFileIdx(this.filename));
|
|
240
|
-
log('start', `${this.filename}, onlyExports: ${onlyExports.join(',')}`);
|
|
241
|
-
const onlyExportsSet = new Set(onlyExports);
|
|
242
|
-
const shouldKeepOverride = override => !!override && ('mock' in override || 'noShake' in override);
|
|
243
|
-
const hasImportOverride = (() => {
|
|
244
|
-
if (!importOverrides || Object.keys(importOverrides).length === 0) {
|
|
245
|
-
return () => false;
|
|
246
|
-
}
|
|
247
|
-
const cache = new Map();
|
|
248
|
-
return source => {
|
|
249
|
-
const cached = cache.get(source);
|
|
250
|
-
if (cached !== undefined) {
|
|
251
|
-
return cached;
|
|
252
|
-
}
|
|
253
|
-
const strippedSource = stripQueryAndHash(source);
|
|
254
|
-
const direct = getImportOverride(importOverrides, source) ?? (strippedSource !== source ? getImportOverride(importOverrides, strippedSource) : null);
|
|
255
|
-
if (direct) {
|
|
256
|
-
const result = shouldKeepOverride(direct);
|
|
257
|
-
cache.set(source, result);
|
|
258
|
-
return result;
|
|
259
|
-
}
|
|
260
|
-
const isFileImport = strippedSource.startsWith('.') || pathLib.isAbsolute(strippedSource);
|
|
261
|
-
if (!isFileImport) {
|
|
262
|
-
cache.set(source, false);
|
|
263
|
-
return false;
|
|
264
|
-
}
|
|
265
|
-
try {
|
|
266
|
-
const resolved = syncResolve(strippedSource, this.filename, []);
|
|
267
|
-
const {
|
|
268
|
-
key
|
|
269
|
-
} = toImportKey({
|
|
270
|
-
source: strippedSource,
|
|
271
|
-
resolved,
|
|
272
|
-
root
|
|
273
|
-
});
|
|
274
|
-
const override = getImportOverride(importOverrides, key);
|
|
275
|
-
const result = shouldKeepOverride(override);
|
|
276
|
-
cache.set(source, result);
|
|
277
|
-
return result;
|
|
278
|
-
} catch {
|
|
279
|
-
cache.set(source, false);
|
|
280
|
-
return false;
|
|
281
|
-
}
|
|
282
|
-
};
|
|
283
|
-
})();
|
|
284
|
-
const collected = collectExportsAndImports(file.path);
|
|
285
|
-
const {
|
|
286
|
-
imports
|
|
287
|
-
} = collected;
|
|
288
|
-
const sideEffectImports = imports.filter(sideEffectImport);
|
|
289
|
-
log('import-and-exports', [`imports: ${imports.length} (side-effects: ${sideEffectImports.length})`, `exports: ${Object.values(collected.exports).length}`, `reexports: ${collected.reexports.length}`].join(', '));
|
|
290
|
-
|
|
291
|
-
// We cannot just throw out exports if they are referred in the code
|
|
292
|
-
// Let's dome some replacements
|
|
293
|
-
const exports = rearrangeExports(babel, file.path, collected.exportRefs, collected.exports);
|
|
294
|
-
Object.values(exports).forEach(local => {
|
|
295
|
-
if (local.isAssignmentExpression()) {
|
|
296
|
-
const left = local.get('left');
|
|
297
|
-
if (left.isIdentifier()) {
|
|
298
|
-
// For some reason babel does not mark id in AssignmentExpression as a reference
|
|
299
|
-
// So we need to do it manually
|
|
300
|
-
reference(left, left, true);
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
});
|
|
304
|
-
const hasWywPreval = exports.__wywPreval !== undefined;
|
|
305
|
-
const hasDefault = exports.default !== undefined;
|
|
306
|
-
|
|
307
|
-
// If __wywPreval is not exported, we can remove it from onlyExports
|
|
308
|
-
if (onlyExportsSet.has('__wywPreval') && !hasWywPreval) {
|
|
309
|
-
onlyExportsSet.delete('__wywPreval');
|
|
310
|
-
}
|
|
311
|
-
if (onlyExportsSet.size === 0) {
|
|
312
|
-
// Fast-lane: if there are no exports to keep, we can just shake out the whole file
|
|
313
|
-
this.imports = [];
|
|
314
|
-
this.exports = {};
|
|
315
|
-
this.reexports = [];
|
|
316
|
-
this.deadExports = Object.keys(exports);
|
|
317
|
-
file.path.get('body').forEach(p => {
|
|
318
|
-
p.remove();
|
|
319
|
-
});
|
|
320
|
-
return;
|
|
321
|
-
}
|
|
322
|
-
const importedAsSideEffect = onlyExportsSet.has('side-effect');
|
|
323
|
-
onlyExportsSet.delete('side-effect');
|
|
324
|
-
|
|
325
|
-
// Hackaround for packages which include a 'default' export without specifying __esModule; such packages cannot be
|
|
326
|
-
// shaken as they will break interopRequireDefault babel helper
|
|
327
|
-
// See example in shaker-plugin.test.ts
|
|
328
|
-
// Real-world example was found in preact/compat npm package
|
|
329
|
-
if (onlyExportsSet.has('default') && hasDefault && !collected.isEsModule) {
|
|
330
|
-
this.imports = imports;
|
|
331
|
-
this.exports = exports;
|
|
332
|
-
this.reexports = collected.reexports;
|
|
333
|
-
this.deadExports = [];
|
|
334
|
-
return;
|
|
335
|
-
}
|
|
336
|
-
if (!onlyExportsSet.has('*')) {
|
|
337
|
-
// __esModule should be kept alive
|
|
338
|
-
onlyExportsSet.add('__esModule');
|
|
339
|
-
const aliveExports = new Set();
|
|
340
|
-
const importNames = imports.map(({
|
|
341
|
-
imported
|
|
342
|
-
}) => imported);
|
|
343
|
-
Object.entries(exports).forEach(([exported, local]) => {
|
|
344
|
-
if (onlyExportsSet.has(exported)) {
|
|
345
|
-
aliveExports.add(local);
|
|
346
|
-
return;
|
|
347
|
-
}
|
|
348
|
-
const binding = local.isIdentifier() && local.scope.getBinding(local.node.name);
|
|
349
|
-
if (binding && (binding.path.isImportSpecifier() || binding.path.isImportDefaultSpecifier() || binding.path.isImportNamespaceSpecifier()) && importNames.includes(local.node.name || '')) {
|
|
350
|
-
aliveExports.add(local);
|
|
351
|
-
return;
|
|
352
|
-
}
|
|
353
|
-
if ([...aliveExports].some(alive => alive === local)) {
|
|
354
|
-
// It's possible to export multiple values from a single variable initializer, e.g
|
|
355
|
-
// export const { foo, bar } = baz();
|
|
356
|
-
// We need to treat all of them as used if any of them are used, since otherwise
|
|
357
|
-
// we'll attempt to delete the baz() call
|
|
358
|
-
aliveExports.add(local);
|
|
359
|
-
}
|
|
360
|
-
});
|
|
361
|
-
collected.reexports.forEach(exp => {
|
|
362
|
-
if (onlyExportsSet.has(exp.exported)) {
|
|
363
|
-
aliveExports.add(exp.local);
|
|
364
|
-
}
|
|
365
|
-
});
|
|
366
|
-
const exportToPath = new Map();
|
|
367
|
-
Object.entries(exports).forEach(([exported, local]) => {
|
|
368
|
-
exportToPath.set(exported, local);
|
|
369
|
-
});
|
|
370
|
-
collected.reexports.forEach(exp => {
|
|
371
|
-
exportToPath.set(exp.exported, exp.local);
|
|
372
|
-
});
|
|
373
|
-
const notFoundExports = [...onlyExportsSet].filter(exp => exp !== '__esModule' && !aliveExports.has(exportToPath.get(exp)));
|
|
374
|
-
exportToPath.clear();
|
|
375
|
-
const isAllExportsFound = notFoundExports.length === 0;
|
|
376
|
-
if (!isAllExportsFound && ifUnknownExport !== 'ignore') {
|
|
377
|
-
if (ifUnknownExport === 'error') {
|
|
378
|
-
throw new Error(`Unknown export(s) requested: ${onlyExports.join(',')}`);
|
|
379
|
-
}
|
|
380
|
-
if (ifUnknownExport === 'reexport-all') {
|
|
381
|
-
// If there are unknown exports, we have keep alive all re-exports.
|
|
382
|
-
if (exports['*'] !== undefined) {
|
|
383
|
-
aliveExports.add(exports['*']);
|
|
384
|
-
}
|
|
385
|
-
collected.reexports.forEach(exp => {
|
|
386
|
-
if (exp.exported === '*') {
|
|
387
|
-
aliveExports.add(exp.local);
|
|
388
|
-
}
|
|
389
|
-
});
|
|
390
|
-
}
|
|
391
|
-
if (ifUnknownExport === 'skip-shaking') {
|
|
392
|
-
this.imports = imports;
|
|
393
|
-
this.exports = exports;
|
|
394
|
-
this.reexports = collected.reexports;
|
|
395
|
-
this.deadExports = [];
|
|
396
|
-
return;
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
const forDeleting = [...Object.values(exports), ...collected.reexports.map(i => i.local)].filter(exp => !aliveExports.has(exp));
|
|
400
|
-
const forDeletingSet = new Set(forDeleting);
|
|
401
|
-
const queueForDeleting = path => {
|
|
402
|
-
if (isRemoved(path) || forDeletingSet.has(path)) {
|
|
403
|
-
return false;
|
|
404
|
-
}
|
|
405
|
-
forDeletingSet.add(path);
|
|
406
|
-
forDeleting.push(path);
|
|
407
|
-
return true;
|
|
408
|
-
};
|
|
409
|
-
if (!keepSideEffects && !importedAsSideEffect) {
|
|
410
|
-
// Drop side-effect imports for eval-only builds unless they were explicitly requested.
|
|
411
|
-
// This prevents evaluating unrelated runtime code (e.g. Radix) during __wywPreval eval.
|
|
412
|
-
sideEffectImports.forEach(i => {
|
|
413
|
-
if (hasImportOverride(i.source)) {
|
|
414
|
-
return;
|
|
415
|
-
}
|
|
416
|
-
queueForDeleting(i.local);
|
|
417
|
-
});
|
|
418
|
-
}
|
|
419
|
-
const deleted = new Set();
|
|
420
|
-
let dereferenced = [];
|
|
421
|
-
let changed = true;
|
|
422
|
-
while (changed) {
|
|
423
|
-
changed = false;
|
|
424
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
425
|
-
for (const path of forDeleting) {
|
|
426
|
-
if (deleted.has(path)) {
|
|
427
|
-
// eslint-disable-next-line no-continue
|
|
428
|
-
continue;
|
|
429
|
-
}
|
|
430
|
-
const binding = getBindingForExport(path);
|
|
431
|
-
const action = findActionForNode(path);
|
|
432
|
-
const parent = action?.[1];
|
|
433
|
-
const outerReferences = (binding?.referencePaths || []).filter(ref => {
|
|
434
|
-
if (ref === parent || parent?.isAncestor(ref)) {
|
|
435
|
-
return false;
|
|
436
|
-
}
|
|
437
|
-
return !forDeleting.some(candidate => candidate !== path && !isRemoved(candidate) && (candidate === ref || candidate.isAncestor(ref)));
|
|
438
|
-
});
|
|
439
|
-
const bindingName = binding?.identifier.name;
|
|
440
|
-
const removableAssignmentStatements = new Set();
|
|
441
|
-
const removableOuterReferences = outerReferences.filter(ref => {
|
|
442
|
-
if (!bindingName) return false;
|
|
443
|
-
const statement = getPropertyAssignmentStatement(ref, bindingName);
|
|
444
|
-
if (!statement || isWithinAliveExport(statement, aliveExports)) {
|
|
445
|
-
return false;
|
|
446
|
-
}
|
|
447
|
-
removableAssignmentStatements.add(statement);
|
|
448
|
-
return true;
|
|
449
|
-
});
|
|
450
|
-
const blockingReferences = outerReferences.filter(ref => !removableOuterReferences.includes(ref));
|
|
451
|
-
if (blockingReferences.length > 0 && path.isIdentifier()) {
|
|
452
|
-
// Temporary deref it in order to simplify further checks.
|
|
453
|
-
dereference(path);
|
|
454
|
-
dereferenced.push(path);
|
|
455
|
-
}
|
|
456
|
-
const strippedEnum = !deleted.has(path) && hasRuntimeReferencesToEnum(path) ? stripExportKeepDeclaration(path, exports, aliveExports, babel.types) : null;
|
|
457
|
-
if (strippedEnum) {
|
|
458
|
-
strippedEnum.forEach(stalePath => {
|
|
459
|
-
deleted.add(stalePath);
|
|
460
|
-
});
|
|
461
|
-
changed = true;
|
|
462
|
-
// eslint-disable-next-line no-continue
|
|
463
|
-
continue;
|
|
464
|
-
}
|
|
465
|
-
const strippedWithBlocking = !deleted.has(path) && binding && blockingReferences.length > 0 ? stripExportKeepDeclaration(path, exports, aliveExports, babel.types) : null;
|
|
466
|
-
if (strippedWithBlocking) {
|
|
467
|
-
strippedWithBlocking.forEach(stalePath => {
|
|
468
|
-
deleted.add(stalePath);
|
|
469
|
-
});
|
|
470
|
-
changed = true;
|
|
471
|
-
// eslint-disable-next-line no-continue
|
|
472
|
-
continue;
|
|
473
|
-
}
|
|
474
|
-
if (!deleted.has(path) && (!binding || blockingReferences.length === 0)) {
|
|
475
|
-
// For variable declaration exports, `path` is the init expression
|
|
476
|
-
// (not the Identifier). Other forDeleting candidates whose init
|
|
477
|
-
// expressions are ancestors of references to this binding can
|
|
478
|
-
// incorrectly filter them out of outerReferences. Those candidates
|
|
479
|
-
// may later survive via stripExportKeepDeclaration, leaving a
|
|
480
|
-
// dangling reference. Strip the export keyword but keep the
|
|
481
|
-
// declaration so the unreferenced sweep removes it only when dead.
|
|
482
|
-
// This only applies to expression paths (variable init), not
|
|
483
|
-
// Identifiers (function/class declarations) which can't be
|
|
484
|
-
// ancestors of external references.
|
|
485
|
-
const strippedWithoutBlocking = binding && !path.isIdentifier() ? stripExportKeepDeclaration(path, exports, aliveExports, babel.types) : null;
|
|
486
|
-
if (strippedWithoutBlocking) {
|
|
487
|
-
strippedWithoutBlocking.forEach(stalePath => {
|
|
488
|
-
deleted.add(stalePath);
|
|
489
|
-
});
|
|
490
|
-
if (removableAssignmentStatements.size > 0) {
|
|
491
|
-
for (const statement of removableAssignmentStatements) {
|
|
492
|
-
if (queueForDeleting(statement)) {
|
|
493
|
-
changed = true;
|
|
494
|
-
}
|
|
495
|
-
}
|
|
496
|
-
}
|
|
497
|
-
changed = true;
|
|
498
|
-
// eslint-disable-next-line no-continue
|
|
499
|
-
continue;
|
|
500
|
-
}
|
|
501
|
-
if (removableAssignmentStatements.size > 0) {
|
|
502
|
-
for (const statement of removableAssignmentStatements) {
|
|
503
|
-
if (queueForDeleting(statement)) {
|
|
504
|
-
changed = true;
|
|
505
|
-
}
|
|
506
|
-
}
|
|
507
|
-
}
|
|
508
|
-
if (action) {
|
|
509
|
-
applyAction(action);
|
|
510
|
-
} else {
|
|
511
|
-
removeWithRelated([path]);
|
|
512
|
-
}
|
|
513
|
-
deleted.add(path);
|
|
514
|
-
changed = true;
|
|
515
|
-
}
|
|
516
|
-
}
|
|
517
|
-
dereferenced.forEach(path => {
|
|
518
|
-
// If path is still alive, we need to reference it back
|
|
519
|
-
if (!isRemoved(path)) {
|
|
520
|
-
reference(path);
|
|
521
|
-
}
|
|
522
|
-
});
|
|
523
|
-
dereferenced = [];
|
|
524
|
-
|
|
525
|
-
// stripExportKeepDeclaration replaces ExportNamedDeclaration with
|
|
526
|
-
// its declaration, creating new AST nodes. The old scope bindings
|
|
527
|
-
// become stale (pointing at disconnected paths). Recrawl so
|
|
528
|
-
// getAllBindings() returns fresh bindings with correct .referenced.
|
|
529
|
-
file.scope.crawl();
|
|
530
|
-
|
|
531
|
-
// Find and mark for deleting all unreferenced variables
|
|
532
|
-
const unreferenced = Object.values(file.scope.getAllBindings()).filter(i => !i.referenced);
|
|
533
|
-
for (const binding of unreferenced) {
|
|
534
|
-
if (binding.path.isVariableDeclarator()) {
|
|
535
|
-
const id = binding.path.get('id');
|
|
536
|
-
// Skip destructured patterns — removing the declarator would kill
|
|
537
|
-
// sibling bindings that may still be referenced (e.g. export {B}
|
|
538
|
-
// from `const [A, B] = createContext(...)` when only A is dead).
|
|
539
|
-
if (!id.isArrayPattern() && !id.isObjectPattern() && !isRemoved(id) && !forDeletingSet.has(id)) {
|
|
540
|
-
// Drop dead variable declarations, e.g. `const foo = make();` when `foo` is no longer referenced.
|
|
541
|
-
for (const violation of binding.constantViolations) {
|
|
542
|
-
if (queueForDeleting(violation)) {
|
|
543
|
-
changed = true;
|
|
544
|
-
}
|
|
545
|
-
}
|
|
546
|
-
if (queueForDeleting(id)) {
|
|
547
|
-
changed = true;
|
|
548
|
-
}
|
|
549
|
-
}
|
|
550
|
-
}
|
|
551
|
-
|
|
552
|
-
// Drop import specifiers whose bindings lost all references during shaking
|
|
553
|
-
// (e.g. when we keep only __wywPreval and the rest of the module is removed).
|
|
554
|
-
if ((binding.path.isImportSpecifier() || binding.path.isImportDefaultSpecifier() || binding.path.isImportNamespaceSpecifier()) && !isRemoved(binding.path) && !forDeletingSet.has(binding.path)) {
|
|
555
|
-
if (queueForDeleting(binding.path)) {
|
|
556
|
-
changed = true;
|
|
557
|
-
}
|
|
558
|
-
}
|
|
559
|
-
}
|
|
560
|
-
}
|
|
561
|
-
}
|
|
562
|
-
this.imports = withoutRemoved(imports);
|
|
563
|
-
this.exports = {};
|
|
564
|
-
this.deadExports = [];
|
|
565
|
-
Object.entries(exports).forEach(([exported, local]) => {
|
|
566
|
-
if (isRemoved(local)) {
|
|
567
|
-
this.deadExports.push(exported);
|
|
568
|
-
} else {
|
|
569
|
-
this.exports[exported] = local;
|
|
570
|
-
}
|
|
571
|
-
});
|
|
572
|
-
this.reexports = withoutRemoved(collected.reexports);
|
|
573
|
-
},
|
|
574
|
-
visitor: {},
|
|
575
|
-
post(file) {
|
|
576
|
-
const log = shakerLogger.extend(getFileIdx(file.opts.filename));
|
|
577
|
-
const dynamicImportWarningsEnabled = Boolean(process.env.WYW_WARN_DYNAMIC_IMPORTS) && process.env.WYW_WARN_DYNAMIC_IMPORTS !== '0' && process.env.WYW_WARN_DYNAMIC_IMPORTS !== 'false';
|
|
578
|
-
const filename = file.opts.filename;
|
|
579
|
-
if (dynamicImportWarningsEnabled && !warnedDynamicImportFiles.has(filename)) {
|
|
580
|
-
const dynamicImports = this.imports.filter(imp => !sideEffectImport(imp) && imp.type === 'dynamic');
|
|
581
|
-
if (dynamicImports.length > 0) {
|
|
582
|
-
const sources = Array.from(new Set(dynamicImports.map(imp => imp.source))).sort();
|
|
583
|
-
const sourcesToWarn = (() => {
|
|
584
|
-
if (!importOverrides || Object.keys(importOverrides).length === 0) {
|
|
585
|
-
return sources;
|
|
586
|
-
}
|
|
587
|
-
const shouldWarn = source => {
|
|
588
|
-
const strippedSource = stripQueryAndHash(source);
|
|
589
|
-
const direct = getImportOverride(importOverrides, source) ?? (strippedSource !== source ? getImportOverride(importOverrides, strippedSource) : undefined);
|
|
590
|
-
if (direct !== undefined) {
|
|
591
|
-
return false;
|
|
592
|
-
}
|
|
593
|
-
const isFileImport = strippedSource.startsWith('.') || pathLib.isAbsolute(strippedSource);
|
|
594
|
-
if (!isFileImport) {
|
|
595
|
-
return true;
|
|
596
|
-
}
|
|
597
|
-
try {
|
|
598
|
-
const resolved = syncResolve(strippedSource, filename, []);
|
|
599
|
-
const importKey = toImportKey({
|
|
600
|
-
source: strippedSource,
|
|
601
|
-
resolved,
|
|
602
|
-
root
|
|
603
|
-
}).key;
|
|
604
|
-
return getImportOverride(importOverrides, importKey) === undefined;
|
|
605
|
-
} catch {
|
|
606
|
-
return true;
|
|
607
|
-
}
|
|
608
|
-
};
|
|
609
|
-
return sources.filter(shouldWarn);
|
|
610
|
-
})();
|
|
611
|
-
if (sourcesToWarn.length > 0) {
|
|
612
|
-
warnedDynamicImportFiles.add(filename);
|
|
613
|
-
const overrideKeys = sourcesToWarn.map(source => {
|
|
614
|
-
const strippedSource = stripQueryAndHash(source);
|
|
615
|
-
const isFileImport = strippedSource.startsWith('.') || pathLib.isAbsolute(strippedSource);
|
|
616
|
-
if (!isFileImport) {
|
|
617
|
-
return {
|
|
618
|
-
source,
|
|
619
|
-
key: source
|
|
620
|
-
};
|
|
621
|
-
}
|
|
622
|
-
try {
|
|
623
|
-
const resolved = syncResolve(strippedSource, filename, []);
|
|
624
|
-
return {
|
|
625
|
-
source,
|
|
626
|
-
key: toImportKey({
|
|
627
|
-
source: strippedSource,
|
|
628
|
-
resolved,
|
|
629
|
-
root
|
|
630
|
-
}).key
|
|
631
|
-
};
|
|
632
|
-
} catch {
|
|
633
|
-
return {
|
|
634
|
-
source,
|
|
635
|
-
key: strippedSource
|
|
636
|
-
};
|
|
637
|
-
}
|
|
638
|
-
}).filter((item, index, array) => {
|
|
639
|
-
const firstIndexForKey = array.findIndex(i => i.key === item.key);
|
|
640
|
-
return firstIndexForKey === index;
|
|
641
|
-
});
|
|
642
|
-
const warning = [`[wyw-in-js] Dynamic imports reached prepare stage`, ``, `file: ${filename}`, `count: ${sourcesToWarn.length}`, `sources:`, ...sourcesToWarn.map(source => ` - ${source}`), ``, `note: these imports will be resolved/processed even if they are lazy (e.g. React.lazy(() => import(...)))`, ``, `tip: if the imported module is runtime-only or heavy, mock it during evaluation via importOverrides:`, ` importOverrides: {`, ...overrideKeys.map(({
|
|
643
|
-
key,
|
|
644
|
-
source
|
|
645
|
-
}) => ` '${key}': { mock: './path/to/mock' }, // from ${source}`), ` }`, ``, `note: importOverrides affects only build-time evaluation (it does not change your bundler runtime behavior)`].join('\n');
|
|
646
|
-
// eslint-disable-next-line no-console
|
|
647
|
-
console.warn(warning);
|
|
648
|
-
}
|
|
649
|
-
}
|
|
650
|
-
}
|
|
651
|
-
const processedImports = new Set();
|
|
652
|
-
const imports = new Map();
|
|
653
|
-
const addImport = ({
|
|
654
|
-
imported,
|
|
655
|
-
source
|
|
656
|
-
}) => {
|
|
657
|
-
if (processedImports.has(`${source}:${imported}`)) {
|
|
658
|
-
return;
|
|
659
|
-
}
|
|
660
|
-
if (!imports.has(source)) {
|
|
661
|
-
imports.set(source, []);
|
|
662
|
-
}
|
|
663
|
-
if (imported) {
|
|
664
|
-
imports.get(source).push(imported);
|
|
665
|
-
}
|
|
666
|
-
processedImports.add(`${source}:${imported}`);
|
|
667
|
-
};
|
|
668
|
-
this.imports.forEach(addImport);
|
|
669
|
-
this.reexports.forEach(addImport);
|
|
670
|
-
log('end', `remaining imports: %O`, imports);
|
|
671
|
-
|
|
672
|
-
// eslint-disable-next-line no-param-reassign
|
|
673
|
-
file.metadata.wywEvaluator = {
|
|
674
|
-
imports
|
|
675
|
-
};
|
|
676
|
-
invalidateTraversalCache(file.path);
|
|
677
|
-
}
|
|
678
|
-
};
|
|
679
|
-
}
|
|
680
|
-
//# sourceMappingURL=shaker.js.map
|