webpack/lib/SourceMapDevToolPlugin.js

98 lines
4.3 KiB
JavaScript
Raw Normal View History

2013-03-26 23:54:41 +08:00
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
var path = require("path");
2013-03-26 23:54:41 +08:00
var RequestShortener = require("./RequestShortener");
var Template = require("./Template");
var ConcatSource = require("webpack-core/lib/ConcatSource");
var RawSource = require("webpack-core/lib/RawSource");
2014-07-18 19:31:50 +08:00
var ModuleFilenameHelpers = require("./ModuleFilenameHelpers");
2013-03-26 23:54:41 +08:00
2014-07-18 19:31:50 +08:00
function SourceMapDevToolPlugin(sourceMapFilename, sourceMappingURLComment, moduleFilenameTemplate, fallbackModuleFilenameTemplate) {
2013-03-26 23:54:41 +08:00
this.sourceMapFilename = sourceMapFilename;
2014-05-26 15:45:42 +08:00
this.sourceMappingURLComment = sourceMappingURLComment || "\n//# sourceMappingURL=[url]";
2014-07-18 19:31:50 +08:00
this.moduleFilenameTemplate = moduleFilenameTemplate || "webpack:///[resourcePath]";
this.fallbackModuleFilenameTemplate = fallbackModuleFilenameTemplate || "webpack:///[resourcePath]?[hash]";
2013-03-26 23:54:41 +08:00
}
module.exports = SourceMapDevToolPlugin;
SourceMapDevToolPlugin.prototype.apply = function(compiler) {
var sourceMapFilename = this.sourceMapFilename;
var sourceMappingURLComment = this.sourceMappingURLComment;
2014-07-18 19:31:50 +08:00
var moduleFilenameTemplate = this.moduleFilenameTemplate;
var fallbackModuleFilenameTemplate = this.fallbackModuleFilenameTemplate;
var requestShortener = new RequestShortener(compiler.context);
2013-03-26 23:54:41 +08:00
compiler.plugin("compilation", function(compilation) {
2013-10-14 19:59:44 +08:00
compilation.plugin("build-module", function(module) {
module.useSourceMap = true;
});
2013-03-26 23:54:41 +08:00
compilation.plugin("after-optimize-chunk-assets", function(chunks) {
chunks.forEach(function(chunk) {
chunk.files.slice().forEach(function(file) {
var asset = this.assets[file];
2013-07-04 17:55:37 +08:00
if(asset.__SourceMapDevTool_Data) {
var data = asset.__SourceMapDevTool_Data;
for(var file in data) {
this.assets[file] = data[file];
}
return;
}
2013-03-26 23:54:41 +08:00
var sourceMap = asset.map();
if(sourceMap) {
2014-07-18 19:31:50 +08:00
var modules = sourceMap.sources.map(function(source) {
2013-03-26 23:54:41 +08:00
var module = compilation.findModule(source);
2014-07-18 19:31:50 +08:00
return module || source;
});
var moduleFilenames = modules.map(function(module) {
return ModuleFilenameHelpers.createFilename(module, moduleFilenameTemplate, requestShortener);
});
moduleFilenames = ModuleFilenameHelpers.replaceDuplicates(moduleFilenames, function(filename, i) {
return ModuleFilenameHelpers.createFilename(modules[i], fallbackModuleFilenameTemplate, requestShortener);
});
moduleFilenames = ModuleFilenameHelpers.replaceDuplicates(moduleFilenames, function(filename, i, n) {
for(var j = 0; j < n; j++)
filename += "*";
return filename;
});
sourceMap.sources = moduleFilenames;
if(sourceMap.sourcesContent) {
sourceMap.sourcesContent = sourceMap.sourcesContent.map(function(content, i) {
return content + "\n\n\n" + ModuleFilenameHelpers.createFooter(modules[i], requestShortener);
});
2013-04-02 15:14:19 +08:00
}
2014-07-18 19:31:50 +08:00
sourceMap.sourceRoot = "";
sourceMap.file = file;
2013-07-04 17:55:37 +08:00
asset.__SourceMapDevTool_Data = {};
2013-03-26 23:54:41 +08:00
if(sourceMapFilename) {
var filename = file, query = "";
var idx = filename.indexOf("?");
if(idx >= 0) {
query = filename.substr(idx);
filename = filename.substr(0, idx);
}
2013-03-26 23:54:41 +08:00
var sourceMapFile = sourceMapFilename
.replace(Template.REGEXP_FILE, filename)
.replace(Template.REGEXP_QUERY, query)
.replace(Template.REGEXP_FILEBASE, basename(filename))
2013-03-26 23:54:41 +08:00
.replace(Template.REGEXP_HASH, this.hash)
.replace(Template.REGEXP_ID, chunk.id);
var sourceMapUrl = path.relative(path.dirname(file), sourceMapFile).replace(/\\/g, "/");
asset.__SourceMapDevTool_Data[file] = this.assets[file] = new ConcatSource(asset, sourceMappingURLComment.replace(/\[url\]/g, sourceMapUrl));
2013-07-04 17:55:37 +08:00
asset.__SourceMapDevTool_Data[sourceMapFile] = this.assets[sourceMapFile] = new RawSource(JSON.stringify(sourceMap));
2013-03-26 23:54:41 +08:00
chunk.files.push(sourceMapFile);
} else {
2014-03-21 23:16:31 +08:00
asset.__SourceMapDevTool_Data[file] = this.assets[file] = new ConcatSource(asset, sourceMappingURLComment.replace(/\[url\]/g, "data:application/json;base64," + new Buffer(JSON.stringify(sourceMap)).toString("base64")));
2013-03-26 23:54:41 +08:00
}
}
}, this);
}, this);
});
});
};
function basename(name) {
if(name.indexOf("/") < 0) return name;
return name.substr(name.lastIndexOf("/")+1);
}