+/* SPDX-License-Identifier: GPL-2.0-or-later */
+
/***************************************************************************
* Copyright (C) 2009 Zachary T Welch <zw@superlucidity.net> *
- * *
- * This program is free software; you can redistribute it and/or modify *
- * it under the terms of the GNU General Public License as published by *
- * the Free Software Foundation; either version 2 of the License, or *
- * (at your option) any later version. *
- * *
- * This program is distributed in the hope that it will be useful, *
- * but WITHOUT ANY WARRANTY; without even the implied warranty of *
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
- * GNU General Public License for more details. *
- * *
- * You should have received a copy of the GNU General Public License *
- * along with this program; if not, write to the *
- * Free Software Foundation, Inc., *
- * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
-#include "log.h"
+#include <helper/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 = "<unchanged>";
- if (CMD_ARGC == 2)
- {
+ if (CMD_ARGC == 2) {
bool enable;
COMMAND_PARSE_ENABLE(CMD_ARGV[1], enable);
msg = enable ? "enable" : "disable";
COMMAND_HANDLER(handle_flag_command)
{
return CALL_COMMAND_HANDLER(handle_command_parse_bool,
- &foo_flag, "foo flag");
+ &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,
- "<address> [enable|disable] - an example command");
- register_command(cmd_ctx, cmd, "baz",
- &handle_foo_command, COMMAND_ANY,
- "<address> [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 const struct command_registration foo_command_handlers[] = {
+ {
+ .name = "bar",
+ .handler = &handle_foo_command,
+ .mode = COMMAND_ANY,
+ .usage = "address ['enable'|'disable']",
+ .help = "an example command",
+ },
+ {
+ .name = "baz",
+ .handler = &handle_foo_command,
+ .mode = COMMAND_ANY,
+ .usage = "address ['enable'|'disable']",
+ .help = "a sample command",
+ },
+ {
+ .name = "flag",
+ .handler = &handle_flag_command,
+ .mode = COMMAND_ANY,
+ .usage = "[on|off]",
+ .help = "set a flag",
+ },
+ COMMAND_REGISTRATION_DONE
+};
static COMMAND_HELPER(handle_hello_args, const char **sep, const char **name)
{
if (CMD_ARGC > 1)
- {
- LOG_ERROR("%s: too many arguments", CMD_NAME);
return ERROR_COMMAND_SYNTAX_ERROR;
- }
- if (1 == CMD_ARGC)
- {
+ if (1 == CMD_ARGC) {
*sep = " ";
*name = CMD_ARGV[0];
- }
- else
+ } else
*sep = *name = "";
return ERROR_OK;
{
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);
+ if (retval == ERROR_OK)
+ command_print(CMD, "Greetings%s%s!", sep, name);
return retval;
}
-int hello_register_commands(struct command_context *cmd_ctx)
-{
- foo_register_commands(cmd_ctx);
-
- struct command *cmd = register_command(cmd_ctx, NULL, "hello",
- &handle_hello_command, COMMAND_ANY,
- "[<name>] - prints a warm welcome");
- return cmd ? ERROR_OK : -ENOMEM;
-}
+const struct command_registration hello_command_handlers[] = {
+ {
+ .name = "hello",
+ .handler = handle_hello_command,
+ .mode = COMMAND_ANY,
+ .help = "prints a warm welcome",
+ .usage = "[name]",
+ },
+ {
+ .name = "foo",
+ .mode = COMMAND_ANY,
+ .help = "example command handler skeleton",
+ .chain = foo_command_handlers,
+ .usage = "",
+ },
+ COMMAND_REGISTRATION_DONE
+};