1
0
mirror of git://git.suckless.org/sbase synced 2024-12-31 19:52:09 +00:00

Audit chroot(1)

1) Fix usage()
2) Rename *p to *cmd
3) _exit trick with 126 + (savederrno == ENOENT)
4) return-style-fix
This commit is contained in:
FRIGN 2015-03-02 17:41:58 +01:00
parent 520d87e58e
commit eb137b9e42
2 changed files with 11 additions and 11 deletions

2
README
View File

@ -15,7 +15,7 @@ The following tools are implemented ('*' == finished, '#' == UTF-8 support,
=* chgrp yes none
=* chmod yes none
=* chown yes none
=* chroot non-posix none
=*| chroot non-posix none
=* cksum yes none
=* cmp yes none
#* cols non-posix none

View File

@ -8,13 +8,13 @@
static void
usage(void)
{
eprintf("usage: chroot dir [cmd [arg ...]]\n");
eprintf("usage: %s dir [cmd [arg ...]]\n", argv0);
}
int
main(int argc, char *argv[])
{
char *shell[] = { "/bin/sh", "-i", NULL }, *aux, *p;
char *shell[] = { "/bin/sh", "-i", NULL }, *aux, *cmd;
int savederrno;
ARGBEGIN {
@ -22,7 +22,7 @@ main(int argc, char *argv[])
usage();
} ARGEND;
if (argc < 1)
if (!argc)
usage();
if ((aux = getenv("SHELL")))
@ -35,16 +35,16 @@ main(int argc, char *argv[])
eprintf("chdir:");
if (argc == 1) {
p = *shell;
cmd = *shell;
execvp(*shell, shell);
} else {
p = argv[1];
execvp(argv[1], argv+1);
cmd = argv[1];
execvp(argv[1], argv + 1);
}
savederrno = errno;
weprintf("execvp %s:", p);
_exit(savederrno == ENOENT ? 127 : 126);
/* unreachable */
return 0;
weprintf("execvp %s:", cmd);
_exit(126 + (savederrno == ENOENT));
return 0; /* not reached */
}