UNPKG

json-q

Version:

Retrieves values from JSON objects (and JavaScript objects) by css-selector-like query (includes attribute filters and array flattening).

56 lines (50 loc) 1.69 kB
/* MIT License http://www.opensource.org/licenses/mit-license.php Author Tobias Koppers @sokra */ function LimitChunkCountPlugin(options) { if(options !== undefined && typeof options !== "object" || Array.isArray(options)) { throw new Error("Argument should be an options object.\nFor more info on options, see https://webpack.github.io/docs/list-of-plugins.html"); } this.options = options || {}; } module.exports = LimitChunkCountPlugin; LimitChunkCountPlugin.prototype.apply = function(compiler) { var options = this.options; compiler.plugin("compilation", function(compilation) { compilation.plugin("optimize-chunks", function(chunks) { var maxChunks = options.maxChunks; if(!maxChunks) return; if(maxChunks < 1) return; if(chunks.length <= maxChunks) return; if(chunks.length > maxChunks) { var combinations = []; chunks.forEach(function(a, idx) { for(var i = 0; i < idx; i++) { var b = chunks[i]; combinations.push([b, a]); } }); combinations.forEach(function(pair) { var a = pair[0].size(options); var b = pair[1].size(options); var ab = pair[0].integratedSize(pair[1], options); pair.unshift(a + b - ab, ab); }); combinations = combinations.filter(function(pair) { return pair[1] !== false; }); combinations.sort(function(a, b) { var diff = b[0] - a[0]; if(diff !== 0) return diff; return a[1] - b[1]; }); var pair = combinations[0]; if(pair && pair[2].integrate(pair[3], "limit")) { chunks.splice(chunks.indexOf(pair[3]), 1); this.restartApplyPlugins(); } } }); }); };