Ответ 1
Функция gulp.watch()
возвращает объект, который, помимо прочего, имеет метод end()
, который вы можете вызвать - см. определение в модуле glob-watcher.
Вы можете сделать что-то в этом направлении:
var gulp = require('gulp');
function doGitCheckout(callback) {
console.log('doing checkout...');
setTimeout(function() {
console.log('done checkout...');
callback();
}, 1000);
}
var watcher;
gulp.task('watch:start', function() {
if (!watcher) {
watcher = gulp.watch('dist/**/*', ['build']);
console.log('started watcher');
}
});
gulp.task('watch:stop', function() {
if (watcher) {
watcher.end();
watcher = null;
console.log('stopped watcher');
}
});
gulp.task('git:checkout', ['watch:stop'], function(cb) {
console.log('isWatching = ' + !!watcher);
// Start the Git checkout...
doGitCheckout(function() {
// The Git checkout is finished!
gulp.start('watch:start', function() {
cb();
});
});
});
gulp.task('default', ['watch:start', 'git:checkout']);
Таким образом, мы сохраняем ссылку на объект наблюдателя, когда мы начинаем наблюдать, и у вас есть задача остановить наблюдателя при запуске. Наша задача Git начинается с watch:stop
, а затем запускает проверку Git с обратным вызовом, когда она завершена. Обратный вызов запускает задачу watch:start
, и когда это будет сделано, мы, наконец, запускаем функцию cb
, чтобы указать, что git:checkout
завершено!
Альтернативой может быть использование add(pattern)
и remove(pattern)
в объекте watch, чтобы отключить его, а затем снова включить вместо того, чтобы уничтожить объект и воссоздать его.