From 202761d052d2faa2c92b23c5afc32c27853b11ad Mon Sep 17 00:00:00 2001 From: Csaba Henk Date: Wed, 15 Sep 2010 08:11:18 +0000 Subject: cli: add system namespace See "gluster system:: help" to get the feel of it. Signed-off-by: Csaba Henk Signed-off-by: Vijay Bellur BUG: 1570 (geosync related changes) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=1570 --- cli/src/Makefile.am | 2 +- cli/src/cli-cmd-misc.c | 8 +++++ cli/src/cli-cmd-system.c | 80 ++++++++++++++++++++++++++++++++++++++++++++++++ cli/src/cli-cmd.c | 4 +++ cli/src/cli-cmd.h | 2 ++ 5 files changed, 95 insertions(+), 1 deletion(-) create mode 100644 cli/src/cli-cmd-system.c (limited to 'cli') diff --git a/cli/src/Makefile.am b/cli/src/Makefile.am index fbbf44dd0..595cfad9d 100644 --- a/cli/src/Makefile.am +++ b/cli/src/Makefile.am @@ -2,7 +2,7 @@ sbin_PROGRAMS = gluster gluster_SOURCES = cli.c registry.c input.c cli-cmd.c cli-rl.c \ cli-cmd-volume.c cli-cmd-peer.c cli3_1-cops.c cli-cmd-parser.c\ - cli-cmd-misc.c + cli-cmd-system.c cli-cmd-misc.c gluster_LDADD = $(top_builddir)/libglusterfs/src/libglusterfs.la $(GF_LDADD)\ $(RLLIBS) $(top_builddir)/rpc/xdr/src/libgfxdr.la \ diff --git a/cli/src/cli-cmd-misc.c b/cli/src/cli-cmd-misc.c index 306a7628f..ecef83d11 100644 --- a/cli/src/cli-cmd-misc.c +++ b/cli/src/cli-cmd-misc.c @@ -40,6 +40,7 @@ extern rpc_clnt_prog_t *cli_rpc_prog; extern struct cli_cmd volume_cmds[]; extern struct cli_cmd cli_probe_cmds[]; extern struct cli_cmd cli_log_cmds[]; +extern struct cli_cmd cli_system_cmds[]; struct cli_cmd cli_misc_cmds[]; int @@ -61,6 +62,13 @@ cli_cmd_display_help (struct cli_state *state, struct cli_cmd_word *in_word, for (cmd = cli_probe_cmds; cmd->pattern; cmd++) cli_out ("%s - %s", cmd->pattern, cmd->desc); + /* + * commands for internal usage, don't expose + + for (cmd = cli_system_cmds; cmd->pattern; cmd++) + cli_out ("%s - %s", cmd->pattern, cmd->desc); + */ + for (cmd = cli_misc_cmds; cmd->pattern; cmd++) cli_out ("%s - %s", cmd->pattern, cmd->desc); diff --git a/cli/src/cli-cmd-system.c b/cli/src/cli-cmd-system.c new file mode 100644 index 000000000..ec53b9848 --- /dev/null +++ b/cli/src/cli-cmd-system.c @@ -0,0 +1,80 @@ +/* + Copyright (c) 2010 Gluster, Inc. + This file is part of GlusterFS. + + GlusterFS is free software; you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published + by the Free Software Foundation; either version 3 of the License, + or (at your option) any later version. + + GlusterFS 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 + Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see + . +*/ + +#include +#include +#include +#include +#include + +#ifndef _CONFIG_H +#define _CONFIG_H +#include "config.h" +#endif + +#include "cli.h" +#include "cli-cmd.h" +#include "cli-mem-types.h" +#include "protocol-common.h" + +extern struct rpc_clnt *global_rpc; + +extern rpc_clnt_prog_t *cli_rpc_prog; + +int cli_cmd_system_help_cbk (struct cli_state *state, struct cli_cmd_word *in_word, + const char **words, int wordcount); + +struct cli_cmd cli_system_cmds[] = { + { "system:: help", + cli_cmd_system_help_cbk, + "display help for system commands"}, + + { NULL, NULL, NULL } +}; + +int +cli_cmd_system_help_cbk (struct cli_state *state, struct cli_cmd_word *in_word, + const char **words, int wordcount) +{ + struct cli_cmd *cmd = NULL; + + for (cmd = cli_system_cmds; cmd->pattern; cmd++) + cli_out ("%s - %s", cmd->pattern, cmd->desc); + + if (!state->rl_enabled) + exit (0); + + return 0; +} + +int +cli_cmd_system_register (struct cli_state *state) +{ + int ret = 0; + struct cli_cmd *cmd = NULL; + + for (cmd = cli_system_cmds; cmd->pattern; cmd++) { + ret = cli_cmd_register (&state->tree, cmd->pattern, cmd->cbk, + cmd->desc); + if (ret) + goto out; + } +out: + return ret; +} diff --git a/cli/src/cli-cmd.c b/cli/src/cli-cmd.c index 011edacfe..f09c62106 100644 --- a/cli/src/cli-cmd.c +++ b/cli/src/cli-cmd.c @@ -199,6 +199,10 @@ cli_cmds_register (struct cli_state *state) if (ret) goto out; + ret = cli_cmd_system_register (state); + if (ret) + goto out; + ret = cli_cmd_misc_register (state); if (ret) goto out; diff --git a/cli/src/cli-cmd.h b/cli/src/cli-cmd.h index 7dda509dd..89fc44cfa 100644 --- a/cli/src/cli-cmd.h +++ b/cli/src/cli-cmd.h @@ -49,6 +49,8 @@ int cli_cmd_volume_register (struct cli_state *state); int cli_cmd_probe_register (struct cli_state *state); +int cli_cmd_system_register (struct cli_state *state); + int cli_cmd_misc_register (struct cli_state *state); struct cli_cmd_word *cli_cmd_nextword (struct cli_cmd_word *word, -- cgit