Quiero iniciar sesión en stdout (el entorno de configuración) cuando una tarea de gulp se está ejecutando o se ha ejecutado.
Algo como esto:
gulp.task('scripts', function () {
var enviroment = argv.env || 'development';
var config = gulp.src('config/' + enviroment + '.json')
.pipe(ngConstant({name: 'app.config'}));
var scripts = gulp.src('js/*');
return es.merge(config, scripts)
.pipe(concat('app.js'))
.pipe(gulp.dest('app/dist'))
.on('success', function() {
console.log('Configured environment: ' + environment);
});
});
No estoy seguro de a qué evento debería responder ni dónde encontrar una lista de estos. ¿Algún consejo? Muchas gracias.
fuente

.on('end', () => gutil.log('ES6 arrow syntax for simplicity...') )console.logfunciona?.on('end', function(){ console.log('Almost there...'); })funciona para mí.gulp-utilha quedado obsoleto: medium.com/gulpjs/gulp-util-ca3b1f9f9ac5(TENGA EN CUENTA: en diciembre de 2017, el
gulp-utilmódulo quedó obsoleto).Para aprovechar la respuesta de Jacob Budin , recientemente probé esto y lo encontré útil.
var gulp = require("gulp"); var util = require("gulp-util"); var changed = require("gulp-changed"); gulp.task("copyIfChanged", function() { var nSrc=0, nDes=0, dest="build/js"; gulp.src("app/**/*.js") .on("data", function() { nSrc+=1;}) .pipe(changed(dest)) //filter out src files not newer than dest .pipe(gulp.dest(dest)) .on("data", function() { nDes+=1;}) .on("finish", function() { util.log("Results for app/**/*.js"); util.log("# src files: ", nSrc); util.log("# dest files:", nDes); }); }fuente
.on("end")y.on("finish")diferir en que?writable.on('finish')se disparará cuandoreadable.on('end')no. El evento exacto puede no importar en este caso; estaba más enfocado en registrar estadísticas útiles.'finish'y'end'son de las clasesstream.Writableystream.Readable, respectivamente". @FrankNockegulp-utilha sido obsoleto, usefancy-logen su lugarLamentablemente, está
gulp.utildepreciado. Utilice en sufancy-loglugar: https://www.npmjs.com/package/fancy-log .fuente