From 2d0e20b663dd1e6d45eea906b29739da3daad7c5 Mon Sep 17 00:00:00 2001 From: Nameer Haider Date: Sat, 17 Feb 2024 18:06:21 +0300 Subject: [PATCH] removing options prefix --- src/{ => commanders}/commander.ts | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) rename src/{ => commanders}/commander.ts (86%) diff --git a/src/commander.ts b/src/commanders/commander.ts similarity index 86% rename from src/commander.ts rename to src/commanders/commander.ts index fe9f4d3..db74a6b 100644 --- a/src/commander.ts +++ b/src/commanders/commander.ts @@ -54,6 +54,10 @@ export class Commander { } private extractCommand(args: string[], command: string): string | null { + if (args.length === 0) { + return null; + } + const commandExists = command == args[0]; if (commandExists) { @@ -64,11 +68,19 @@ export class Commander { } } + private removeCommandOptionPrefix(args: string) { + return args.replace(/^-+/g, ''); + } + private getCommandOptions(args: string[], options: CommandOptions[]) { + if (args.length === 0 || options.length === 0) { + return {}; + } const finalOptions: Record = {}; for (const option of options) { if (option.option === args[0] || option.shortOption === args[0]) { - finalOptions[args[0]] = args[1]; + const key = this.removeCommandOptionPrefix(args[0]); + finalOptions[key] = args[1]; args.splice(0, 2); } } @@ -91,6 +103,9 @@ export class Commander { } private checkSubCommands(subCommands: Commander[], args: string[]) { + if (args.length === 0 || subCommands.length === 0) { + return true; + } const isCommandOption = args[0].startsWith('-'); const isSubcommand = subCommands.find((subCommand) => subCommand.command === args[0]) !==