Busybox should only multiplex based on argv[1] when it's called as "busybox".
authorRob Landley <rob@landley.net>
Thu, 1 Sep 2005 00:02:56 +0000 (00:02 -0000)
committerRob Landley <rob@landley.net>
Thu, 1 Sep 2005 00:02:56 +0000 (00:02 -0000)
Otherwise if you build busybox without a given applet you get the wrong error
message when you call it via a symlink to that applet.

(You also get the wrong behavior; it tries to use argv[1] as the command
name just like busybox does for _any_ unknown, and although I doubt
"echo rm -rf *" is common usage there's no upside and enough downside to
make me nervous.)

This fixes it.

applets/applets.c

index 9db16b41dc8f6fed5702cf30f66df77bf5a5c184..ce9ecbbc58964cde3475bc575760ce22f69e6b6c 100644 (file)
@@ -163,10 +163,6 @@ run_applet_by_name (const char *name, int argc, char **argv)
 
        exit ((*(applet_using->main)) (argc, argv));
   }
-  /* Just in case they have renamed busybox - Check argv[1] */
-  if (recurse_level == 1) {
-       run_applet_by_name ("busybox", argc, argv);
-  }
   recurse_level--;
 }