require warnings and warnings->import;
require strict and strict->import;
}
-
- # allow 'use ANFANG' to work after it's been do()ne
- $INC{"ANFANG.pm"} ||= __FILE__;
- $INC{"t/lib/ANFANG.pm"} ||= __FILE__;
- $INC{"./t/lib/ANFANG.pm"} ||= __FILE__;
}
-BEGIN {
+#
+# FROM THIS POINT ONWARD EVERYTHING HAPPENS LINEARLY AT RUNTIME
+#
+our $anfang_loaded;
+
+# this allows the obscure but possible call case to behave correctly:
+#
+# perl -Mt::lib::ANFANG -e 'do "./t/lib/ANFANG.pm" or die ( $@ || $! )'
+#
+return 1 if $anfang_loaded;
+
+# cover even more bases
+$INC{$_} ||= __FILE__ for (qw( ANFANG.pm t/lib/ANFANG.pm ./t/lib/ANFANG.pm ));
+{
# load-me-first sanity check
if (
and
- # if this is set - all bets are off
- ! $ENV{PERL5OPT}
+ # if these are set - all bets are off
+ ! (
+ $ENV{PERL5OPT}
+ or
+ scalar grep { $_ =~ m| \/ sitecustomize\.pl $ |x } keys %INC
+ )
and
and
+ # a ghetto way of recognizing cperl without loading Config.pm
+ # the $] guard is there because touching $^V on pre-5.10 loads
+ # the entire utf8 stack (wtf!!!)
+ ( "$]" < 5.010 or $^V !~ /\d+c$/ )
+
+ and
+
# just don't check anything under RELEASE_TESTING
# a naive approach would be to simply whitelist both
# strict and warnings, but pre 5.10 there were even
goto $orig;
};
}
-
}
-use lib 't/lib';
+
+require lib;
+lib->import('t/lib');
+
+
+# everything expects this to be there
+! -d 't/var' and (
+ mkdir 't/var'
+ or
+ die "Unable to create 't/var': $!\n"
+);
+
# Back in ab340f7f ribasushi stupidly introduced a "did you check your deps"
# verification tied very tightly to Module::Install. The check went away, and
# dead. In order to reduce hair-pulling make sure that ./inc/ is always there
-f 'Makefile.PL' and mkdir 'inc' and mkdir 'inc/.author';
-1;
+END {
+ if( my @finalest_tasks = (
+
+ ( !$ENV{DBICTEST_DIRTY_EXIT} ? () : sub {
+
+ my $exit = $?;
+ require POSIX;
+
+ # Crucial flushes in case we are piping things out (e.g. prove)
+ # Otherwise the last lines will never arrive at the receiver
+ close($_) for \*STDOUT, \*STDERR;
+
+ POSIX::_exit($exit);
+ } ),
+
+ )) {
+
+ # in the case of an early skip_all B may very well not have loaded
+ unless( $INC{"B.pm"} ) {
+ local ( $!, $^E, $?, $@ );
+ require B;
+ }
+
+ # Make sure we run after any cleanup in other END blocks
+ # ( push-to-end twice in a row )
+ push @{ B::end_av()->object_2svref }, sub {
+ push @{ B::end_av()->object_2svref }, @finalest_tasks;
+ }
+ }
+}
+
+# make absolutely sure this is last
+$anfang_loaded = 1;