make it use getarg so that it can handle --help and --version (and

thus make check can pass)


git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@11214 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Assar Westerlund
2002-08-23 03:19:21 +00:00
parent d58e378f3a
commit 1778731bc7

View File

@@ -11,25 +11,65 @@
#ifdef HAVE_ERRNO_H #ifdef HAVE_ERRNO_H
#include <errno.h> #include <errno.h>
#endif #endif
#include <getarg.h>
#include "editline.h" #include "editline.h"
static int n_flag = 0;
static int version_flag = 0;
static int help_flag = 0;
static struct getargs args[] = {
{"dry-run", 'n', arg_flag, &n_flag,
"do not run commands", NULL },
{"version", 0, arg_flag, &version_flag,
"print version", NULL },
{"help", 0, arg_flag, &help_flag,
NULL, NULL }
};
static void
usage (int ret)
{
arg_printusage (args,
sizeof(args)/sizeof(*args),
NULL,
"");
exit (ret);
}
int int
main(int ac, char **av) main(int argc, char **argv)
{ {
char *p; char *p;
int doit; int optind = 0;
setprogname (argv[0]);
if(getarg(args, sizeof(args) / sizeof(args[0]), argc, argv, &optind))
usage(1);
if (help_flag)
usage (0);
if(version_flag){
print_version(NULL);
exit(0);
}
argc -= optind;
argv += optind;
doit = ac == 1;
while ((p = readline("testit> ")) != NULL) { while ((p = readline("testit> ")) != NULL) {
(void)printf("\t\t\t|%s|\n", p); (void)printf("\t\t\t|%s|\n", p);
if (doit) if (!n_flag) {
if (strncmp(p, "cd ", 3) == 0) { if (strncmp(p, "cd ", 3) == 0) {
if (chdir(&p[3]) < 0) if (chdir(&p[3]) < 0)
perror(&p[3]); perror(&p[3]);
} else if (system(p) != 0) { } else if (system(p) != 0) {
perror(p); perror(p);
} }
}
add_history(p); add_history(p);
free(p); free(p);
} }