diff --git a/makefile b/makefile index 7f16d650935f..6abcbdedb9c5 100644 --- a/makefile +++ b/makefile @@ -44,7 +44,7 @@ compile: install # Compile all assets in development. compile-dev: install - @NODE_ENV=development ./tools/task-runner/runner compile --dev + @NODE_ENV=development ./tools/task-runner/runner compile/index.dev # Compile atom-specific JS compile-atoms: install @@ -58,7 +58,7 @@ compile-javascript: install # PRIVATE @./tools/task-runner/runner compile/javascript compile-javascript-dev: install # PRIVATE - @./tools/task-runner/runner compile/javascript --dev + @./tools/task-runner/runner compile/javascript/index.dev compile-css: install # PRIVATE @./tools/task-runner/runner compile/css diff --git a/tools/__tasks__/compile/javascript/index.dev.js b/tools/__tasks__/compile/javascript/index.dev.js index f40e69b7e2e8..4f9540cf99dd 100644 --- a/tools/__tasks__/compile/javascript/index.dev.js +++ b/tools/__tasks__/compile/javascript/index.dev.js @@ -2,7 +2,6 @@ const inlineSVGs = require('../inline-svgs/index.js'); const clean = require('./clean.js'); const copy = require('./copy.js'); const webpack = require('./webpack.dev'); -const webpackDCR = require('./webpack-dcr.dev'); const bundlePolyfills = require('./bundle-polyfills'); const task = { @@ -13,7 +12,6 @@ const task = { clean, copy, webpack, - webpackDCR, bundlePolyfills, ], }; diff --git a/tools/task-runner/run-task-verbose-formater.js b/tools/task-runner/run-task-verbose-formater.js index bbb8da5923f7..22e514742a1a 100644 --- a/tools/task-runner/run-task-verbose-formater.js +++ b/tools/task-runner/run-task-verbose-formater.js @@ -61,4 +61,4 @@ class VerboseRenderer { } } -module.exports = VerboseRenderer; +module.exports = { VerboseRenderer }; diff --git a/tools/task-runner/runner b/tools/task-runner/runner index 35b098c32b72..e925197f0753 100755 --- a/tools/task-runner/runner +++ b/tools/task-runner/runner @@ -8,51 +8,61 @@ const path = require('path'); const os = require('os'); const yargs = require('yargs'); +const { hideBin } = require('yargs/helpers'); const { Listr } = require('listr2'); const execa = require('execa'); const chalk = require('chalk'); const figures = require('figures'); const uniq = require('lodash.uniq'); +const { VerboseRenderer } = require('./run-task-verbose-formater.js'); // name of the tasks directory const tasksDirectory = '__tasks__'; // use yargs to get a useful CLI -const { dev: IS_DEV, debug: IS_DEBUG, verbose: IS_VERBOSE, stdout: IS_STDOUT, _: TASKS } = yargs - .option('dev', { - demand: false, - describe: 'Prefer the dev version of the task, if it exits.', - type: 'boolean', - nargs: 0, - }) - .option('debug', { - demand: false, - describe: 'Log everything there is to log.', - type: 'boolean', - nargs: 0, - }) - .option('verbose', { - demand: false, - describe: 'Log everything there is to log with a simple format for the output.', - type: 'boolean', - nargs: 0, - }) - .option('stdout', { - demand: false, - describe: 'Log all stdout once the tasks are finished (errors are logged by default).', - type: 'boolean', - nargs: 0, - }) - .usage('Usage: $0 [] [--dev]') - .command('task', `Run a task defined in '${tasksDirectory}'.`) - .example('$0 copy', 'Run all the copy tasks.') - .example('$0 javascript/copy', 'Run the javascript copy task.') - .example('$0 javascript/copy --dev', 'Run the javascript copy task, and prefer the development version, if it exists.') - .example('$0 javascript/copy css/copy --dev', 'Run the javascript and css copy tasks, and prefer the development versions, if they exist.') - .demand(1) - .help().alias('h', 'help') // eslint-disable-line newline-per-chained-call - .version().alias('v', 'version') // eslint-disable-line newline-per-chained-call - .argv; +const { + debug: IS_DEBUG, + verbose: IS_VERBOSE, + stdout: IS_STDOUT, + _: TASKS, +} = yargs(hideBin(process.argv)) + .option('debug', { + demand: false, + describe: 'Log everything there is to log.', + type: 'boolean', + nargs: 0, + }) + .option('verbose', { + demand: false, + describe: + 'Log everything there is to log with a simple format for the output.', + type: 'boolean', + nargs: 0, + }) + .option('stdout', { + demand: false, + describe: + 'Log all stdout once the tasks are finished (errors are logged by default).', + type: 'boolean', + nargs: 0, + }) + .usage('Usage: $0 [] [--dev]') + .command('task', `Run a task defined in '${tasksDirectory}'.`) + .example('$0 copy', 'Run all the copy tasks.') + .example('$0 javascript/copy', 'Run the javascript copy task.') + .example( + '$0 javascript/copy --dev', + 'Run the javascript copy task, and prefer the development version, if it exists.', + ) + .example( + '$0 javascript/copy css/copy --dev', + 'Run the javascript and css copy tasks, and prefer the development versions, if they exist.', + ) + .demand(1) + .help() + .alias('h', 'help') // eslint-disable-line newline-per-chained-call + .version() + .alias('v', 'version').argv; // eslint-disable-line newline-per-chained-call // if this is true, we log as much as we can const VERBOSE = IS_VERBOSE || IS_DEBUG; @@ -66,124 +76,153 @@ const cache = []; // use exaca to run simple terminal commands const exec = (task, onError, ctx) => { - const [cmd, ...args] = task.trim().split(' '); - - return execa(cmd, args) - .then((result) => { - // store any stdout incase we need it later - if (result.stdout) ctx.stdouts.push(result.stdout); - }) - .catch((e) => { - // if the task supplies an `onError` function, run it - if (typeof onError === 'function') onError(ctx); - // continue with a fake rejected promise - return Promise.reject(e); - }); + const [cmd, ...args] = task.trim().split(' '); + + return execa(cmd, args) + .then((result) => { + // store any stdout incase we need it later + if (result.stdout) ctx.stdouts.push(result.stdout); + }) + .catch((e) => { + // if the task supplies an `onError` function, run it + if (typeof onError === 'function') onError(ctx); + // continue with a fake rejected promise + return Promise.reject(e); + }); }; const getCpuCount = () => os.cpus().length; // turn a list of our tasks into objects listr can use function listrify(steps, { concurrent = false } = {}) { - const listrTasks = steps - .map((step) => { - const { description: title, task, concurrent: isConcurrent, onError } = step; - - // if another task has included this one, don't run it again - const skip = cache.indexOf(step) !== -1 ? () => 'Skipping: already run by another task' : false; - cache.push(step); - - // if the task is a set of subtasks, prepare them - if (Array.isArray(task)) { - return { - title, - task: () => listrify(task.map((_task) => { - if (_task.task) return _task; - if (typeof _task === 'string') return { title, task: ctx => exec(_task, onError, ctx), skip }; - return { title, task: _task, skip }; - }), { concurrent: VERBOSE ? false : (isConcurrent ? getCpuCount() : false) }), - skip, - }; - } - - // treat tasks that are strings as terminal commands - if (typeof task === 'string') return { title, task: ctx => exec(task, onError, ctx), skip }; - - // assume the task is a function - // if it's not, listr will blow up anyway, which is fine - return { - title, - task: ctx => new Promise((resolve, reject) => { - try { - resolve(task(ctx)); - } catch (e) { - if (typeof onError === 'function') onError(ctx); - if (VERBOSE) console.log(e); - reject(e); - } - }), - skip, - }; - }); - - let renderer = 'default'; - if (IS_VERBOSE) renderer = require('./run-task-verbose-formater'); - - return new Listr(listrTasks, { - concurrent: concurrent ? getCpuCount() : false, - collapse: true, - renderer, - }); + const listrTasks = steps.map((step) => { + const { + description: title, + task, + concurrent: isConcurrent, + onError, + } = step; + + // if another task has included this one, don't run it again + const skip = + cache.indexOf(step) !== -1 + ? () => 'Skipping: already run by another task' + : false; + cache.push(step); + + // if the task is a set of subtasks, prepare them + if (Array.isArray(task)) { + return { + title, + task: () => + listrify( + task.map((_task) => { + if (_task.task) return _task; + if (typeof _task === 'string') + return { + title, + task: (ctx) => exec(_task, onError, ctx), + skip, + }; + return { title, task: _task, skip }; + }), + { + concurrent: VERBOSE + ? false + : isConcurrent + ? getCpuCount() + : false, + }, + ), + skip, + }; + } + + // treat tasks that are strings as terminal commands + if (typeof task === 'string') + return { title, task: (ctx) => exec(task, onError, ctx), skip }; + + // assume the task is a function + // if it's not, listr will blow up anyway, which is fine + return { + title, + task: (ctx) => + new Promise((resolve, reject) => { + try { + resolve(task(ctx)); + } catch (e) { + if (typeof onError === 'function') onError(ctx); + if (VERBOSE) console.log(e); + reject(e); + } + }), + skip, + }; + }); + + const renderer = IS_VERBOSE ? VerboseRenderer : 'default'; + + return new Listr(listrTasks, { + concurrent: concurrent ? getCpuCount() : false, + collapse: true, + renderer, + }); } // resolve the tasks from yargs to actual files const getTasksFromModule = (taskName) => { - try { - const modulePath = path.resolve(taskSrc, taskName); - if (IS_DEV) { - try { - return require(`${modulePath}.dev`); - } catch (e) { /* do nothing */ } - try { - return require(`${modulePath}/index.dev`); - } catch (e) { /* do nothing */ } - } - return require(modulePath); - } catch (e) { - // we can't find any modules, or something else has gone wrong in resolving it - // so output an erroring task - return { - description: `${chalk.red(taskName)} failed:`, - task: () => Promise.reject(e), - }; - } + try { + const modulePath = path.resolve(taskSrc, taskName); + return require(modulePath); + } catch (e) { + // we can't find any modules, or something else has gone wrong in resolving it + // so output an erroring task + return { + description: `${chalk.red(taskName)} failed:`, + task: () => Promise.reject(e), + }; + } }; // get a list of the tasks we're going to run const taskModules = TASKS.map(getTasksFromModule); // run them! -listrify(taskModules).run({ - // we're adding these to the [listr context](https://github.com/SamVerschueren/listr#context) - messages: [], - stdouts: [], -}).catch((e) => { - // something went wrong, so log whatever we have - if (!e.stderr && !e.stdout) console.log(e); - if (e.stderr) console.error(`\n${e.stderr.trim()}`); - if (e.stdout) console.log(`\n${e.stdout.trim()}`); - return Object.assign(e.context, { error: true }); -}).then((ctx) => { - if (IS_STDOUT) ctx.stdouts.forEach(stdout => console.log(stdout.toString().trim())); - - if (ctx.messages.length) { - console.log(''); - uniq(ctx.messages).forEach(message => console.log(chalk.dim(`${figures.arrowRight} ${message.split('\n').join('\n ')}`))); - } - - if (ctx.error) { - console.log(''); - // if something's gone wrong, fail hard - process.exit(1); - } -}); +listrify(taskModules) + .run({ + // we're adding these to the [listr context](https://github.com/SamVerschueren/listr#context) + messages: [], + stdouts: [], + }) + .catch((e) => { + // something went wrong, so log whatever we have + if (!e.stderr && !e.stdout) console.log(e); + if (e.stderr) console.error(`\n${e.stderr.trim()}`); + if (e.stdout) console.log(`\n${e.stdout.trim()}`); + return Object.assign(e.context, { error: true }); + }) + .then((ctx) => { + if (IS_STDOUT) + ctx.stdouts.forEach((stdout) => + console.log(stdout.toString().trim()), + ); + + if (ctx.messages.length) { + console.log(''); + uniq(ctx.messages).forEach((message) => + console.log( + chalk.dim( + `${figures.arrowRight} ${message + .split('\n') + .join('\n ')}`, + ), + ), + ); + } + + if (ctx.error) { + console.log(''); + // if something's gone wrong, fail hard + process.exit(1); + } + });