From 3be5f8e9018ab74ba968d04eb034c0e8b11c6042 Mon Sep 17 00:00:00 2001 From: des Date: Thu, 6 Jun 2002 12:12:23 +0000 Subject: Support suidperl as well. --- usr.bin/perl/Makefile | 3 ++- usr.bin/perl/perl.c | 8 ++++++-- 2 files changed, 8 insertions(+), 3 deletions(-) (limited to 'usr.bin/perl') diff --git a/usr.bin/perl/Makefile b/usr.bin/perl/Makefile index fea5979..0c03778 100644 --- a/usr.bin/perl/Makefile +++ b/usr.bin/perl/Makefile @@ -3,6 +3,7 @@ PROG= perl NOMAN= WARNS?= 6 -LINKS= ${BINDIR}/perl ${BINDIR}/perl5 +LINKS= ${BINDIR}/perl ${BINDIR}/perl5 \ + ${BINDIR}/perl ${BINDIR}/suidperl .include diff --git a/usr.bin/perl/perl.c b/usr.bin/perl/perl.c index 15a155d..7bd52ad 100644 --- a/usr.bin/perl/perl.c +++ b/usr.bin/perl/perl.c @@ -44,15 +44,19 @@ int main(int argc __unused, char *argv[]) { char path[PATH_MAX]; - const char *p, *q, *self; + const char *cmd, *p, *q, *self; size_t len; self = argv[0]; + if ((cmd = strrchr(self, '/')) == NULL) + cmd = self; + else + cmd++; argv[0] = path; for (p = q = getenv("PATH"); p && *p && *q; p = q + 1) { for (q = p; *q && *q != ':'; ++q) /* nothing */ ; - len = snprintf(path, sizeof path, "%.*s/perl", (int)(q - p), p); + len = snprintf(path, sizeof path, "%.*s/%s", (int)(q - p), p, cmd); if (len >= PATH_MAX || strcmp(path, self) == 0) continue; execve(path, argv, environ); -- cgit v1.1