diff options
author | Florian Dold <florian.dold@gmail.com> | 2018-09-20 02:56:13 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2018-09-20 02:56:13 +0200 |
commit | bbff7403fbf46f9ad92240ac213df8d30ef31b64 (patch) | |
tree | c58400ec5124da1c7d56b01aea83309f80a56c3b /node_modules/flagged-respawn/index.js | |
parent | 003fb34971cf63466184351b4db5f7c67df4f444 (diff) |
update packages
Diffstat (limited to 'node_modules/flagged-respawn/index.js')
-rw-r--r-- | node_modules/flagged-respawn/index.js | 38 |
1 files changed, 36 insertions, 2 deletions
diff --git a/node_modules/flagged-respawn/index.js b/node_modules/flagged-respawn/index.js index b1234003e..15b4bf70d 100644 --- a/node_modules/flagged-respawn/index.js +++ b/node_modules/flagged-respawn/index.js @@ -1,18 +1,52 @@ const reorder = require('./lib/reorder'); const respawn = require('./lib/respawn'); +const remover = require('./lib/remover'); -module.exports = function (flags, argv, execute) { +const FORBID_RESPAWNING_FLAG = '--no-respawning'; + +module.exports = function (flags, argv, forcedFlags, execute) { if (!flags) { throw new Error('You must specify flags to respawn with.'); } if (!argv) { throw new Error('You must specify an argv array.'); } + + if (typeof forcedFlags === 'function') { + execute = forcedFlags; + forcedFlags = []; + } + + if (typeof forcedFlags === 'string') { + forcedFlags = [forcedFlags]; + } + + if (!Array.isArray(forcedFlags)) { + forcedFlags = []; + } + + var index = argv.indexOf(FORBID_RESPAWNING_FLAG); + if (index >= 0) { + argv = argv.slice(0, index).concat(argv.slice(index + 1)); + argv = remover(flags, argv); + execute(true, process, argv); + return; + } + var proc = process; var reordered = reorder(flags, argv); var ready = JSON.stringify(argv) === JSON.stringify(reordered); + + if (forcedFlags.length) { + reordered = reordered.slice(0, 1) + .concat(forcedFlags) + .concat(reordered.slice(1)); + ready = false; + } + if (!ready) { + reordered.push(FORBID_RESPAWNING_FLAG); proc = respawn(reordered); } - execute(ready, proc); + execute(ready, proc, reordered); }; |