in reply to Do not working as expected on Windows

You didn't check if do succeeded.

if (!do($include)) { my $error = $@ ? $@ : $! ? $! : 'did not return a true value'; die("Unable to load common stuff: $error\n"); }

It probably failed because the current working directory is not what you think it is.

Use absolute paths,

use File::Basename qw( dirname ); use File::Spec::Functions qw( rel2abs ); my $include_fq = rel2abs('common.inc', dirname(rel2abs($0))); if (!do($include_fq)) { my $error = $@ ? $@ : $! ? $! : 'did not return a true value'; die("Unable to load common stuff: $error\n"); }

use absolute paths in @INC,

use File::Basename qw( dirname ); use File::Spec::Functions qw( rel2abs ); use lib dirname(rel2abs($0)); if (!do('common.inc')) { my $error = $@ ? $@ : $! ? $! : 'did not return a true value'; die("Unable to load common stuff: $error\n"); }

or change the current directory to where you expect it to be.

use File::Basename qw( dirname ); use File::Spec::Functions qw( rel2abs ); BEGIN { chdir(dirname(rel2abs($0))); } if (!do('common.inc')) { my $extra = $@ ? ": $@" : $! ? ": $!" : ': did not return a true value'; die("Unable to load common stuff$extra\n"); }

P.S. — What's with "./"? "./foo" is the same thing as just "foo".

Update: Added $!/$@ to the error message when do sets them.
Update: Added use lib solution.

Replies are listed 'Best First'.
Re^2: Do not working as expected on Windows
by gwhite (Friar) on Sep 04, 2007 at 15:41 UTC

    Using the code that works with the @INC looks like the best option for me, one question on it, I have already set some libraries to use for some special reporting code, will the use lib statement in your snippet have any negative effect?

    g_White

      @INC is the search path used by do, require and use. use lib adds a path to the front of @INC. That could only lead to a problem if you have two identically named modules in different paths. Then, do/require/use might load the wrong one.