diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2011-03-08 12:44:02 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2011-03-08 12:44:02 +0100 |
commit | 86cf0364bd58e07646a23a1128e4a9ea79189579 (patch) | |
tree | 22e161a76936796b5f8d49536684d371e7e8bfc3 | |
parent | 6b6af53426d98ab513972bd710f250e246e7fc98 (diff) | |
download | busybox-86cf0364bd58e07646a23a1128e4a9ea79189579.tar.gz |
printenv: fix environ == NULL segfault
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | coreutils/printenv.c | 11 | ||||
-rw-r--r-- | coreutils/test.c | 2 |
2 files changed, 9 insertions, 4 deletions
diff --git a/coreutils/printenv.c b/coreutils/printenv.c index 33be5c096..d0fb71636 100644 --- a/coreutils/printenv.c +++ b/coreutils/printenv.c @@ -19,9 +19,14 @@ int printenv_main(int argc UNUSED_PARAM, char **argv) /* no variables specified, show whole env */ if (!argv[1]) { - int e = 0; - while (environ[e]) - puts(environ[e++]); + char **e = environ; + + /* environ can be NULL! (for example, after clearenv()) + * Check for that: + */ + if (e) + while (*e) + puts(*e++); } else { /* search for specified variables and print them out if found */ char *arg, *env; diff --git a/coreutils/test.c b/coreutils/test.c index 8248a1ef5..2d245be6c 100644 --- a/coreutils/test.c +++ b/coreutils/test.c @@ -45,7 +45,7 @@ /* This is a NOFORK applet. Be very careful! */ /* test_main() is called from shells, and we need to be extra careful here. - * This is true regardless of PREFER_APPLETS and STANDALONE_SHELL + * This is true regardless of PREFER_APPLETS and SH_STANDALONE * state. */ /* test(1) accepts the following grammar: |