webpack/lib/BannerPlugin.js

140 lines
3.6 KiB
JavaScript
Raw Normal View History

2013-05-13 05:16:22 +08:00
/*
2018-07-30 23:08:51 +08:00
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
"use strict";
const { ConcatSource } = require("webpack-sources");
const Compilation = require("./Compilation");
const ModuleFilenameHelpers = require("./ModuleFilenameHelpers");
const Template = require("./Template");
const createSchemaValidation = require("./util/create-schema-validation");
2017-10-28 05:23:38 +08:00
2023-06-22 08:59:10 +08:00
/** @typedef {import("../declarations/plugins/BannerPlugin").BannerFunction} BannerFunction */
/** @typedef {import("../declarations/plugins/BannerPlugin").BannerPluginArgument} BannerPluginArgument */
/** @typedef {import("../declarations/plugins/BannerPlugin").BannerPluginOptions} BannerPluginOptions */
2024-08-15 02:38:08 +08:00
/** @typedef {import("./Compilation").PathData} PathData */
/** @typedef {import("./Compiler")} Compiler */
2024-08-15 02:38:08 +08:00
/** @typedef {import("./TemplatedPathPlugin").TemplatePath} TemplatePath */
const validate = createSchemaValidation(
/** @type {((value: typeof import("../schemas/plugins/BannerPlugin.json")) => boolean)} */
2024-10-24 05:07:47 +08:00
(require("../schemas/plugins/BannerPlugin.check.js")),
() => require("../schemas/plugins/BannerPlugin.json"),
{
name: "Banner Plugin",
baseDataPath: "options"
}
);
2023-05-26 02:31:28 +08:00
/**
* @param {string} str string to wrap
* @returns {string} wrapped string
*/
2018-02-25 09:00:20 +08:00
const wrapComment = str => {
if (!str.includes("\n")) {
return Template.toComment(str);
}
2018-02-25 09:00:20 +08:00
return `/*!\n * ${str
.replace(/\*\//g, "* /")
.split("\n")
2019-09-29 18:31:16 +08:00
.join("\n * ")
.replace(/\s+\n/g, "\n")
2022-08-31 17:56:03 +08:00
.trimEnd()}\n */`;
2017-04-12 07:54:08 +08:00
};
2013-05-13 05:16:22 +08:00
class BannerPlugin {
/**
* @param {BannerPluginArgument} options options object
*/
constructor(options) {
if (typeof options === "string" || typeof options === "function") {
options = {
banner: options
};
}
validate(options);
2019-10-15 19:56:06 +08:00
2018-07-06 17:19:30 +08:00
this.options = options;
const bannerOption = options.banner;
if (typeof bannerOption === "function") {
const getBanner = bannerOption;
2024-08-15 02:38:08 +08:00
/** @type {BannerFunction} */
this.banner = this.options.raw
? getBanner
2023-06-22 08:59:10 +08:00
: /** @type {BannerFunction} */ data => wrapComment(getBanner(data));
} else {
2018-05-11 15:46:16 +08:00
const banner = this.options.raw
? bannerOption
: wrapComment(bannerOption);
2024-08-15 02:38:08 +08:00
/** @type {BannerFunction} */
this.banner = () => banner;
}
}
/**
2020-04-23 16:48:36 +08:00
* Apply the plugin
* @param {Compiler} compiler the compiler instance
* @returns {void}
*/
apply(compiler) {
2017-04-14 01:25:04 +08:00
const options = this.options;
const banner = this.banner;
2018-02-25 09:00:20 +08:00
const matchObject = ModuleFilenameHelpers.matchObject.bind(
undefined,
options
);
2022-03-02 01:22:07 +08:00
const cache = new WeakMap();
const stage =
this.options.stage || Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;
2018-02-25 09:00:20 +08:00
compiler.hooks.compilation.tap("BannerPlugin", compilation => {
compilation.hooks.processAssets.tap(
{
name: "BannerPlugin",
stage
},
() => {
for (const chunk of compilation.chunks) {
if (options.entryOnly && !chunk.canBeInitial()) {
2018-01-22 20:52:43 +08:00
continue;
}
for (const file of chunk.files) {
if (!matchObject(file)) {
continue;
}
2018-01-22 20:52:43 +08:00
2024-08-15 02:38:08 +08:00
/** @type {PathData} */
const data = { chunk, filename: file };
2018-01-22 20:52:43 +08:00
2024-08-15 02:38:08 +08:00
const comment = compilation.getPath(
/** @type {TemplatePath} */
(banner),
data
);
2022-03-02 01:22:07 +08:00
compilation.updateAsset(file, old => {
2024-07-31 04:09:42 +08:00
const cached = cache.get(old);
2022-03-02 01:22:07 +08:00
if (!cached || cached.comment !== comment) {
2022-04-02 02:29:34 +08:00
const source = options.footer
? new ConcatSource(old, "\n", comment)
: new ConcatSource(comment, "\n", old);
2022-03-02 01:22:07 +08:00
cache.set(old, { source, comment });
return source;
}
return cached.source;
});
}
2018-01-22 20:52:43 +08:00
}
}
);
2013-05-13 05:16:22 +08:00
});
}
}
module.exports = BannerPlugin;