2016-04-18 115 views
1

在這裏我沒有得到任何輸出,並命令將永遠運行下去:作爲命令運行時在Grunt中顯示輸出?

grunt.registerTask('serve', function() { 
    var done = this.async(); 

    grunt.util.spawn({ 
     cmd: 'jekyll', 
     args: ['serve'], 
     stdio: 'inherit' 
    }, function (err, res, exit_code) { 
     res.stdout && console.info(res.stdout); 
     exit_code && console.error(res.stderr); 
     done(err); 
    }); 
}); 

我想輸出(和命令運行,直到錯誤或中斷)。

回答

1

試試這個:

grunt.registerTask('serve', function(){ 
    var done = this.async(); 

    var child = grunt.util.spawn({ 
     cmd: 'jekyll', 
     args: ['serve'] 
    }, function(){ 
     ... 
    }); 

    child.stdout.pipe(process.stdout); 
    child.stderr.pipe(process.stderr); 
}); 

參見:Grunt spawned process not capturing output

0

您可以使用grunt log

提供以下功能

grunt.log.write(msg) 
grunt.log.writeln([msg]) 
grunt.log.error([msg]) 
grunt.log.errorlns(msg) 
grunt.log.ok([msg]) 
grunt.log.oklns(msg) 
grunt.log.subhead(msg) 
grunt.log.writeflags(obj, prefix) 
grunt.log.debug(msg) 
1

感謝您的答案,@ Lihau譚接近到正確的一個。

結合這個問題的答案我的嘗試,我想出了這個解決方案:

grunt.registerTask('serve', function() { 
    var child = grunt.util.spawn({ 
     cmd: 'jekyll', 
     args: ['serve', '-P', process.env.PORT || 4001], 
     stdio: 'inherit' 
    }, this.async()); 

    child.stdout.pipe(process.stdout); 
    child.stderr.pipe(process.stderr); 
}); 
相關問題