X-Git-Url: https://review.openocd.org/gitweb?p=openocd.git;a=blobdiff_plain;f=src%2Fhello.c;h=2ab7eb5079937d8c0e0626d7f485151ddb2728ac;hp=267cc28e4eda264c8f1e33c489104930dcc2def8;hb=71cde5e359f273585880ea8986709b950ba85b08;hpb=98723c4ecdbe06f90c66f3abec27b792c3b38e34 diff --git a/src/hello.c b/src/hello.c index 267cc28e4e..2ab7eb5079 100644 --- a/src/hello.c +++ b/src/hello.c @@ -22,17 +22,68 @@ #endif #include "log.h" +COMMAND_HANDLER(handle_foo_command) +{ + if (CMD_ARGC < 1 || CMD_ARGC > 2) + { + LOG_ERROR("%s: incorrect number of arguments", CMD_NAME); + return ERROR_COMMAND_SYNTAX_ERROR; + } + + uint32_t address; + COMMAND_PARSE_NUMBER(u32, CMD_ARGV[0], address); + + const char *msg = ""; + if (CMD_ARGC == 2) + { + bool enable; + COMMAND_PARSE_ENABLE(CMD_ARGV[1], enable); + msg = enable ? "enable" : "disable"; + } + + LOG_INFO("%s: address=0x%8.8" PRIx32 " enabled=%s", CMD_NAME, address, msg); + return ERROR_OK; +} + +static bool foo_flag; + +COMMAND_HANDLER(handle_flag_command) +{ + return CALL_COMMAND_HANDLER(handle_command_parse_bool, + &foo_flag, "foo flag"); +} + +int foo_register_commands(struct command_context *cmd_ctx) +{ + // register several commands under the foo command + struct command *cmd = register_command(cmd_ctx, NULL, "foo", + NULL, COMMAND_ANY, "foo: command handler skeleton"); + + register_command(cmd_ctx, cmd, "bar", + &handle_foo_command, COMMAND_ANY, + "
[enable|disable] - an example command"); + register_command(cmd_ctx, cmd, "baz", + &handle_foo_command, COMMAND_ANY, + "
[enable|disable] - a sample command"); + + register_command(cmd_ctx, cmd, "flag", + &handle_flag_command, COMMAND_ANY, + "[on|off] - set a flag"); + + return ERROR_OK; +} + static COMMAND_HELPER(handle_hello_args, const char **sep, const char **name) { - if (argc > 1) + if (CMD_ARGC > 1) { LOG_ERROR("%s: too many arguments", CMD_NAME); return ERROR_COMMAND_SYNTAX_ERROR; } - if (1 == argc) + if (1 == CMD_ARGC) { *sep = " "; - *name = args[0]; + *name = CMD_ARGV[0]; } else *sep = *name = ""; @@ -44,14 +95,16 @@ COMMAND_HANDLER(handle_hello_command) const char *sep, *name; int retval = CALL_COMMAND_HANDLER(handle_hello_args, &sep, &name); if (ERROR_OK == retval) - command_print(cmd_ctx, "Greetings%s%s!", sep, name); + command_print(CMD_CTX, "Greetings%s%s!", sep, name); return retval; } int hello_register_commands(struct command_context *cmd_ctx) { - struct command_s *cmd = register_command(cmd_ctx, NULL, "hello", + foo_register_commands(cmd_ctx); + + struct command *cmd = register_command(cmd_ctx, NULL, "hello", &handle_hello_command, COMMAND_ANY, - "option"); + "[] - prints a warm welcome"); return cmd ? ERROR_OK : -ENOMEM; }