From 370d08aa1a66ab04be606ce75edc6fa068236222 Mon Sep 17 00:00:00 2001 From: brushmate Date: Thu, 31 May 2018 11:56:35 +0200 Subject: [PATCH] fix(cli): make positional arguments required and handle errors in serve and bundle manually (#518) --- cli/index.ts | 41 +++++++++++++++++++++++++++-------------- 1 file changed, 27 insertions(+), 14 deletions(-) diff --git a/cli/index.ts b/cli/index.ts index 6281e5cac3..bff4604ec2 100644 --- a/cli/index.ts +++ b/cli/index.ts @@ -32,7 +32,7 @@ const BUNDLES_DIR = dirname(require.resolve('redoc')); /* tslint:disable-next-line */ YargsParser.command( - 'serve [spec]', + 'serve ', 'start the server', yargs => { yargs.positional('spec', { @@ -60,16 +60,22 @@ YargsParser.command( return yargs; }, async argv => { - await serve(argv.port, argv.spec, { + const config = { ssr: argv.ssr, watch: argv.watch, templateFileName: argv.template, redocOptions: argv.options || {}, - }); + }; + + try { + await serve(argv.port, argv.spec, config); + } catch (e) { + handleError(e); + } }, ) .command( - 'bundle [spec]', + 'bundle ', 'bundle spec into zero-dependency HTML-file', yargs => { yargs.positional('spec', { @@ -99,16 +105,22 @@ YargsParser.command( return yargs; }, async argv => { - await bundle(argv.spec, { + const config = { ssr: true, output: argv.o, cdn: argv.cdn, title: argv.title, templateFileName: argv.template, redocOptions: argv.options || {}, - }); + }; + + try { + await bundle(argv.spec, config); + } catch (e) { + handleError(e); + } }, - ) +) .demandCommand() .options('t', { alias: 'template', @@ -117,10 +129,6 @@ YargsParser.command( }) .options('options', { describe: 'ReDoc options, use dot notation, e.g. options.nativeScrollbars', - }) - .fail((message, error) => { - console.log(error.stack); - process.exit(1); }).argv; async function serve(port: number, pathToSpec: string, options: Options = {}) { @@ -229,13 +237,13 @@ async function getPageHTML( ssr ? 'hydrate(__redoc_state, container);' : `init("spec.json", ${JSON.stringify(redocOptions)}, container)` - }; + }; `, redocHead: ssr ? (cdn - ? '' - : ``) + css + ? '' + : ``) + css : '', title, }); @@ -296,3 +304,8 @@ function isURL(str: string): boolean { function escapeUnicode(str) { return str.replace(/\u2028|\u2029/g, m => '\\u202' + (m === '\u2028' ? '8' : '9')); } + +function handleError(error: Error) { + console.error(error.stack); + process.exit(1); +}