Работа с асинхронными задачами в Gulp 4

Я обновил gulp до версии 4.0.0, прочитал инструкцию https://github.com/gulpjs/gulp/tree/master/docs/getting-started и полностью переписал код.

'use strict';

const { series, 
        parallel, 
        src, 
        dest, 
        watch }    = require('gulp'),
      sass         = require('gulp-sass'),
      autoprefixer = require('gulp-autoprefixer'),
      gcmq         = require('gulp-group-css-media-queries'),
      sourcemaps   = require('gulp-sourcemaps'),
      notify       = require('gulp-notify'),
      gutil        = require('gulp-util'),
      ftp          = require('vinyl-ftp'),
      cleanCSS     = require('gulp-clean-css'),
      rename       = require('gulp-rename'),
      uglify       = require('gulp-uglify'),
      concat       = require('gulp-concat'),
      del          = require('del'),
      csscomb      = require('gulp-csscomb'),
      changed      = require('gulp-changed'),
      gulpif       = require('gulp-if');

function comb () {
  return src(path.scss.files)
    .pipe(csscomb('.csscomb.json')
      .on("error", notify.onError(function (error) {
        return "File: " + error.message;
      })))
    .pipe(dest(path.scss.combFolder)
      .on('end', () => { if(true) console.log('   ---------------   completed COMB'); }));
}

function combUpdate () {
  return src(path.scss.combFiles)
    .pipe(dest(path.scss.folder)
      .on('end', () => { if(true) console.log('   ---------------   updated COMB -> SCSS'); }));
}

function scss () {
  return src(path.scss.combFiles)
    .pipe(sourcemaps.init())
    .pipe(csscomb('.csscomb.json')
      .on("error", notify.onError(function (error) {
      return "File: " + error.message;
    })))
    .pipe(sass()
      .on("error", notify.onError(function (error) {
        return "File: " + error.message;
      })))
    .pipe(gcmq())
    .pipe(autoprefixer({ browsers: ['last 5 versions', '> 1%'], cascade: true }))
    .pipe(notify({ message: 'Compiled!', sound: false }))
    .pipe(sourcemaps.write('./'))
    .pipe(dest(path.css.folder)
      .on('end', () => { if(true) console.log('   ---------------   completed SCSS'); }));
}

function mincss () {
  return src([path.css.files,
      '!' + path.css.filesMin,
      '!' + path.css.folder + '**/font-awesome.css',
      '!' + path.css.folder + '**/normalize.css'
    ])
    .pipe(cleanCSS({ specialComments: 'false' }))
    .pipe(rename({ suffix: '.min' }))
    .pipe(dest(path.css.folder)
      .on('end', () => { if(true) console.log('   ---------------   completed MINIFY (.min.css)'); }));
}

function minjs () {
  return src([path.js.files, '!' + path.js.filesMin])
    .pipe(uglify())
    .pipe(rename({ suffix: '.min' }))
    .pipe(dest(path.js.folder)
      .on('end', () => { if(true) console.log('   ---------------   completed UGLIFY (.min.js)'); }));
}

function processBuild (srcUrl, baseUrl, destUrl, newest) {
  return src(srcUrl)
    .pipe(gulpif(newest, changed(path.tmp.temp + baseUrl)))
    .pipe(dest(destUrl + baseUrl));
}

function setBuild (destUrl, newest) {
  processBuild(path.css.files,    path.css.folder,    destUrl, newest); /*CSS*/
  processBuild(path.css.mapFiles, path.css.mapFolder, destUrl, newest); /*MAP*/
  processBuild(path.html.files,   path.html.folder,   destUrl, newest); /*HTML*/
  processBuild(path.js.files,     path.js.folder,     destUrl, newest); /*JS*/
  return Promise.resolve('finished');
}

function tempBuild () { return setBuild(path.tmp.temp, false); }
function distBuild () { return setBuild(path.tmp.dist, false); }
function upldBuild (cb) {
  setBuild(path.tmp.upld, true);
  return Promise.resolve('finished');
  cb();
}
function cleanTemp () { return del(path.tmp.temp, {force: true}); };
function cleanDist () { return del(path.tmp.dist, {force: true}); };
function cleanUpld () { return del(path.tmp.upld, {force: true}); }

function watchFiles() {
  watch(path.scss.files, 
        series(comb, scss, mincss, 
          cleanUpld, upldBuild, cleanDist, distBuild, cleanTemp, tempBuild));
  watch([path.js.files, '!' + path.js.filesMin], 
        series(minjs, 
          cleanUpld, upldBuild, cleanDist, distBuild, cleanTemp, tempBuild));
  watch(path.html.files, 
    series(cleanUpld, upldBuild,
          delay, upload2mbc,
          cleanDist, distBuild, cleanTemp, tempBuild));
}

function delay (done) {
  setTimeout(done, 100);
}

function upload2mbc() {
  var upload = [path.tmp.upld + '**/*.*'];
  return src( upload, { base: '', buffer: false } )
    .pipe(conn.newer('/public_html/ext' ))
    .pipe(conn.dest('/public_html/ext' )
      .on('end', () => { if (true) console.log('   ---------------   completed FILES UPLOADED'); }));
}

exports.default = watchFiles;

exports.upload = upload2mbc;

exports.updateSass = series(comb, combUpdate);

upload2mbc ничего не отправляет на сервер, потому что upldBuild не успел собрать папку. http://prntscr.com/l8fi9g

    watch(path.html.files, 
    series(cleanUpld, upldBuild,
          upload2mbc,
          cleanDist, distBuild, cleanTemp, tempBuild));

если я запускаю обе задачи по отдельности - все работает. http://prntscr.com/l8fimr

function upldBuild () {
  setBuild(path.tmp.upld, true);
  return Promise.resolve('finished');
}

function upldBuild (cb) {
  return  setBuild(path.tmp.upld, true);
  cb();
}

Я уже выкопал много материала, но я все еще не могу понять, где моя ошибка. Заранее спасибо за помощь.

0 ответов

Другие вопросы по тегам