HarmonyImportSideEffectDependency.js 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. MIT License http://www.opensource.org/licenses/mit-license.php
  3. Author Tobias Koppers @sokra
  4. */
  5. "use strict";
  6. const Module = require("../Module");
  7. const { JAVASCRIPT_TYPE } = require("../ModuleSourceTypeConstants");
  8. const makeSerializable = require("../util/makeSerializable");
  9. const HarmonyImportDependency = require("./HarmonyImportDependency");
  10. /** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
  11. /** @typedef {import("../Dependency")} Dependency */
  12. /** @typedef {import("../Dependency").GetConditionFn} GetConditionFn */
  13. /** @typedef {import("../DependencyTemplate").DependencyTemplateContext} DependencyTemplateContext */
  14. /** @typedef {import("../ModuleGraph")} ModuleGraph */
  15. /** @typedef {import("../ModuleGraphConnection").ConnectionState} ConnectionState */
  16. /** @typedef {import("../javascript/JavascriptParser").ImportAttributes} ImportAttributes */
  17. /** @typedef {import("./ImportPhase").ImportPhaseType} ImportPhaseType */
  18. class HarmonyImportSideEffectDependency extends HarmonyImportDependency {
  19. /**
  20. * Creates an instance of HarmonyImportSideEffectDependency.
  21. * @param {string} request the request string
  22. * @param {number} sourceOrder source order
  23. * @param {ImportPhaseType} phase import phase
  24. * @param {ImportAttributes=} attributes import attributes
  25. */
  26. constructor(request, sourceOrder, phase, attributes) {
  27. super(request, sourceOrder, phase, attributes);
  28. }
  29. get type() {
  30. return "harmony side effect evaluation";
  31. }
  32. /**
  33. * Returns function to determine if the connection is active.
  34. * @param {ModuleGraph} moduleGraph module graph
  35. * @returns {null | false | GetConditionFn} function to determine if the connection is active
  36. */
  37. getCondition(moduleGraph) {
  38. return (connection) => {
  39. const refModule = connection.resolvedModule;
  40. if (!refModule) return true;
  41. return refModule.getSideEffectsConnectionState(moduleGraph);
  42. };
  43. }
  44. /**
  45. * Gets module evaluation side effects state.
  46. * @param {ModuleGraph} moduleGraph the module graph
  47. * @returns {ConnectionState} how this dependency connects the module to referencing modules
  48. */
  49. getModuleEvaluationSideEffectsState(moduleGraph) {
  50. const refModule = moduleGraph.getModule(this);
  51. if (!refModule) return true;
  52. return refModule.getSideEffectsConnectionState(moduleGraph);
  53. }
  54. }
  55. makeSerializable(
  56. HarmonyImportSideEffectDependency,
  57. "webpack/lib/dependencies/HarmonyImportSideEffectDependency"
  58. );
  59. HarmonyImportSideEffectDependency.Template = class HarmonyImportSideEffectDependencyTemplate extends (
  60. HarmonyImportDependency.Template
  61. ) {
  62. /**
  63. * Applies the plugin by registering its hooks on the compiler.
  64. * @param {Dependency} dependency the dependency for which the template should be applied
  65. * @param {ReplaceSource} source the current replace source which can be modified
  66. * @param {DependencyTemplateContext} templateContext the context object
  67. * @returns {void}
  68. */
  69. apply(dependency, source, templateContext) {
  70. const { moduleGraph, concatenationScope } = templateContext;
  71. const module = /** @type {Module} */ (moduleGraph.getModule(dependency));
  72. if (module && !Module.getSourceBasicTypes(module).has(JAVASCRIPT_TYPE)) {
  73. // no need to render import
  74. return;
  75. }
  76. if (concatenationScope && concatenationScope.isModuleInScope(module)) {
  77. return;
  78. }
  79. super.apply(dependency, source, templateContext);
  80. }
  81. };
  82. module.exports = HarmonyImportSideEffectDependency;