webpack/lib/asset/AssetModulesPlugin.js

107 lines
2.7 KiB
JavaScript
Raw Normal View History

/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Yuta Hiroto @hiroppy
*/
"use strict";
const Generator = require("../Generator");
const { compareModulesByIdentifier } = require("../util/comparators");
const AssetGenerator = require("./AssetGenerator");
const AssetJavascriptGenerator = require("./AssetJavascriptGenerator");
const AssetParser = require("./AssetParser");
/** @typedef {import("webpack-sources").Source} Source */
/** @typedef {import("../Chunk")} Chunk */
/** @typedef {import("../Compiler")} Compiler */
/** @typedef {import("../Module")} Module */
2019-11-16 00:27:36 +08:00
/**
* @typedef {Object} DataUrlOptions
* @property {string | false} encoding?
* @property {string} mimetype?
* @property {number} maxSize?
*/
/**
* @callback DataUrlFn
* @param {string} source
* @param {string} resourcePath
* @returns {string|null}
*/
/**
* @typedef {Object} GeneratorOptions
* @property {DataUrlOptions | DataUrlFn} dataUrl?
*/
const type = "asset";
const plugin = "AssetModulesPlugin";
2019-07-16 19:33:45 +08:00
class AssetModulesPlugin {
/**
* @param {Compiler} compiler webpack compiler
* @returns {void}
*/
apply(compiler) {
compiler.hooks.compilation.tap(
plugin,
(compilation, { normalModuleFactory }) => {
normalModuleFactory.hooks.createParser.for(type).tap(plugin, () => {
return new AssetParser();
});
2019-11-16 00:27:36 +08:00
normalModuleFactory.hooks.createGenerator
.for(type)
.tap(plugin, generatorOptions => {
// todo add scheme validation
return Generator.byType({
asset: new AssetGenerator(generatorOptions),
javascript: new AssetJavascriptGenerator(
compilation,
generatorOptions
)
});
});
compilation.hooks.renderManifest.tap(plugin, (result, options) => {
const { chunkGraph } = compilation;
const { chunk, runtimeTemplate, codeGenerationResults } = options;
const { outputOptions } = runtimeTemplate;
const modules = chunkGraph.getOrderedChunkModulesIterableBySourceType(
chunk,
"asset",
compareModulesByIdentifier
);
if (modules) {
for (const module of modules) {
const filename = module.nameForCondition();
const filenameTemplate = outputOptions.assetModuleFilename;
result.push({
render: () =>
codeGenerationResults.get(module).sources.get(type),
filenameTemplate,
pathOptions: {
module,
filename,
chunkGraph
},
auxiliary: true,
identifier: `assetModule${chunkGraph.getModuleId(module)}`,
hash: chunkGraph.getModuleHash(module)
});
}
}
return result;
});
}
);
}
}
module.exports = AssetModulesPlugin;