Added support for ignoring '-g' per GNU ls, thanks to David Vrabel
[oweals/busybox.git] / chroot.c
index 63fa4d14602caa6461c23b4b6a6e0885db4ca328..1c64e08a94b14401a637b313688ba043807d83df 100644 (file)
--- a/chroot.c
+++ b/chroot.c
 #include <errno.h>
 
 
-static const char chroot_usage[] = "chroot NEWROOT [COMMAND...]\n\n"
-
-       "Run COMMAND with root directory set to NEWROOT.\n";
+static const char chroot_usage[] = "chroot NEWROOT [COMMAND...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+       "\nRun COMMAND with root directory set to NEWROOT.\n"
+#endif
+       ;
 
 
 
 int chroot_main(int argc, char **argv)
 {
+       char *prog;
+
        if ((argc < 2) || (**(argv + 1) == '-')) {
                usage(chroot_usage);
        }
@@ -43,27 +47,24 @@ int chroot_main(int argc, char **argv)
        argv++;
 
        if (chroot(*argv) || (chdir("/"))) {
-               fprintf(stderr, "chroot: cannot change root directory to %s: %s\n",
+               fatalError("chroot: cannot change root directory to %s: %s\n", 
                                *argv, strerror(errno));
-               exit(FALSE);
        }
 
        argc--;
        argv++;
        if (argc >= 1) {
-               fprintf(stderr, "command: %s\n", *argv);
+               prog = *argv;
                execvp(*argv, argv);
        } else {
-               char *prog;
-
                prog = getenv("SHELL");
                if (!prog)
                        prog = "/bin/sh";
                execlp(prog, prog, NULL);
        }
-       fprintf(stderr, "chroot: cannot execute %s: %s\n",
-                       *argv, strerror(errno));
-       exit(FALSE);
+       fatalError("chroot: cannot execute %s: %s\n", 
+                       prog, strerror(errno));
+
 }