Skip to content

Commit

Permalink
Fix webpack-dev-server child compilation on template change
Browse files Browse the repository at this point in the history
  • Loading branch information
jantimon committed May 20, 2015
1 parent 2753884 commit c12a4d0
Showing 1 changed file with 20 additions and 23 deletions.
43 changes: 20 additions & 23 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,16 +41,19 @@ function HtmlWebpackPlugin(options) {

HtmlWebpackPlugin.prototype.apply = function(compiler) {
var self = this;
var compilationPromise;
self.context = compiler.context;

compiler.plugin('this-compilation', function(compilation, callback) {
// Compile the template
compilationPromise = self.compileTemplate(self.options.template, self.options.filename, compilation);
compilationPromise.finally(callback);
});

compiler.plugin('emit', function(compilation, callback) {
// Get all chunks
var chunks = self.filterChunks(compilation.getStats().toJson(), self.options.chunks, self.options.excludeChunks);
// Skip if no new files were added
if (self.didChunkFilesChange(chunks) === false) {
return callback();
}
// Compile the template
self.compileTemplate(self.options.template, self.options.filename, compilation)
compilationPromise
.then(function(resultAsset) {
// Once everything is compiled evaluate the html factory
// and replace it with its content
Expand Down Expand Up @@ -84,17 +87,12 @@ HtmlWebpackPlugin.prototype.apply = function(compiler) {
};

/**
* Checks wether files were added or removed since the last call
* Returns the child compiler name
*/
HtmlWebpackPlugin.prototype.didChunkFilesChange = function(chunks) {
var files = _.flatten(chunks.map(function(chunk) {
return chunk.files;
}));
if(!this.filesOfLastRun || _.difference(files, this.filesOfLastRun).length > 0) {
this.filesOfLastRun = files;
return true;
}
return false;
HtmlWebpackPlugin.prototype.getCompilerName = function() {
var absolutePath = path.resolve(this.context, this.options.filename);
var relativePath = path.relative(this.context, absolutePath);
return 'html-webpack-plugin for "' + (absolutePath.length < relativePath.length ? absolutePath : relativePath) + '"';
};

/**
Expand All @@ -104,33 +102,32 @@ HtmlWebpackPlugin.prototype.didChunkFilesChange = function(chunks) {
HtmlWebpackPlugin.prototype.compileTemplate = function(template, outputFilename, compilation) {
// The entry file is just an empty helper as the dynamic template
// require is added in "loader.js"
var entryRequest = template;
var outputOptions = {
filename: outputFilename,
publicPath: compilation.outputOptions.publicPath
};
// Create an additional child compiler which takes the template
// and turns it into an Node.JS html factory.
// This allows us to use loaders during the compilation
var compilerName = 'html-webpack-plugin for "' + path.basename(outputOptions.filename) + '"';
var compilerName = this.getCompilerName();
var childCompiler = compilation.createChildCompiler(compilerName, outputOptions);
childCompiler.apply(new NodeTemplatePlugin(outputOptions));
childCompiler.apply(new LibraryTemplatePlugin('result', 'var'));
childCompiler.apply(new NodeTargetPlugin());
childCompiler.apply(new SingleEntryPlugin(this.context, entryRequest));
childCompiler.apply(new SingleEntryPlugin(this.context, template));
// Create a subCache (copied from https://github.com/SanderSpies/extract-text-webpack-plugin/blob/master/loader.js)
var subCache = 'HtmlWebpackPlugin-' + outputFilename;
childCompiler.plugin('compilation', function(compilation) {
if(compilation.cache) {
if(!compilation.cache[subCache]) {
compilation.cache[subCache] = {};
if(!compilation.cache[compilerName]) {
compilation.cache[compilerName] = {};
}
compilation.cache = compilation.cache[subCache];
compilation.cache = compilation.cache[compilerName];
}
});
// Compile and return a promise
return new Promise(function (resolve, reject) {
childCompiler.runAsChild(function(err) {
// Resolve / reject the promise
if (err) {
reject(err);
} else {
Expand Down

0 comments on commit c12a4d0

Please sign in to comment.