我有一个带有多个插件的 git 存储库(一个主要插件和几个仅用于主要插件的插件)。我正在使用这种方法进行分发,因为 bower 没有提供一种让每个 git repo 拥有多个插件的方法。
因此,我需要缩小每个插件,为每个插件创建一个源映射,然后将每个插件放入与 git 子模块相对应的单独分发文件夹中,按照惯例,我将其命名为与插件相同以使其简单。我想出了以下 Gulp 脚本,它可以一步完成,这主要基于我在此处找到的答案。
return gulp.src(['./jquery.dirtyforms.js', './helpers/*.js', './dialogs/*.js'], { base: './' })
.pipe(jshint())
.pipe(jshint.reporter(stylish))
.pipe(rename(function (path) {
var baseName = path.basename;
var dirName = path.dirname;
if (dirName == 'helpers' || dirName == 'dialogs') {
path.basename = 'jquery.dirtyforms.' + dirName + '.' + baseName;
console.log(path.basename);
}
path.dirname = path.basename;
}))
.pipe(gulp.dest(distributionFolder))
.pipe(sourcemaps.init())
.pipe(rename(function (path) {
var baseName = path.basename;
var dirName = path.dirname;
if (dirName == 'helpers' || dirName == 'dialogs') {
path.basename = 'jquery.dirtyforms.' + dirName + '.' + baseName;
console.log(path.basename);
}
path.dirname = path.basename;
path.extname = '.min.js';
}))
.pipe(uglify({
outSourceMap: true,
sourceRoot: '/'
}))
.pipe(gulp.dest(distributionFolder))
.pipe(sourcemaps.write('.', {
includeContent: true,
sourceRoot: '/'
}))
.pipe(gulp.dest(distributionFolder));
它完全符合我的要求,除了一件事。为每个插件生成的 sourcemap 文件在路径中包含子目录。由于插件的最终目的地不会包含此路径,因此这是无效的。
在jquery.dirtyforms.min.js.map
文件中:
{"version":3,"sources":["jquery.dirtyforms/jquery.dirtyforms.min.js"]...
应该
{"version":3,"sources":["jquery.dirtyforms.min.js"]...
在jquery.dirtyforms.min.js
文件中:
//# sourceMappingURL=../jquery.dirtyforms/jquery.dirtyforms.min.js.map
应该
//# sourceMappingURL=jquery.dirtyforms.min.js.map
我挖掘了 gulp-sourcemaps 的源代码,试图找到一个覆盖文件名的选项,但似乎没有。
我为此提出的两种可能的解决方案是:
- 使用正则表达式在每个文件中进行替换
- 在 中生成文件,
distributionFolder
然后在生成后将它们移动到正确的子文件夹中
但这两个似乎都是黑客。如果流首先正确地创建它们会更好。有没有办法做到这一点?