X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=coreutils%2Fenv.c;h=fd58a23da823b4a5104e4298465c7ff3348e918d;hb=e135a5d746c4f163f191e12b527636b0345e1456;hp=56577b611038ba58eee36a3f51f3d62fe24c8966;hpb=84e229cfbe00d27ce81dad66c982bec0d50cdfd7;p=oweals%2Fbusybox.git diff --git a/coreutils/env.c b/coreutils/env.c index 56577b611..fd58a23da 100644 --- a/coreutils/env.c +++ b/coreutils/env.c @@ -21,49 +21,95 @@ * * Original copyright notice is retained at the end of this file. * - * Modified for BusyBox by Erik Andersen , + * Modified for BusyBox by Erik Andersen */ +/* BB_AUDIT SUSv3 compliant */ +/* http://www.opengroup.org/onlinepubs/007904975/utilities/env.html */ + +/* Mar 16, 2003 Manuel Novoa III (mjn3@codepoet.org) + * + * Fixed bug involving exit return codes if execvp fails. Also added + * output error checking. + */ + +/* + * Modified by Vladimir Oleynik (C) 2003 + * - correct "-" option usage + * - multiple "-u unsetenv" support + * - GNU long option support + * - use bb_default_error_retval + */ + + #include #include -#include #include +#include #include +#include /* struct option */ #include "busybox.h" -extern int env_main(int argc, char** argv) + +static const struct option env_long_options[] = { + { "ignore-environment", 0, NULL, 'i' }, + { "unset", 1, NULL, 'u' }, + { 0, 0, 0, 0 } +}; + +int env_main(int argc, char** argv) { + static char *cleanenv[1] = { NULL }; + char **ep, *p; - char *cleanenv[1]; - int ch; - - while ((ch = getopt(argc, argv, "-iu:")) != -1) - switch(ch) { - case '-': - case 'i': - environ = cleanenv; - cleanenv[0] = NULL; - break; - case 'u': - unsetenv(optarg); - break; - default: - show_usage(); + unsigned long opt; + llist_t *unset_env = NULL; + extern char **environ; + + bb_opt_complementally = "u::"; + bb_applet_long_options = env_long_options; + + opt = bb_getopt_ulflags(argc, argv, "+iu:", &unset_env); + + argv += optind; + if (*argv && (argv[0][0] == '-') && !argv[0][1]) { + opt |= 1; + ++argv; + } + + if(opt & 1) + environ = cleanenv; + else if(opt & 2) { + while(unset_env) { + unsetenv(unset_env->data); + unset_env = unset_env->link; + } + } + + while (*argv && ((p = strchr(*argv, '=')) != NULL)) { + if (putenv(*argv) < 0) { + bb_perror_msg_and_die("putenv"); } - for (argv += optind; *argv && (p = strchr(*argv, '=')); ++argv) - setenv(*argv, ++p, 1); + ++argv; + } + if (*argv) { execvp(*argv, argv); - perror_msg_and_die("%s", *argv); + /* SUSv3-mandated exit codes. */ + bb_default_error_retval = (errno == ENOENT) ? 127 : 126; + bb_perror_msg_and_die("%s", *argv); + } + + for (ep = environ; *ep; ep++) { + puts(*ep); } - for (ep = environ; *ep; ep++) - printf("%s\n", *ep); - exit(EXIT_SUCCESS); + + bb_fflush_stdout_and_exit(0); } /* * Copyright (c) 1988, 1993, 1994 - * The Regents of the University of California. All rights reserved. + * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -74,8 +120,8 @@ extern int env_main(int argc, char** argv) * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - * 3. + * 3. * * 4. Neither the name of the University nor the names of its contributors * may be used to endorse or promote products derived from this software