From e7fd1d3d5031a98e56503c46baa0c2f23ac7d88c Mon Sep 17 00:00:00 2001 From: Zachary T Welch Date: Sat, 21 Nov 2009 13:49:00 -0800 Subject: [PATCH] hello: use register_commands() Use new register_commands() with command registration table. --- src/hello.c | 52 ++++++++++++++++++++++++++++++++++++---------------- 1 file changed, 36 insertions(+), 16 deletions(-) diff --git a/src/hello.c b/src/hello.c index 8c97a401e..6f0249487 100644 --- a/src/hello.c +++ b/src/hello.c @@ -53,24 +53,36 @@ COMMAND_HANDLER(handle_flag_command) &foo_flag, "foo flag"); } +static const struct command_registration foo_command_handlers[] = { + { + .name = "bar", + .handler = &handle_foo_command, + .mode = COMMAND_ANY, + .help = "
[enable|disable] - an example command", + }, + { + .name = "baz", + .handler = &handle_foo_command, + .mode = COMMAND_ANY, + .help = "
[enable|disable] - a sample command", + }, + { + .name = "flag", + .handler = &handle_flag_command, + .mode = COMMAND_ANY, + .help = "[on|off] - set a flag", + }, + COMMAND_REGISTRATION_DONE +}; + int foo_register_commands(struct command_context *cmd_ctx) { // register several commands under the foo command struct command *cmd = COMMAND_REGISTER(cmd_ctx, NULL, "foo", - NULL, COMMAND_ANY, "foo: command handler skeleton"); + NULL, COMMAND_ANY, "example command handler skeleton"); - COMMAND_REGISTER(cmd_ctx, cmd, "bar", - &handle_foo_command, COMMAND_ANY, - "
[enable|disable] - an example command"); - COMMAND_REGISTER(cmd_ctx, cmd, "baz", - &handle_foo_command, COMMAND_ANY, - "
[enable|disable] - a sample command"); - COMMAND_REGISTER(cmd_ctx, cmd, "flag", - &handle_flag_command, COMMAND_ANY, - "[on|off] - set a flag"); - - return ERROR_OK; + return register_commands(cmd_ctx, cmd, foo_command_handlers); } static COMMAND_HELPER(handle_hello_args, const char **sep, const char **name) @@ -99,12 +111,20 @@ COMMAND_HANDLER(handle_hello_command) return retval; } +static const struct command_registration hello_command_handlers[] = { + { + .name = "hello", + .handler = &handle_hello_command, + .mode = COMMAND_ANY, + .help = "prints a warm welcome", + .usage = "[]", + }, + COMMAND_REGISTRATION_DONE +}; + int hello_register_commands(struct command_context *cmd_ctx) { foo_register_commands(cmd_ctx); - struct command *cmd = COMMAND_REGISTER(cmd_ctx, NULL, "hello", - &handle_hello_command, COMMAND_ANY, - "[] - prints a warm welcome"); - return cmd ? ERROR_OK : -ENOMEM; + return register_commands(cmd_ctx, NULL, hello_command_handlers); }