mirror of https://github.com/webpack/webpack.git
				
				
				
			
		
			
				
	
	
		
			98 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| /*
 | |
| 	MIT License http://www.opensource.org/licenses/mit-license.php
 | |
| 	Author Tobias Koppers @sokra
 | |
| */
 | |
| function AggressiveMergingPlugin(options) {
 | |
| 	this.options = options || {};
 | |
| }
 | |
| module.exports = AggressiveMergingPlugin;
 | |
| 
 | |
| AggressiveMergingPlugin.prototype.apply = function(compiler) {
 | |
| 	var options = this.options;
 | |
| 	var minSizeReduce = options.minSizeReduce || 1.5;
 | |
| 	function getParentsWeight(chunk) {
 | |
| 		return chunk.parents.map(function(p) {
 | |
| 			return p.initial ? options.entryChunkMultiplicator || 10 : 1;
 | |
| 		}).reduce(function(a, b) {
 | |
| 			return a + b;
 | |
| 		}, 0);
 | |
| 	}
 | |
| 	compiler.plugin("compilation", function(compilation) {
 | |
| 		compilation.plugin("optimize-chunks", function(chunks) {
 | |
| 			var combinations = [];
 | |
| 			chunks.forEach(function(a, idx) {
 | |
| 				if(a.initial) return;
 | |
| 				for(var i = 0; i < idx; i++) {
 | |
| 					var b = chunks[i];
 | |
| 					if(b.initial) continue;
 | |
| 					combinations.push([b, a]);
 | |
| 				}
 | |
| 			});
 | |
| 
 | |
| 			combinations.forEach(function(pair) {
 | |
| 				var a = pair[0].size({chunkOverhead: 0});
 | |
| 				var b = pair[1].size({chunkOverhead: 0});
 | |
| 				var ab = pair[0].integratedSize(pair[1], {chunkOverhead: 0});
 | |
| 				pair.push({ a: a, b: b, ab: ab });
 | |
| 				if(ab === false) {
 | |
| 					pair.unshift(false);
 | |
| 				} else if(options.moveToParents) {
 | |
| 					var aOnly = ab - b;
 | |
| 					var bOnly = ab - a;
 | |
| 					var common = a + b - ab;
 | |
| 					var newSize = common + getParentsWeight(pair[0]) * aOnly + getParentsWeight(pair[1]) * bOnly;
 | |
| 					pair.push({ aOnly: aOnly, bOnly: bOnly, common: common, newSize: newSize });
 | |
| 				} else {
 | |
| 					var newSize = ab;
 | |
| 				}
 | |
| 
 | |
| 				pair.unshift((a + b) / newSize);
 | |
| 			});
 | |
| 			combinations = combinations.filter(function(pair) {
 | |
| 				return pair[0] !== false;
 | |
| 			});
 | |
| 			combinations.sort(function(a, b) {
 | |
| 				return b[0] - a[0];
 | |
| 			});
 | |
| 
 | |
| 			var pair = combinations[0];
 | |
| 
 | |
| 			if(!pair) return;
 | |
| 			if(pair[0] < minSizeReduce) return;
 | |
| 
 | |
| 			if(options.moveToParents) {
 | |
| 				var commonModules = pair[1].modules.filter(function(m) {
 | |
| 					return pair[2].modules.indexOf(m) >= 0;
 | |
| 				});
 | |
| 				var aOnlyModules = pair[1].modules.filter(function(m) {
 | |
| 					return commonModules.indexOf(m) < 0;
 | |
| 				});
 | |
| 				var bOnlyModules = pair[2].modules.filter(function(m) {
 | |
| 					return commonModules.indexOf(m) < 0;
 | |
| 				});
 | |
| 				aOnlyModules.forEach(function(m) {
 | |
| 					pair[1].removeModule(m);
 | |
| 					m.removeChunk(pair[1]);
 | |
| 					pair[1].parents.forEach(function(c) {
 | |
| 						c.addModule(m);
 | |
| 						m.addChunk(c);
 | |
| 					});
 | |
| 				});
 | |
| 				bOnlyModules.forEach(function(m) {
 | |
| 					pair[2].removeModule(m);
 | |
| 					m.removeChunk(pair[2]);
 | |
| 					pair[2].parents.forEach(function(c) {
 | |
| 						c.addModule(m);
 | |
| 						m.addChunk(c);
 | |
| 					});
 | |
| 				});
 | |
| 			}
 | |
| 			if(pair[1].integrate(pair[2], "aggressive-merge")) {
 | |
| 				chunks.splice(chunks.indexOf(pair[2]), 1);
 | |
| 				this.restartApplyPlugins();
 | |
| 			}
 | |
| 		});
 | |
| 	});
 | |
| };
 | |
| 
 |