diff options
author | Rafal Szczesniak <mimir@samba.org> | 2005-02-16 21:51:37 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 13:10:44 -0500 |
commit | a19b2e84f81baaa24651a44076ce2c62056135e9 (patch) | |
tree | a80114180e0bc19cb43f2f6c370f7f80040f0fd8 /source4 | |
parent | 16f64ae6d6a9ea0ec14ec124c097787ccb320864 (diff) | |
download | samba-a19b2e84f81baaa24651a44076ce2c62056135e9.tar.gz samba-a19b2e84f81baaa24651a44076ce2c62056135e9.tar.xz samba-a19b2e84f81baaa24651a44076ce2c62056135e9.zip |
r5424: Automatically generate basic help display on basis of name
and description from function table.
rafal
(This used to be commit 24f7a3860e82bf632ebd6b3416e5e874e832be5f)
Diffstat (limited to 'source4')
-rw-r--r-- | source4/utils/net/net.c | 81 |
1 files changed, 31 insertions, 50 deletions
diff --git a/source4/utils/net/net.c b/source4/utils/net/net.c index 63f19624f00..fb87a5a6d9d 100644 --- a/source4/utils/net/net.c +++ b/source4/utils/net/net.c @@ -57,9 +57,11 @@ int net_run_function(struct net_context *ctx, { int i; - if (argc < 1) { - d_printf("Usage: \n"); + if (argc == 0) { return usage_fn(ctx, argc, argv); + + } else if (argc == 1 && strequal(argv[0], "help")) { + return net_help(ctx, functable); } for (i=0; functable[i].name; i++) { @@ -79,12 +81,12 @@ int net_run_usage(struct net_context *ctx, const struct net_functable *functable) { int i; - +/* if (argc < 1) { d_printf("net_run_usage: TODO (argc < 1)\n"); return 1; } - +*/ for (i=0; functable[i].name; i++) { if (StrCaseCmp(argv[0], functable[i].name) == 0) if (functable[i].usage) { @@ -92,62 +94,42 @@ int net_run_usage(struct net_context *ctx, } } - d_printf("No usage for command: %s\n", argv[0]); + d_printf("No usage information for command: %s\n", argv[0]); return 1; } -/* - run a usage function from a function table. If not found then fail -*/ -int net_run_help(struct net_context *ctx, - int argc, const char **argv, - const struct net_functable *functable) -{ - int i; - if (argc < 1) { - d_printf("net_run_help: TODO (argc < 1)\n"); - return 1; - } +/* main function table */ +static const struct net_functable net_functable[] = { + {"password", "change password\n", net_password, net_password_usage}, + {"time", "get remote server's time\n", net_time, net_time_usage}, + {"join", "join a domain\n", net_join, net_join_usage}, + {"user", "manage user accounts\n", net_user, net_user_usage}, + {NULL, NULL, NULL, NULL} +}; - for (i=0; functable[i].name; i++) { - if (StrCaseCmp(argv[0], functable[i].name) == 0) - if (functable[i].help) { - return functable[i].help(ctx, argc-1, argv+1); - } +int net_help(struct net_context *ctx, const struct net_functable *ftable) +{ + int i = 0; + const char *name = ftable[i].name; + const char *desc = ftable[i].desc; + + d_printf("Available commands:\n"); + while (name && desc) { + d_printf("\t%s\t\t%s", name, desc); + name = ftable[++i].name; + desc = ftable[i].desc; } - d_printf("No help for command: %s\n", argv[0]); - - return 1; -} - -static int net_help(struct net_context *ctx, int argc, const char **argv) -{ - d_printf("net_help: TODO\n"); return 0; } -static int net_help_usage(struct net_context *ctx, int argc, const char **argv) -{ - d_printf("net_help_usage: TODO\n"); - return 0; -} - -/* main function table */ -static const struct net_functable net_functable[] = { - {"password", net_password, net_password_usage, net_password_help}, - {"time", net_time, net_time_usage, net_time_help}, - {"join", net_join, net_join_usage, net_join_help}, - {"user", net_user, net_user_usage, net_user_help}, - {"help", net_help, net_help_usage, net_help}, - {NULL, NULL} -}; - static int net_usage(struct net_context *ctx, int argc, const char **argv) { - return net_run_usage(ctx, argc, argv, net_functable); + d_printf("Usage:\n"); + d_printf("net <command> [options]\n"); + return 0; } /**************************************************************************** @@ -185,7 +167,7 @@ static int binary_net(int argc, const char **argv) default: d_printf("Invalid option %s: %s\n", poptBadOption(pc, 0), poptStrerror(opt)); - net_help(ctx, argc, argv); + net_usage(ctx, argc, argv); exit(1); } } @@ -204,8 +186,7 @@ static int binary_net(int argc, const char **argv) } if (argc_new < 2) { - d_printf("Usage: TODO\n"); - return 1; + return net_usage(ctx, argc, argv); } net_init_subsystems; |