summaryrefslogtreecommitdiffstats
path: root/cli/src/cli.c
diff options
context:
space:
mode:
authorPranith K <pranithk@gluster.com>2010-10-27 10:33:23 +0000
committerAnand V. Avati <avati@dev.gluster.com>2010-10-27 23:37:28 -0700
commite93b270e8d09fc9d36a39b22987d3a172197e73b (patch)
treee0c39f6c3ed99adbd224417d8a4a6357fc5f5283 /cli/src/cli.c
parentb2f195720b27d9e69f7b851478515781e5786469 (diff)
cli: gluster --version implementation
Signed-off-by: Pranith Kumar K <pranithk@gluster.com> Signed-off-by: Anand V. Avati <avati@dev.gluster.com> BUG: 2006 (Add gluster version command) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=2006
Diffstat (limited to 'cli/src/cli.c')
-rw-r--r--cli/src/cli.c74
1 files changed, 59 insertions, 15 deletions
diff --git a/cli/src/cli.c b/cli/src/cli.c
index a08d2d214d7..5e389b6c67f 100644
--- a/cli/src/cli.c
+++ b/cli/src/cli.c
@@ -76,6 +76,9 @@
extern int connected;
/* using argp for command line parsing */
+static char gf_doc[] = "";
+
+static char argp_doc[] = "";
const char *argp_program_version = "" \
PACKAGE_NAME" "PACKAGE_VERSION" built on "__DATE__" "__TIME__ \
@@ -88,7 +91,10 @@ const char *argp_program_version = "" \
const char *argp_program_bug_address = "<" PACKAGE_BUGREPORT ">";
-
+static struct argp_option gf_options[] = {
+ {0, 0, 0, 0, "Basic options:"},
+ {0, }
+};
struct rpc_clnt *global_rpc;
@@ -97,6 +103,39 @@ rpc_clnt_prog_t *cli_rpc_prog;
extern struct rpc_clnt_program cli3_1_prog;
+static error_t
+parse_opts (int key, char *arg, struct argp_state *argp_state)
+{
+ struct cli_state *state = NULL;
+ char **argv = NULL;
+
+ state = argp_state->input;
+
+ switch (key) {
+ case ARGP_KEY_ARG:
+ if (!state->argc) {
+ argv = calloc (state->argc + 2,
+ sizeof (*state->argv));
+ } else {
+ argv = realloc (state->argv, (state->argc + 2) *
+ sizeof (*state->argv));
+ }
+ if (!argv)
+ return -1;
+
+ state->argv = argv;
+
+ argv[state->argc] = strdup (arg);
+ if (!argv[state->argc])
+ return -1;
+ state->argc++;
+ argv[state->argc] = NULL;
+
+ break;
+ }
+
+ return 0;
+}
@@ -356,24 +395,29 @@ parse_cmdline (int argc, char *argv[], struct cli_state *state)
int i = 0;
int j = 0;
char *opt = NULL;
+ struct argp argp = { 0,};
- state->argc=argc-1;
- state->argv=&argv[1];
+ argp.options = gf_options;
+ argp.parser = parse_opts;
+ argp.args_doc = argp_doc;
+ argp.doc = gf_doc;
- for (i = 0; i < state->argc; i++) {
- opt = strtail (state->argv[i], "--");
+ for (i = 0; i < argc; i++) {
+ opt = strtail (argv[i], "--");
if (opt) {
ret = cli_opt_parse (opt, state);
if (ret == -1) {
- cli_out ("unrecognized option --%s", opt);
- return ret;
+ break;
}
- for (j = i; j < state->argc - 1; j++)
- state->argv[j] = state->argv[j + 1];
- state->argc--;
+ for (j = i; j < argc - 1; j++)
+ argv[j] = argv[j + 1];
+ argc--;
}
}
+ ret = argp_parse (&argp, argc, argv,
+ ARGP_IN_ORDER, NULL, state);
+
return ret;
}
@@ -524,11 +568,6 @@ main (int argc, char *argv[])
int ret = -1;
glusterfs_ctx_t *ctx = NULL;
- if (geteuid ()) {
- printf ("Only super user can run this command\n");
- return EPERM;
- }
-
ret = glusterfs_globals_init ();
if (ret)
return ret;
@@ -552,6 +591,11 @@ main (int argc, char *argv[])
if (ret)
goto out;
+ if (geteuid ()) {
+ printf ("Only super user can run this command\n");
+ return EPERM;
+ }
+
global_rpc = cli_rpc_init (&state);
if (!global_rpc)
goto out;