UNPKG

webpack

Version:

Packs ECMAScript/CommonJs/AMD modules for the browser. Allows you to split your codebase into multiple bundles, which can be loaded on demand. Supports loaders to preprocess files, i.e. json, jsx, es7, css, less, ... and your custom stuff.

199 lines (192 loc) 6.43 kB
/* MIT License http://www.opensource.org/licenses/mit-license.php */ "use strict"; const RuntimeGlobals = require("../RuntimeGlobals"); const Template = require("../Template"); const HelperRuntimeModule = require("./HelperRuntimeModule"); /** @typedef {import("../Compilation")} Compilation */ class AsyncModuleRuntimeModule extends HelperRuntimeModule { /** * @param {boolean=} deferInterop if defer import is used. */ constructor(deferInterop = false) { super("async module"); this._deferInterop = deferInterop; } /** * @returns {string | null} runtime code */ generate() { const compilation = /** @type {Compilation} */ (this.compilation); const { runtimeTemplate } = compilation; const fn = RuntimeGlobals.asyncModule; const defer = this._deferInterop; return Template.asString([ 'var hasSymbol = typeof Symbol === "function";', 'var webpackQueues = hasSymbol ? Symbol("webpack queues") : "__webpack_queues__";', `var webpackExports = ${ defer ? `${RuntimeGlobals.asyncModuleExportSymbol}= ` : "" }hasSymbol ? Symbol("webpack exports") : "${RuntimeGlobals.exports}";`, 'var webpackError = hasSymbol ? Symbol("webpack error") : "__webpack_error__";', defer ? Template.asString([ `var webpackDone = ${RuntimeGlobals.asyncModuleDoneSymbol} = hasSymbol ? Symbol("webpack done") : "__webpack_done__";`, `var webpackDefer = ${RuntimeGlobals.deferredModuleAsyncTransitiveDependenciesSymbol} = hasSymbol ? Symbol("webpack defer") : "__webpack_defer__";`, `${RuntimeGlobals.deferredModuleAsyncTransitiveDependencies} = ${runtimeTemplate.basicFunction( "asyncDeps", [ Template.indent([ "var hasUnresolvedAsyncSubgraph = asyncDeps.some((id) => {", Template.indent([ "var cache = __webpack_module_cache__[id];", "return !cache || cache[webpackDone] === false;" ]), "});", "if (hasUnresolvedAsyncSubgraph) {", Template.indent([ "return ({ then(onFulfilled, onRejected) { return Promise.all(asyncDeps.map(__webpack_require__)).then(onFulfilled, onRejected) } })" ]), "}" ]) ] )}` ]) : "", `var resolveQueue = ${runtimeTemplate.basicFunction("queue", [ "if(queue && queue.d < 1) {", Template.indent([ "queue.d = 1;", `queue.forEach(${runtimeTemplate.expressionFunction( "fn.r--", "fn" )});`, `queue.forEach(${runtimeTemplate.expressionFunction( "fn.r-- ? fn.r++ : fn()", "fn" )});` ]), "}" ])}`, `var wrapDeps = ${runtimeTemplate.returningFunction( `deps.map(${runtimeTemplate.basicFunction("dep", [ 'if(dep !== null && typeof dep === "object") {', Template.indent([ defer ? Template.asString([ "if(!dep[webpackQueues] && dep[webpackDefer]) {", Template.indent([ `var asyncDeps = ${RuntimeGlobals.deferredModuleAsyncTransitiveDependencies}(dep[webpackDefer]);`, "if (asyncDeps) {", Template.indent([ "var d = dep;", "dep = {", Template.indent([ "then(onFulfilled, onRejected) {", Template.indent([ `asyncDeps.then(${runtimeTemplate.returningFunction( "onFulfilled(d)" )}, onRejected);` ]), "}" ]), "};" ]), "} else return dep;" ]), "}" ]) : "", "if(dep[webpackQueues]) return dep;", "if(dep.then) {", Template.indent([ "var queue = [];", "queue.d = 0;", `dep.then(${runtimeTemplate.basicFunction("r", [ "obj[webpackExports] = r;", "resolveQueue(queue);" ])}, ${runtimeTemplate.basicFunction("e", [ "obj[webpackError] = e;", "resolveQueue(queue);" ])});`, "var obj = {};", defer ? "obj[webpackDefer] = false;" : "", `obj[webpackQueues] = ${runtimeTemplate.expressionFunction( "fn(queue)", "fn" )};`, "return obj;" ]), "}" ]), "}", "var ret = {};", `ret[webpackQueues] = ${runtimeTemplate.emptyFunction()};`, "ret[webpackExports] = dep;", "return ret;" ])})`, "deps" )};`, `${fn} = ${runtimeTemplate.basicFunction("module, body, hasAwait", [ "var queue;", "hasAwait && ((queue = []).d = -1);", "var depQueues = new Set();", "var exports = module.exports;", "var currentDeps;", "var outerResolve;", "var reject;", `var promise = new Promise(${runtimeTemplate.basicFunction( "resolve, rej", ["reject = rej;", "outerResolve = resolve;"] )});`, "promise[webpackExports] = exports;", `promise[webpackQueues] = ${runtimeTemplate.expressionFunction( `queue && fn(queue), depQueues.forEach(fn), promise["catch"](${runtimeTemplate.emptyFunction()})`, "fn" )};`, "module.exports = promise;", `var handle = ${runtimeTemplate.basicFunction("deps", [ "currentDeps = wrapDeps(deps);", "var fn;", `var getResult = ${runtimeTemplate.returningFunction( `currentDeps.map(${runtimeTemplate.basicFunction("d", [ defer ? "if(d[webpackDefer]) return d;" : "", "if(d[webpackError]) throw d[webpackError];", "return d[webpackExports];" ])})` )}`, `var promise = new Promise(${runtimeTemplate.basicFunction( "resolve", [ `fn = ${runtimeTemplate.expressionFunction( "resolve(getResult)", "" )};`, "fn.r = 0;", `var fnQueue = ${runtimeTemplate.expressionFunction( "q !== queue && !depQueues.has(q) && (depQueues.add(q), q && !q.d && (fn.r++, q.push(fn)))", "q" )};`, `currentDeps.map(${runtimeTemplate.expressionFunction( `${ defer ? "dep[webpackDefer]||" : "" }dep[webpackQueues](fnQueue)`, "dep" )});` ] )});`, "return fn.r ? promise : getResult();" ])}`, `var done = ${runtimeTemplate.expressionFunction( `(err ? reject(promise[webpackError] = err) : outerResolve(exports)), resolveQueue(queue)${ defer ? ", promise[webpackDone] = true" : "" }`, "err" )}`, "body(handle, done);", "queue && queue.d < 0 && (queue.d = 0);" ])};` ]); } } module.exports = AsyncModuleRuntimeModule;