Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(plugin-webpack): add an option to export webpack compilation stats #639

Merged
merged 11 commits into from
Jan 23, 2020
12 changes: 12 additions & 0 deletions packages/plugin/webpack/src/Config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,12 @@ export interface WebpackPluginRendererConfig {
* The webpack config for your renderer process
*/
config: WebpackConfiguration | string;
/**
* Instructs webpack to emit a JSON file containing statistics about
* modules, the dependency graph and various other build information for the renderer process.
* This file is located in `.webpack/renderer/stats.json` and is not packaged with your app.
*/
jsonStats?: boolean;
/**
* Array of entry points, these should map to the windows your app needs to
* open. Each window requires it's own entry point
Expand All @@ -64,6 +70,12 @@ export interface WebpackPluginConfig {
* The webpack config for your main process
*/
mainConfig: WebpackConfiguration | string;
/**
* Instructs webpack to emit a JSON file containing statistics about
* modules, the dependency graph and various other build information for the main process.
* This file is located in `.webpack/main/stats.json` and is not packaged with your app.
*/
jsonStats?: boolean;
/**
* Electron Forge webpack configuration for your renderer process
*/
Expand Down
36 changes: 31 additions & 5 deletions packages/plugin/webpack/src/WebpackPlugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,10 +92,24 @@ export default class WebpackPlugin extends PluginBase<WebpackPluginConfig> {
if (options.exit) process.exit();
}

async writeJSONStats(
type: string,
stats: webpack.Stats,
statsOptions?: webpack.Stats.ToStringOptions,
): Promise<void> {
d(`Writing JSON stats for ${type} config`);
const jsonStats = stats.toJson(statsOptions as webpack.Stats.ToJsonOptions);
const jsonStatsFilename = path.resolve(this.baseDir, type, 'stats.json');
await fs.writeJson(jsonStatsFilename, jsonStats, { spaces: 2 });
}

// eslint-disable-next-line max-len
private runWebpack = async (options: Configuration): Promise<webpack.Stats> => new Promise((resolve, reject) => {
private runWebpack = async (options: Configuration, isRenderer = false): Promise<webpack.Stats> => new Promise((resolve, reject) => {
webpack(options)
.run((err, stats) => {
.run(async (err, stats) => {
if (isRenderer && this.config.renderer.jsonStats) {
await this.writeJSONStats('renderer', stats, options.stats);
}
if (err) {
return reject(err);
}
Expand Down Expand Up @@ -168,6 +182,14 @@ Your packaged app may be larger than expected if you dont ignore everything othe
forgeConfig.packagerConfig.ignore = (file: string) => {
if (!file) return false;

if (this.config.jsonStats && file.endsWith(path.join('.webpack', 'main', 'stats.json'))) {
return true;
}

if (this.config.renderer.jsonStats && file.endsWith(path.join('.webpack', 'renderer', 'stats.json'))) {
return true;
}

return !/^[/\\]\.webpack($|[/\\]).*$/.test(file);
};
return forgeConfig;
Expand Down Expand Up @@ -200,16 +222,19 @@ Your packaged app may be larger than expected if you dont ignore everything othe
tab = logger.createTab('Main Process');
}
await asyncOra('Compiling Main Process Code', async () => {
const config = await this.configGenerator.getMainConfig();
const mainConfig = await this.configGenerator.getMainConfig();
await new Promise((resolve, reject) => {
const compiler = webpack(config);
const compiler = webpack(mainConfig);
const [onceResolve, onceReject] = once(resolve, reject);
const cb: webpack.ICompiler.Handler = (err, stats) => {
const cb: webpack.ICompiler.Handler = async (err, stats: webpack.Stats) => {
if (tab && stats) {
tab.log(stats.toString({
colors: true,
}));
}
if (this.config.jsonStats) {
await this.writeJSONStats('main', stats, mainConfig.stats);
}

if (err) return onceReject(err);
if (!watch && stats.hasErrors()) {
Expand All @@ -231,6 +256,7 @@ Your packaged app may be larger than expected if you dont ignore everything othe
await asyncOra('Compiling Renderer Template', async () => {
const stats = await this.runWebpack(
await this.configGenerator.getRendererConfig(this.config.renderer.entryPoints),
true,
);
if (!watch && stats.hasErrors()) {
throw new Error(`Compilation errors in the renderer: ${stats.toString()}`);
Expand Down