HarmonyImportSideEffectDependency.js 2.9 KB

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