index.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. Object.defineProperty(exports, "buildDynamicImport", {
  6. enumerable: true,
  7. get: function () {
  8. return _dynamicImport.buildDynamicImport;
  9. }
  10. });
  11. exports.buildNamespaceInitStatements = buildNamespaceInitStatements;
  12. exports.ensureStatementsHoisted = ensureStatementsHoisted;
  13. Object.defineProperty(exports, "getModuleName", {
  14. enumerable: true,
  15. get: function () {
  16. return _getModuleName.default;
  17. }
  18. });
  19. Object.defineProperty(exports, "hasExports", {
  20. enumerable: true,
  21. get: function () {
  22. return _normalizeAndLoadMetadata.hasExports;
  23. }
  24. });
  25. Object.defineProperty(exports, "isModule", {
  26. enumerable: true,
  27. get: function () {
  28. return _helperModuleImports.isModule;
  29. }
  30. });
  31. Object.defineProperty(exports, "isSideEffectImport", {
  32. enumerable: true,
  33. get: function () {
  34. return _normalizeAndLoadMetadata.isSideEffectImport;
  35. }
  36. });
  37. exports.rewriteModuleStatementsAndPrepareHeader = rewriteModuleStatementsAndPrepareHeader;
  38. Object.defineProperty(exports, "rewriteThis", {
  39. enumerable: true,
  40. get: function () {
  41. return _rewriteThis.default;
  42. }
  43. });
  44. exports.wrapInterop = wrapInterop;
  45. var _assert = require("assert");
  46. var _core = require("@babel/core");
  47. var _helperModuleImports = require("@babel/helper-module-imports");
  48. var _rewriteThis = require("./rewrite-this.js");
  49. var _rewriteLiveReferences = require("./rewrite-live-references.js");
  50. var _normalizeAndLoadMetadata = require("./normalize-and-load-metadata.js");
  51. var Lazy = require("./lazy-modules.js");
  52. var _dynamicImport = require("./dynamic-import.js");
  53. var _getModuleName = require("./get-module-name.js");
  54. exports.getDynamicImportSource = require("./dynamic-import").getDynamicImportSource;
  55. function rewriteModuleStatementsAndPrepareHeader(path, {
  56. exportName,
  57. strict,
  58. allowTopLevelThis,
  59. strictMode,
  60. noInterop,
  61. importInterop = noInterop ? "none" : "babel",
  62. lazy,
  63. getWrapperPayload = Lazy.toGetWrapperPayload(lazy != null ? lazy : false),
  64. wrapReference = Lazy.wrapReference,
  65. esNamespaceOnly,
  66. filename,
  67. constantReexports = arguments[1].loose,
  68. enumerableModuleMeta = arguments[1].loose,
  69. noIncompleteNsImportDetection
  70. }) {
  71. (0, _normalizeAndLoadMetadata.validateImportInteropOption)(importInterop);
  72. _assert((0, _helperModuleImports.isModule)(path), "Cannot process module statements in a script");
  73. path.node.sourceType = "script";
  74. const meta = (0, _normalizeAndLoadMetadata.default)(path, exportName, {
  75. importInterop,
  76. initializeReexports: constantReexports,
  77. getWrapperPayload,
  78. esNamespaceOnly,
  79. filename
  80. });
  81. if (!allowTopLevelThis) {
  82. (0, _rewriteThis.default)(path);
  83. }
  84. (0, _rewriteLiveReferences.default)(path, meta, wrapReference);
  85. if (strictMode !== false) {
  86. const hasStrict = path.node.directives.some(directive => {
  87. return directive.value.value === "use strict";
  88. });
  89. if (!hasStrict) {
  90. path.unshiftContainer("directives", _core.types.directive(_core.types.directiveLiteral("use strict")));
  91. }
  92. }
  93. const headers = [];
  94. if ((0, _normalizeAndLoadMetadata.hasExports)(meta) && !strict) {
  95. headers.push(buildESModuleHeader(meta, enumerableModuleMeta));
  96. }
  97. const nameList = buildExportNameListDeclaration(path, meta);
  98. if (nameList) {
  99. meta.exportNameListName = nameList.name;
  100. headers.push(nameList.statement);
  101. }
  102. headers.push(...buildExportInitializationStatements(path, meta, wrapReference, constantReexports, noIncompleteNsImportDetection));
  103. return {
  104. meta,
  105. headers
  106. };
  107. }
  108. function ensureStatementsHoisted(statements) {
  109. statements.forEach(header => {
  110. header._blockHoist = 3;
  111. });
  112. }
  113. function wrapInterop(programPath, expr, type) {
  114. if (type === "none") {
  115. return null;
  116. }
  117. if (type === "node-namespace") {
  118. return _core.types.callExpression(programPath.hub.addHelper("interopRequireWildcard"), [expr, _core.types.booleanLiteral(true)]);
  119. } else if (type === "node-default") {
  120. return null;
  121. }
  122. let helper;
  123. if (type === "default") {
  124. helper = "interopRequireDefault";
  125. } else if (type === "namespace") {
  126. helper = "interopRequireWildcard";
  127. } else {
  128. throw new Error(`Unknown interop: ${type}`);
  129. }
  130. return _core.types.callExpression(programPath.hub.addHelper(helper), [expr]);
  131. }
  132. function buildNamespaceInitStatements(metadata, sourceMetadata, constantReexports = false, wrapReference = Lazy.wrapReference) {
  133. var _wrapReference;
  134. const statements = [];
  135. const srcNamespaceId = _core.types.identifier(sourceMetadata.name);
  136. for (const localName of sourceMetadata.importsNamespace) {
  137. if (localName === sourceMetadata.name) continue;
  138. statements.push(_core.template.statement`var NAME = SOURCE;`({
  139. NAME: localName,
  140. SOURCE: _core.types.cloneNode(srcNamespaceId)
  141. }));
  142. }
  143. const srcNamespace = (_wrapReference = wrapReference(srcNamespaceId, sourceMetadata.wrap)) != null ? _wrapReference : srcNamespaceId;
  144. if (constantReexports) {
  145. statements.push(...buildReexportsFromMeta(metadata, sourceMetadata, true, wrapReference));
  146. }
  147. for (const exportName of sourceMetadata.reexportNamespace) {
  148. statements.push((!_core.types.isIdentifier(srcNamespace) ? _core.template.statement`
  149. Object.defineProperty(EXPORTS, "NAME", {
  150. enumerable: true,
  151. get: function() {
  152. return NAMESPACE;
  153. }
  154. });
  155. ` : _core.template.statement`EXPORTS.NAME = NAMESPACE;`)({
  156. EXPORTS: metadata.exportName,
  157. NAME: exportName,
  158. NAMESPACE: _core.types.cloneNode(srcNamespace)
  159. }));
  160. }
  161. if (sourceMetadata.reexportAll) {
  162. const statement = buildNamespaceReexport(metadata, _core.types.cloneNode(srcNamespace), constantReexports);
  163. statement.loc = sourceMetadata.reexportAll.loc;
  164. statements.push(statement);
  165. }
  166. return statements;
  167. }
  168. const ReexportTemplate = {
  169. constant: ({
  170. exports,
  171. exportName,
  172. namespaceImport
  173. }) => _core.template.statement.ast`
  174. ${exports}.${exportName} = ${namespaceImport};
  175. `,
  176. constantComputed: ({
  177. exports,
  178. exportName,
  179. namespaceImport
  180. }) => _core.template.statement.ast`
  181. ${exports}["${exportName}"] = ${namespaceImport};
  182. `,
  183. spec: ({
  184. exports,
  185. exportName,
  186. namespaceImport
  187. }) => _core.template.statement.ast`
  188. Object.defineProperty(${exports}, "${exportName}", {
  189. enumerable: true,
  190. get: function() {
  191. return ${namespaceImport};
  192. },
  193. });
  194. `
  195. };
  196. function buildReexportsFromMeta(meta, metadata, constantReexports, wrapReference) {
  197. var _wrapReference2;
  198. let namespace = _core.types.identifier(metadata.name);
  199. namespace = (_wrapReference2 = wrapReference(namespace, metadata.wrap)) != null ? _wrapReference2 : namespace;
  200. const {
  201. stringSpecifiers
  202. } = meta;
  203. return Array.from(metadata.reexports, ([exportName, importName]) => {
  204. let namespaceImport = _core.types.cloneNode(namespace);
  205. if (importName === "default" && metadata.interop === "node-default") {} else if (stringSpecifiers.has(importName)) {
  206. namespaceImport = _core.types.memberExpression(namespaceImport, _core.types.stringLiteral(importName), true);
  207. } else {
  208. namespaceImport = _core.types.memberExpression(namespaceImport, _core.types.identifier(importName));
  209. }
  210. const astNodes = {
  211. exports: meta.exportName,
  212. exportName,
  213. namespaceImport
  214. };
  215. if (constantReexports || _core.types.isIdentifier(namespaceImport)) {
  216. if (stringSpecifiers.has(exportName)) {
  217. return ReexportTemplate.constantComputed(astNodes);
  218. } else {
  219. return ReexportTemplate.constant(astNodes);
  220. }
  221. } else {
  222. return ReexportTemplate.spec(astNodes);
  223. }
  224. });
  225. }
  226. function buildESModuleHeader(metadata, enumerableModuleMeta = false) {
  227. return (enumerableModuleMeta ? _core.template.statement`
  228. EXPORTS.__esModule = true;
  229. ` : _core.template.statement`
  230. Object.defineProperty(EXPORTS, "__esModule", {
  231. value: true,
  232. });
  233. `)({
  234. EXPORTS: metadata.exportName
  235. });
  236. }
  237. function buildNamespaceReexport(metadata, namespace, constantReexports) {
  238. return (constantReexports ? _core.template.statement`
  239. Object.keys(NAMESPACE).forEach(function(key) {
  240. if (key === "default" || key === "__esModule") return;
  241. VERIFY_NAME_LIST;
  242. if (key in EXPORTS && EXPORTS[key] === NAMESPACE[key]) return;
  243. EXPORTS[key] = NAMESPACE[key];
  244. });
  245. ` : _core.template.statement`
  246. Object.keys(NAMESPACE).forEach(function(key) {
  247. if (key === "default" || key === "__esModule") return;
  248. VERIFY_NAME_LIST;
  249. if (key in EXPORTS && EXPORTS[key] === NAMESPACE[key]) return;
  250. Object.defineProperty(EXPORTS, key, {
  251. enumerable: true,
  252. get: function() {
  253. return NAMESPACE[key];
  254. },
  255. });
  256. });
  257. `)({
  258. NAMESPACE: namespace,
  259. EXPORTS: metadata.exportName,
  260. VERIFY_NAME_LIST: metadata.exportNameListName ? (0, _core.template)`
  261. if (Object.prototype.hasOwnProperty.call(EXPORTS_LIST, key)) return;
  262. `({
  263. EXPORTS_LIST: metadata.exportNameListName
  264. }) : null
  265. });
  266. }
  267. function buildExportNameListDeclaration(programPath, metadata) {
  268. const exportedVars = Object.create(null);
  269. for (const data of metadata.local.values()) {
  270. for (const name of data.names) {
  271. exportedVars[name] = true;
  272. }
  273. }
  274. let hasReexport = false;
  275. for (const data of metadata.source.values()) {
  276. for (const exportName of data.reexports.keys()) {
  277. exportedVars[exportName] = true;
  278. }
  279. for (const exportName of data.reexportNamespace) {
  280. exportedVars[exportName] = true;
  281. }
  282. hasReexport = hasReexport || !!data.reexportAll;
  283. }
  284. if (!hasReexport || Object.keys(exportedVars).length === 0) return null;
  285. const name = programPath.scope.generateUidIdentifier("exportNames");
  286. delete exportedVars.default;
  287. return {
  288. name: name.name,
  289. statement: _core.types.variableDeclaration("var", [_core.types.variableDeclarator(name, _core.types.valueToNode(exportedVars))])
  290. };
  291. }
  292. function buildExportInitializationStatements(programPath, metadata, wrapReference, constantReexports = false, noIncompleteNsImportDetection = false) {
  293. const initStatements = [];
  294. for (const [localName, data] of metadata.local) {
  295. if (data.kind === "import") {} else if (data.kind === "hoisted") {
  296. initStatements.push([data.names[0], buildInitStatement(metadata, data.names, _core.types.identifier(localName))]);
  297. } else if (!noIncompleteNsImportDetection) {
  298. for (const exportName of data.names) {
  299. initStatements.push([exportName, null]);
  300. }
  301. }
  302. }
  303. for (const data of metadata.source.values()) {
  304. if (!constantReexports) {
  305. const reexportsStatements = buildReexportsFromMeta(metadata, data, false, wrapReference);
  306. const reexports = [...data.reexports.keys()];
  307. for (let i = 0; i < reexportsStatements.length; i++) {
  308. initStatements.push([reexports[i], reexportsStatements[i]]);
  309. }
  310. }
  311. if (!noIncompleteNsImportDetection) {
  312. for (const exportName of data.reexportNamespace) {
  313. initStatements.push([exportName, null]);
  314. }
  315. }
  316. }
  317. initStatements.sort(([a], [b]) => {
  318. if (a < b) return -1;
  319. if (b < a) return 1;
  320. return 0;
  321. });
  322. const results = [];
  323. if (noIncompleteNsImportDetection) {
  324. for (const [, initStatement] of initStatements) {
  325. results.push(initStatement);
  326. }
  327. } else {
  328. const chunkSize = 100;
  329. for (let i = 0; i < initStatements.length; i += chunkSize) {
  330. let uninitializedExportNames = [];
  331. for (let j = 0; j < chunkSize && i + j < initStatements.length; j++) {
  332. const [exportName, initStatement] = initStatements[i + j];
  333. if (initStatement !== null) {
  334. if (uninitializedExportNames.length > 0) {
  335. results.push(buildInitStatement(metadata, uninitializedExportNames, programPath.scope.buildUndefinedNode()));
  336. uninitializedExportNames = [];
  337. }
  338. results.push(initStatement);
  339. } else {
  340. uninitializedExportNames.push(exportName);
  341. }
  342. }
  343. if (uninitializedExportNames.length > 0) {
  344. results.push(buildInitStatement(metadata, uninitializedExportNames, programPath.scope.buildUndefinedNode()));
  345. }
  346. }
  347. }
  348. return results;
  349. }
  350. const InitTemplate = {
  351. computed: ({
  352. exports,
  353. name,
  354. value
  355. }) => _core.template.expression.ast`${exports}["${name}"] = ${value}`,
  356. default: ({
  357. exports,
  358. name,
  359. value
  360. }) => _core.template.expression.ast`${exports}.${name} = ${value}`,
  361. define: ({
  362. exports,
  363. name,
  364. value
  365. }) => _core.template.expression.ast`
  366. Object.defineProperty(${exports}, "${name}", {
  367. enumerable: true,
  368. value: void 0,
  369. writable: true
  370. })["${name}"] = ${value}`
  371. };
  372. function buildInitStatement(metadata, exportNames, initExpr) {
  373. const {
  374. stringSpecifiers,
  375. exportName: exports
  376. } = metadata;
  377. return _core.types.expressionStatement(exportNames.reduce((value, name) => {
  378. const params = {
  379. exports,
  380. name,
  381. value
  382. };
  383. if (name === "__proto__") {
  384. return InitTemplate.define(params);
  385. }
  386. if (stringSpecifiers.has(name)) {
  387. return InitTemplate.computed(params);
  388. }
  389. return InitTemplate.default(params);
  390. }, initExpr));
  391. }
  392. //# sourceMappingURL=index.js.map