我正在重构我的 Gulp 构建过程,因此用户不必输入V=1.2.88
等。
相反,我希望用户只需键入major gulp build
,minor gulp build
或patch gulp build
. 然后当然会迭代版本号。
为了使它工作,但是我需要 gulp 来读取创建的最后一个构建的文件夹名称:
我当前的 Gulp 任务生成版本号:
var version = '';
var env = process.env.V; // V={version number} ie: V=1.0.1 gulp build
gulp.task('version', function() {
return printOut(env);
});
function errorlog(err) {
console.log(err.message);
this.emit('end');
}
function printOut(ver) {
gutil.log(gutil.colors.blue.bold('Last build: '+paths.last));
version = ver;
if (version === undefined) {
version = '0.0.0';
}
gutil.log(gutil.colors.blue.bold('##################################################'));
gutil.log(gutil.colors.blue.bold(' Building Dashboard version '+version));
gutil.log(gutil.colors.green.bold('~~ All change is detectable ~~'));
gutil.log(gutil.colors.blue.bold('##################################################'));
}
有人知道如何在 Gulp 中完成此任务吗?
这是我到目前为止发现的 Gulp-folders
所以使用Gulp-folders
插件我创建了以下首先运行的任务:
gulp.task('build:getLastBuild', folders(paths.lastBuild, function(folder) {
console.log( 'Last version number is: '+folder);
return lastVersion = folder;
//This will loop over all folders inside pathToFolder main, secondary
//Return stream so gulp-folders can concatenate all of them
//so you still can use safely use gulp multitasking
// return gutil.colors.blue.bold('Last build folder: '+folder);
// return gulp.src(path.join(paths.lastBuild, folder))
// .pipe(console.log(' Getting last version number: '+folder))
// .pipe(lastVersion = folder);
}));
现在,当我运行我的构建时,请在下面查看!我在 console.log 中获得了文件夹的名称,但是我的过程出错了:(
TypeError:e.pipe 不是函数