Как запустить функцию во время выполнения Gulp, чтобы Gulp рассматривал функцию как задачу (выводил ее в журнал)?
Вот пример моего gulpfile.js:
async function doStaff(todo) {
// ...
}
exports.default = async () => {
// Some asynchronous logic which gets the subtasks
const todos = await myAPI.getTodos();
await Promise.all(todos.map(async todo => {
const subTask = doStuff.bind(todo);
subTask.displayName = `todo «${todo.name}»`;
await subTask(); // I want it to run as a Gulp task
}));
};
Ожидаемый результат Gulp:
Starting 'default'...
Starting 'todo «foo»'...
Starting 'todo «bar»'...
Finished 'todo «foo»' after 1.2s
Finished 'todo «bar»' after 1.5s
Finished 'default' after 2s
Фактический вывод Gulp:
Starting 'default'...
Finished 'default' after 2s
Почему: мой список подзадач не может быть получен синхронно и Gulp не поддерживает асинхронную конфигурацию, и я не собираюсь его поддерживать. Тем не менее я хочу видеть прогресс и время выполнения подзадач в выводе Gulp.
Оберните функцию в gulp.series
или gulp.parallel
, чтобы Gulp отображал ее статус. Это не выглядит элегантным решением, но это лучшее, что я нашел.
Вот универсальный пример:
function runGulpTask(func) {
return new Promise((resolve, reject) => gulp.series(func)(error => {
if (error) {
reject(error);
} else {
resolve();
}
}));
// The same solution using built-in Node.js functions:
// const {promisify} = require('util');
// return promisify(gulp.series(func))();
}
async function doStaff(todo) {
// ...
}
exports.default = async () => {
const todos = await myAPI.getTodos();
await Promise.all(todos.map(async todo => {
const subTask = doStuff.bind(todo);
subTask.displayName = `todo «${todo.name}»`;
await runGulpTask(subTask);
}));
};
Вывод Gulp такой же, как и ожидаемый.
А вот более конкретный пример:
async function doStaff(todo) {
// ...
}
exports.default = async () => {
const todos = await myAPI.getTodos();
const subTasks = todos.map(todo => {
const subTask = doStuff.bind(todo);
subTask.displayName = `todo «${todo.name}»`;
return subTask;
});
await new Promise((resolve, reject) => gulp.parallel(...subTasks)(error => {
if (error) {
reject(error);
} else {
resolve();
}
}));
// Or using built-in Node.js functions:
// const {promisify} = require('util');
// await promisify(gulp.parallel(...subTasks))();
};