Gulp退出太早了

时间:2014-02-07 17:39:39

标签: javascript gulp

有简单的gulp文件,但它没有按预期执行:

var gulp = require('gulp');
var rename = require('gulp-rename');
var mapStream = require('map-stream');
var fs = require('fs');

gulp.task('default', function () {
    gulp.src('123.js')
        .pipe(log('before'))
        .pipe(rename({prefix: '_'}))
        .pipe(gulp.dest('.'))
        .pipe(log('after'))
    ;
});

function log (txt) {
    return mapStream(function (file, cb) {
        console.log(txt, fs.statSync(file.path).size, !!file.contents.toString());
        cb();
    });
}

仅记录“之前”,但不记录“之后”。为什么呢?

2 个答案:

答案 0 :(得分:1)

您需要return the stream

gulp.task('default', function () {
    return gulp.src('123.js')
        .pipe(log('before'))
        .pipe(rename({prefix: '_'}))
        .pipe(gulp.dest('.'))
        .pipe(log('after'));
});

答案 1 :(得分:1)

除了按照Sindre的建议返回流之外,还需要将'file'传递给'map-stream'的回调函数,以便通过流传递数据。

function log (txt) {
    return mapStream(function (file, cb) {
        console.log(txt, fs.statSync(file.path).size, !!file.contents.toString());
        cb(null, file);
    });
}