summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDean Glazeski <dnglaze@gmail.com>2009-12-31 16:01:32 -0600
committerDavid Brownell <dbrownell@users.sourceforge.net>2010-01-02 02:10:55 -0800
commit9d167d62f2eadf81e0028e471e05154c9aabbbfb (patch)
treec2ede3e076dbfa5cc12205465f04fdce4af0aa98
parentbe01786186951b42d8aa8b8968ac1615e080a9c7 (diff)
downloadopenocd+libswd-9d167d62f2eadf81e0028e471e05154c9aabbbfb.tar.gz
openocd+libswd-9d167d62f2eadf81e0028e471e05154c9aabbbfb.tar.bz2
openocd+libswd-9d167d62f2eadf81e0028e471e05154c9aabbbfb.tar.xz
openocd+libswd-9d167d62f2eadf81e0028e471e05154c9aabbbfb.zip
Fix usage/help search for subcommands.
This makes it so that the usage/help command properly uses the whole command, including subcommand, in the search for help information. This previously caused erroneous output from the usage command handler. Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
-rw-r--r--src/helper/command.c41
1 files changed, 34 insertions, 7 deletions
diff --git a/src/helper/command.c b/src/helper/command.c
index e55f9e73..b4e31ea1 100644
--- a/src/helper/command.c
+++ b/src/helper/command.c
@@ -960,18 +960,45 @@ static COMMAND_HELPER(command_help_show, struct command *c, unsigned n,
COMMAND_HANDLER(handle_help_command)
{
bool full = strcmp(CMD_NAME, "help") == 0;
-
+ int retval;
struct command *c = CMD_CTX->commands;
+ char *match = NULL;
- const char *match = "";
if (CMD_ARGC == 0)
match = "";
- else if (CMD_ARGC == 1)
- match = CMD_ARGV[0];
- else
+ else if (CMD_ARGC >= 1) {
+ unsigned i;
+
+ for (i = 0; i < CMD_ARGC; ++i) {
+ if (NULL != match) {
+ char *prev = match;
+
+ match = alloc_printf("%s %s", match,
+ CMD_ARGV[i]);
+ free(prev);
+ if (NULL == match) {
+ LOG_ERROR("unable to build "
+ "search string");
+ return -ENOMEM;
+ }
+ } else {
+ match = alloc_printf("%s", CMD_ARGV[i]);
+ if (NULL == match) {
+ LOG_ERROR("unable to build "
+ "search string");
+ return -ENOMEM;
+ }
+ }
+ }
+ } else
return ERROR_COMMAND_SYNTAX_ERROR;
-
- return CALL_COMMAND_HANDLER(command_help_show_list, c, 0, full, match);
+
+ retval = CALL_COMMAND_HANDLER(command_help_show_list,
+ c, 0, full, match);
+
+ if (CMD_ARGC >= 1)
+ free(match);
+ return retval;
}
static int command_unknown_find(unsigned argc, Jim_Obj *const *argv,