diff --git a/client/cmdparser.c b/client/cmdparser.c index 4f6e24635..1afeb9307 100644 --- a/client/cmdparser.c +++ b/client/cmdparser.c @@ -26,7 +26,7 @@ void CmdsHelp(const command_t Commands[]) } } -void CmdsParse(const command_t Commands[], const char *Cmd) +void CmdsParse(const command_t Commands[], char *Cmd) { char cmd_name[32]; int len = 0; @@ -53,9 +53,11 @@ void CmdsParse(const command_t Commands[], const char *Cmd) if (Commands[i].Name) { while (Cmd[len] == ' ') ++len; + while (Cmd[strlen(Cmd) - 1] == ' ') + Cmd[strlen(Cmd) - 1] = '\0'; Commands[i].Parse(Cmd + len); } else { - // show help (always first in array) for selected hierarchy or if command not recognised + // show help for selected hierarchy or if command not recognised CmdsHelp(Commands); } } diff --git a/client/cmdparser.h b/client/cmdparser.h index 28c2e66ef..1002df8b5 100644 --- a/client/cmdparser.h +++ b/client/cmdparser.h @@ -24,6 +24,6 @@ typedef struct command_s // Print help for each command in the command array void CmdsHelp(const command_t Commands[]); // Parse a command line -void CmdsParse(const command_t Commands[], const char *Cmd); +void CmdsParse(const command_t Commands[], char *Cmd); #endif