diff options
-rw-r--r-- | Makefile | 6 | ||||
-rw-r--r-- | src/c_opts.c | 48 | ||||
-rw-r--r-- | src/c_opts.h | 11 | ||||
-rw-r--r-- | src/c_unixize.c | 17 |
4 files changed, 57 insertions, 25 deletions
@@ -51,14 +51,14 @@ ${TARGET}: ${OBJS} all: ${TARGET} -debug: CFLAGS += -glldb +debug: CFLAGS += -g3 debug: all -asan: CFLAGS += -glldb +asan: CFLAGS += -g3 asan: CFLAGS += -fsanitize=address asan: all -msan: CFLAGS += -glldb +msan: CFLAGS += -g3 msan: CFLAGS += -fsanitize=memory msan: CFLAGS += -fsanitize-memory-track-origins msan: all diff --git a/src/c_opts.c b/src/c_opts.c index 98f60cb..7bfd4e7 100644 --- a/src/c_opts.c +++ b/src/c_opts.c @@ -46,21 +46,40 @@ */ #include <stdlib.h> +#include <string.h> #include <unistd.h> #include <stdio.h> #include "c_opts.h" +#include "c_unixize.h" + +static void +c_ask_confirm(const char dir[]) +{ + char c; + + printf("unixize directory %s? (y/n [n]) ", dir); + scanf("%c", &c); + if (c != 'y' && c != 'Y') { + printf("not unixized\n"); + exit(0); + } +} void -c_opts(struct opts_s* opts, int argc, const char* argv[]) +c_get_opts(struct opts_s* opts, + int argc, + const char* argv[]) { - int opt; + int opt; + bool_t confirm; opts->recursive = FALSE; opts->verbose = FALSE; opts->pretend = FALSE; - opts->hidden = FALSE; - opts->hyphen = FALSE; + opts->hidden = FALSE; + opts->hyphen = FALSE; + confirm = FALSE; while ((opt = getopt(argc, (char *const *)argv, C_OPTS)) != -1) { if (opt == 'R') { opts->recursive = TRUE; @@ -75,19 +94,26 @@ c_opts(struct opts_s* opts, int argc, const char* argv[]) /* c_dump_usage(); */ exit(0); } + else if (opt == 'i') { + confirm = TRUE; + } else if (opt == '?') { - dprintf( - STDERR_FILENO, + dprintf(STDERR_FILENO, "unixize: %c: unknown option\n", - optopt - ); + optopt); exit(1); } } + if (optind < argc && argv[optind] != NULL) { + strncpy(opts->dir, argv[optind], PATH_MAX); + } + if (argv[optind] == NULL) { + strncpy(opts->dir, ".", 2); + } + if (confirm == TRUE) { + c_ask_confirm(opts->dir); + } if (opts->pretend == TRUE) { opts->verbose = TRUE; } - if (optind < argc && argv[optind] != NULL) { - printf("arg: %s\n", argv[optind]); - } } diff --git a/src/c_opts.h b/src/c_opts.h index cbe2e54..16b2ce8 100644 --- a/src/c_opts.h +++ b/src/c_opts.h @@ -46,9 +46,15 @@ #ifndef __C_OPTS_H__ #define __C_OPTS_H__ value +#ifdef __linux__ +# include <linux/limits.h> +#else +# include <limits.h> +#endif + #include "c_unixize.h" -#define C_OPTS "hpnRv" +#define C_OPTS "hinpRv" struct opts_s { bool_t recursive; @@ -56,8 +62,9 @@ struct opts_s { bool_t pretend; bool_t hidden; bool_t hyphen; + char dir[PATH_MAX]; }; -void c_opts(struct opts_s*, int, const char*[]); +void c_get_opts(struct opts_s*, int, const char*[]); #endif /* ifndef __C_OPTS_H__ */ diff --git a/src/c_unixize.c b/src/c_unixize.c index d05c78e..7f3495d 100644 --- a/src/c_unixize.c +++ b/src/c_unixize.c @@ -45,28 +45,27 @@ * This is the main function and entrypoint of the program. */ -/* #ifdef __linux__ */ -/* # include <linux/limits.h> */ -/* #else */ -/* # include <limits.h> */ -/* #endif */ - #include <stdio.h> #include "c_opts.h" int -main(int argc, const char* argv[]) +main(int argc, + const char* argv[]) { - struct opts_s opts; + struct opts_s opts; - c_opts(&opts, argc, argv); + c_get_opts(&opts, argc, argv); if (opts.recursive == TRUE) printf("Recursive\n"); if (opts.verbose == TRUE) printf("Verbose\n"); if (opts.pretend == TRUE) printf("Pretend\n"); + if (opts.hidden == TRUE) + printf("Hidden\n"); + if (opts.hyphen == TRUE) + printf("Hyphen\n"); return (0); } |