HarmonyExportSpecifierDependency.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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 HarmonyExportInitFragment = require("./HarmonyExportInitFragment");
  8. const NullDependency = require("./NullDependency");
  9. /** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
  10. /** @typedef {import("../Dependency")} Dependency */
  11. /** @typedef {import("../Dependency").ExportsSpec} ExportsSpec */
  12. /** @typedef {import("../DependencyTemplate").DependencyTemplateContext} DependencyTemplateContext */
  13. /** @typedef {import("../ModuleGraph")} ModuleGraph */
  14. /** @typedef {import("../ModuleGraphConnection").ConnectionState} ConnectionState */
  15. /** @typedef {import("../serialization/ObjectMiddleware").ObjectDeserializerContext} ObjectDeserializerContext */
  16. /** @typedef {import("../serialization/ObjectMiddleware").ObjectSerializerContext} ObjectSerializerContext */
  17. /** @typedef {import("./HarmonyExportInitFragment").UnusedExports} UnusedExports */
  18. /** @typedef {import("./HarmonyExportInitFragment").ExportMap} ExportMap */
  19. class HarmonyExportSpecifierDependency extends NullDependency {
  20. /**
  21. * @param {string} id the id
  22. * @param {string} name the name
  23. */
  24. constructor(id, name) {
  25. super();
  26. this.id = id;
  27. this.name = name;
  28. }
  29. get type() {
  30. return "harmony export specifier";
  31. }
  32. /**
  33. * Returns the exported names
  34. * @param {ModuleGraph} moduleGraph module graph
  35. * @returns {ExportsSpec | undefined} export names
  36. */
  37. getExports(moduleGraph) {
  38. return {
  39. exports: [this.name],
  40. priority: 1,
  41. terminalBinding: true,
  42. dependencies: undefined
  43. };
  44. }
  45. /**
  46. * @param {ModuleGraph} moduleGraph the module graph
  47. * @returns {ConnectionState} how this dependency connects the module to referencing modules
  48. */
  49. getModuleEvaluationSideEffectsState(moduleGraph) {
  50. return false;
  51. }
  52. /**
  53. * @param {ObjectSerializerContext} context context
  54. */
  55. serialize(context) {
  56. const { write } = context;
  57. write(this.id);
  58. write(this.name);
  59. super.serialize(context);
  60. }
  61. /**
  62. * @param {ObjectDeserializerContext} context context
  63. */
  64. deserialize(context) {
  65. const { read } = context;
  66. this.id = read();
  67. this.name = read();
  68. super.deserialize(context);
  69. }
  70. }
  71. makeSerializable(
  72. HarmonyExportSpecifierDependency,
  73. "webpack/lib/dependencies/HarmonyExportSpecifierDependency"
  74. );
  75. HarmonyExportSpecifierDependency.Template = class HarmonyExportSpecifierDependencyTemplate extends (
  76. NullDependency.Template
  77. ) {
  78. /**
  79. * @param {Dependency} dependency the dependency for which the template should be applied
  80. * @param {ReplaceSource} source the current replace source which can be modified
  81. * @param {DependencyTemplateContext} templateContext the context object
  82. * @returns {void}
  83. */
  84. apply(
  85. dependency,
  86. source,
  87. { module, moduleGraph, initFragments, runtime, concatenationScope }
  88. ) {
  89. const dep = /** @type {HarmonyExportSpecifierDependency} */ (dependency);
  90. if (concatenationScope) {
  91. concatenationScope.registerExport(dep.name, dep.id);
  92. return;
  93. }
  94. const used = moduleGraph
  95. .getExportsInfo(module)
  96. .getUsedName(dep.name, runtime);
  97. if (!used) {
  98. /** @type {UnusedExports} */
  99. const set = new Set();
  100. set.add(dep.name || "namespace");
  101. initFragments.push(
  102. new HarmonyExportInitFragment(module.exportsArgument, undefined, set)
  103. );
  104. return;
  105. }
  106. /** @type {ExportMap} */
  107. const map = new Map();
  108. map.set(used, `/* binding */ ${dep.id}`);
  109. initFragments.push(
  110. new HarmonyExportInitFragment(module.exportsArgument, map, undefined)
  111. );
  112. }
  113. };
  114. module.exports = HarmonyExportSpecifierDependency;