Задача наблюдения не продолжается после ошибки, обнаруженной Gulp-plumber, была исправлена, несмотря на обратный вызов errorHandler.

Итак, у меня есть этот аккуратный gulpfile и все такое, и он работает без сбоев, за исключением одного.

Я запускаю gulp-plumber, чтобы предотвратить сбой задачи наблюдения из-за ошибки, ошибка улавливается им, но затем, когда я исправляю ошибку, наблюдатель отказывается продолжать. Я добавил обратный вызов handleError, но он, похоже, ничего не делает, хотя в этой статье сказано, что так и должно быть. Это сводит меня с ума, потому что я знаю людей, которые добились того, чтобы это работало без каких-либо из них, но ни одно из найденных мной решений, похоже, не работает. Я что-то упустил?

РЕДАКТИРОВАТЬ: например, когда у меня есть ошибка в _lists.scss, она выглядит следующим образом:

[22:04:43] Plumber found unhandled error:
Error in plugin 'gulp-sass'
Message:
styles\partials\_lists.scss
1:1  invalid top-level expression

Означает ли это, что мне также придется обрабатывать ошибку вручную, используя on.('error', function() {})? Потому что я думал, что это была цель сантехника, чтобы убрать ручную обработку ошибок. Я даже попытался вручную отловить ошибку, используя это, но он просто выплюнул ошибку в консоли и отказался продолжать, как и раньше.

Вот часть трубы сантехника:

// Compile our SCSS into minified CSS
gulp.task('styles', function() {
  return gulp.src('styles/main.scss')
    .pipe(plumber({
      handleError: function (err) {
        console.log(err);
        this.emit('end');
      }
    }))
    .pipe(sass({ style: 'expanded' }))
    .pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4'))
    .pipe(gulp.dest('dist/styles'))
    .pipe(rename({ suffix: '.min' }))
    .pipe(minifycss())
    .pipe(gulp.dest('dist/styles'))
    .pipe(notify({ message: 'Finished compiling SCSS' }))
});

А вот и весь gulpfile.js:

var gulp         = require('gulp'),
    sass         = require('gulp-sass'),
    autoprefixer = require('gulp-autoprefixer'),
    minifycss    = require('gulp-minify-css'),
    plumber      = require('gulp-plumber'),
    jshint       = require('gulp-jshint'),
    uglify       = require('gulp-uglify'),
    imagemin     = require('gulp-imagemin'),
    rename       = require('gulp-rename'),
    concat       = require('gulp-concat'),
    notify       = require('gulp-notify'),
    cache        = require('gulp-cache'),
    livereload   = require('gulp-livereload'),
    htmlmin      = require('gulp-htmlmin'),
    del          = require('del');

// Minify our HTML
gulp.task('html', function() {
  return gulp.src('*.html')
    .pipe(htmlmin({ collapseWhitespace: true }))
    .pipe(gulp.dest('dist'))
});

// Compile our SCSS into minified CSS
gulp.task('styles', function() {
  return gulp.src('styles/main.scss')
    .pipe(plumber({
      handleError: function (err) {
        console.log(err);
        this.emit('end');
      }
    }))
    .pipe(sass({ style: 'expanded' }))
    .pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4'))
    .pipe(gulp.dest('dist/styles'))
    .pipe(rename({ suffix: '.min' }))
    .pipe(minifycss())
    .pipe(gulp.dest('dist/styles'))
    .pipe(notify({ message: 'Finished compiling SCSS' }))
});

// Concat and compile our JS into a minified file
gulp.task('scripts', function() {
  return gulp.src('scripts/**/*.js')
    .pipe(jshint())
    .pipe(jshint.reporter('default'))
    .pipe(concat('main.js'))
    .pipe(gulp.dest('dist/scripts'))
    .pipe(rename({ suffix: '.min' }))
    .pipe(uglify())
    .pipe(gulp.dest('dist/scripts'))
    .pipe(notify({ message: 'Finished compiling scripts' }));
});

// Compress our images
gulp.task('images', function() {
  return gulp.src('images/**/*.js')
    .pipe(cache(imagemin({ optimizationLevel: 5, progressive: true, interlaced: true })))
    .pipe(gulp.dest('dist/images'))
    .pipe(notify({ message: 'Finished compiling images' }));
});

// Clean/empty our dist folder
gulp.task('clean', function(cb) {
  del(['dist/styles', 'dist/scripts', 'dist/images'], cb)
});

// Run all our tasks when using 'gulp' command in CLI
gulp.task('default', ['clean'], function() {
  gulp.start('html', 'styles', 'scripts', 'images');
});

// Watch our files for changes
gulp.task('watch', function() {
  gulp.watch('styles/**/*.scss', ['styles']);
  gulp.watch('scripts/**/*.js', ['scripts']);
  gulp.watch('images/**/*', ['images']);
});

person Chrillewoodz    schedule 03.06.2015    source источник


Ответы (2)


Возможно, это просто опечатка.

Попробуйте заменить handleError на errorHandler.

person Raspo    schedule 07.06.2015
comment
Здесь та же проблема, похоже, она была изменена в этой фиксации: github.com/floatdrop/gulp -сантехник / совершить / - person cloying; 08.03.2016

Точно такая же проблема, только что решила. Очарование состоит в том, чтобы добавить

this.emit('end');

в конце вашего обработчика, чтобы изящно завершить задачу.

person ra wa    schedule 12.01.2016