diff options
author | jozan <jozan@noemail.net> | 2020-11-06 01:28:25 +0000 |
---|---|---|
committer | jozan <jozan@noemail.net> | 2020-11-06 01:28:25 +0000 |
commit | 4c62287110a7b81769d6999950b4a27a3d0cc046 (patch) | |
tree | 3b7b6729c3f019a269e7224a3b9b68cd941bde94 /src/u_utils.c | |
parent | Looks like I have to code well (diff) | |
download | unixize-4c62287110a7b81769d6999950b4a27a3d0cc046.tar.gz unixize-4c62287110a7b81769d6999950b4a27a3d0cc046.tar.bz2 unixize-4c62287110a7b81769d6999950b4a27a3d0cc046.tar.xz unixize-4c62287110a7b81769d6999950b4a27a3d0cc046.tar.zst unixize-4c62287110a7b81769d6999950b4a27a3d0cc046.zip |
Recursion in progress
FossilOrigin-Name: 9acb0381b558565524c28866313ef303bca12cadc7def46d3a0efef91ffb8a81
Diffstat (limited to 'src/u_utils.c')
-rw-r--r-- | src/u_utils.c | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/src/u_utils.c b/src/u_utils.c index cc7faeb..000cbca 100644 --- a/src/u_utils.c +++ b/src/u_utils.c @@ -49,6 +49,8 @@ #include <string.h> #include <unistd.h> +#include "c_unixize.h" + void u_memdel(void** ptr) { @@ -76,3 +78,97 @@ u_dump_errno_path(const char path[]) strerror(errno) ); } + +static char +u_get_extra_args(char args[], struct opts_s* opts) +{ + char i; + + i = 0; + args[0] = 0x00; + if (opts->hidden == TRUE) { + memcpy((char*)args + (i * 3), "-a:", 4 * sizeof(char)); + i++; + } + if (opts->confirm == TRUE) { + memcpy((char*)args + (i * 3), "-i:", 4 * sizeof(char)); + i++; + } + if (opts->hyphen == TRUE) { + memcpy((char*)args + (i * 3), "-n:", 4 * sizeof(char)); + i++; + } + if (opts->pretend == TRUE) { + memcpy((char*)args + (i * 3), "-p:", 4 * sizeof(char)); + i++; + } + if (opts->verbose == TRUE) { + memcpy((char*)args + (i * 3), "-v:", 4 * sizeof(char)); + i++; + } + if (i > 0) { + *(args + ((i - 2) * 3) - 1) = 0x00; + } + return (i); +} + +static void +u_del_nargv(char** nargv) +{ + char** ptr; + + ptr = nargv; + while (*ptr != NULL) { + ptr++; + } +} + +char** +u_get_nargv(struct opts_s* opts) +{ + short i; + char args[19]; + char** nargv; + char* tok; + + i = u_get_extra_args(args, opts) + 2; + nargv = (char**)malloc((i + 1) * sizeof(char*)); + if (nargv == NULL) { + u_dump_errno(); + return (NULL); + } + nargv[0] = strdup("unixize"); + nargv[1] = NULL; + if (nargv[0] == NULL) { + u_memdel((void*)&nargv); + return (NULL); + } + nargv[1] = strdup("-R"); + nargv[2] = NULL; + if (nargv[1] == NULL) { + u_memdel((void*)&nargv[0]); + u_memdel((void*)&nargv); + return (NULL); + } + if (i > 2) { + i = 2; + tok = strtok(args, ":"); + nargv[i] = strdup(tok); + if (nargv[i] == NULL) { + u_del_nargv(nargv); + return (NULL); + } + nargv[i + 1] = NULL; + while ((tok = strtok(NULL, ":")) != NULL) { + nargv[i] = strdup(tok); + if (nargv[i] == NULL) { + u_del_nargv(nargv); + return (NULL); + } + nargv[i + 1] = NULL; + i++; + } + } + exit(0); + return (nargv); +} |