From b8378b72956f290ff41ea1ce3b194c78c89181a1 Mon Sep 17 00:00:00 2001 From: Chip Salzenberg Date: Sun, 5 Jan 1997 10:51:38 +1200 Subject: Fix $^X on systems that set it to Perl's basename --- toke.c | 45 +++++++++++++++++++++++++++++++-------------- 1 file changed, 31 insertions(+), 14 deletions(-) (limited to 'toke.c') diff --git a/toke.c b/toke.c index 5d53fb314c..39a7f572d7 100644 --- a/toke.c +++ b/toke.c @@ -1567,23 +1567,40 @@ yylex() if (*s == ':' && s[1] != ':') /* for csh execing sh scripts */ s++; if (!in_eval && *s == '#' && s[1] == '!') { -#ifdef ARG_ZERO_IS_SCRIPT /* - * HP-UX (at least) sets argv[0] to the script - * name, which makes $^X incorrect. - * So, having found "#!", we'll set it right. + * HP-UX (at least) sets argv[0] to the script name, + * which makes $^X incorrect. And Digital UNIX and Linux, + * at least, set argv[0] to the basename of the Perl + * interpreter. So, having found "#!", we'll set it right. */ - GV *x = gv_fetchpv("\030", TRUE, SVt_PV); - if (sv_eq(GvSV(x), GvSV(curcop->cop_filegv))) { - char *a = s + 2; - while (*a == ' ' || *a == '\t') - a++; - d = a; - while (*d && !isSPACE(*d)) - d++; - sv_setpvn(GvSV(x), a, d - a); + SV *x = GvSV(gv_fetchpv("\030", TRUE, SVt_PV)); + char *ipath; + char *ibase; + + d = s + 2; + while (*d == ' ' || *d == '\t') + d++; + ipath = d; + ibase = Nullch; + while (*d && !isSPACE(*d)) { + if (*d++ == '/') + ibase = d; } -#endif /* ARG_ZERO_IS_SCRIPT */ + assert(SvPOK(x) || SvGMAGICAL(x)); + if (sv_eq(x, GvSV(curcop->cop_filegv)) + || (ibase + && SvCUR(x) == (d - ibase) + && strnEQ(SvPVX(x), ibase, d - ibase))) + sv_setpvn(x, ipath, d - ipath); + /* + * $^X is always tainted, but taintedness must be off + * when parsing code, so forget we ever saw it. + */ + TAINT_NOT; + + /* + * Look for options. + */ d = instr(s,"perl -"); if (!d) d = instr(s,"perl"); -- cgit v1.2.1