develooper Front page | perl.perl5.porters | Postings from June 2008

PERL5OPT -M processed after command line -M?

Thread Next
From:
David Golden
Date:
June 2, 2008 20:28
Subject:
PERL5OPT -M processed after command line -M?
Message ID:
5d4beb40806022028r4e920f3bn65167f5ef9ccb738@mail.gmail.com
I was a little surprised to find that -M switches in PERL5OPT get
processed after any -M options on the command line.  (Whereas -I
options in PERL5OPT are processed earlier as expected.)

E.g., assuming foo.pm in lib/

# works
  $ perl -Ilib -Mfoo -e 1
  $ perl -Mlib=lib -Mfoo -e 1
  $ PERL5OPT=-Ilib perl -Mfoo -e 1

# doesn't work
  $ PERL5OPT=-Mlib=lib perl -Mfoo -e 1

The implication is that one can't (shouldn't) use modules in PERL5OPT
to manipulate @INC or override how modules are loaded.  Among
practical applications, that would seem to rule out the CPAN::PERL5INC
trick to replace $ENV{PERL5LIB} munging with a module loaded from
PERL5OPT.  (Which was intended to avoid having PERL5LIB clipped by OS
limitations.)

If this is intentional behavior, then it would be good to document it
in perlrun.  If it's not intentional, should it be fixed?  Or is
fixing it likely to break other things?

-- David

Thread Next


nntp.perl.org: Perl Programming lists via nntp and http.
Comments to Ask Bjørn Hansen at ask@perl.org | Group listing | About