BEGIN {
$ENV
{MODULEBUILDRC} =
'NONE'
;
my
$t_lib
= File::Spec->catdir(
't'
,
'bundled'
);
unless
(
$ENV
{PERL_CORE}) {
push
@INC
,
$t_lib
;
}
else
{
@INC
= (
map
(File::Spec->rel2abs(
$_
),
@INC
),
"."
);
chdir
'..'
or
die
"Couldn't chdir to .."
;
push
@INC
, File::Spec->catdir(
qw/lib Module Build/
,
$t_lib
);
$ENV
{PERL5LIB} = File::Spec->catdir(Cwd::cwd(),
'lib'
);
}
}
use
vars
qw($VERSION @ISA @EXPORT %EXPORT_TAGS $TODO)
;
$VERSION
= 0.01;
@ISA
=
qw(Test::More)
;
@EXPORT
=
@Test::More::EXPORT
;
%EXPORT_TAGS
=
%Test::More::EXPORT_TAGS
;
my
@extra_exports
=
qw(
stdout_of
stderr_of
stdout_stderr_of
slurp
find_in_path
check_compiler
have_module
ensure_blib
)
;
push
@EXPORT
,
@extra_exports
;
__PACKAGE__->export(
scalar
caller
,
@extra_exports
);
{
my
$cwd
= Cwd::cwd;
my
$tmp
= File::Spec->catdir(
$cwd
,
't'
,
'_tmp'
. $$);
mkdir
$tmp
, 0777
unless
-d
$tmp
;
sub
tmpdir {
$tmp
}
END {
if
(-d
$tmp
) {
chdir
$cwd
or
die
"Couldn't chdir to $cwd"
;
File::Path::rmtree(
$tmp
) or diag
"cannot clean dir '$tmp'"
;
}
}
}
{
my
$tmp_count
= 0;
my
$tmp_base_name
=
sprintf
(
"%d-%d"
, $$,
time
());
sub
temp_file_name {
sprintf
(
"%s-%04d"
,
$tmp_base_name
, ++
$tmp_count
)
}
}
sub
save_handle {
my
(
$handle
,
$subr
) =
@_
;
my
$outfile
= temp_file_name();
local
*SAVEOUT
;
open
SAVEOUT,
">&"
.
fileno
(
$handle
)
or
die
"Can't save output handle: $!"
;
open
$handle
,
"> $outfile"
or
die
"Can't create $outfile: $!"
;
eval
{
$subr
->()};
open
$handle
,
">&SAVEOUT"
or
die
"Can't restore output: $!"
;
my
$ret
= slurp(
$outfile
);
1
while
unlink
$outfile
;
return
$ret
;
}
sub
stdout_of { save_handle(\
*STDOUT
,
@_
) }
sub
stderr_of { save_handle(\
*STDERR
,
@_
) }
sub
stdout_stderr_of {
my
$subr
=
shift
;
my
(
$stdout
,
$stderr
);
$stdout
= stdout_of (
sub
{
$stderr
= stderr_of(
$subr
)
});
return
(
$stdout
,
$stderr
);
}
sub
slurp {
my
$fh
= IO::File->new(
$_
[0]) or
die
"Can't open $_[0]: $!"
;
local
$/;
return
scalar
<
$fh
>;
}
sub
exe_exts {
if
($^O eq
'MSWin32'
) {
return
split
(
$Config
{path_sep},
$ENV
{PATHEXT} ||
'.com;.exe;.bat'
);
}
if
($^O eq
'os2'
) {
return
qw(.exe .com .pl .cmd .bat .sh .ksh)
;
}
return
;
}
sub
find_in_path {
my
$thing
=
shift
;
my
@path
=
split
$Config
{path_sep},
$ENV
{PATH};
my
@exe_ext
= exe_exts();
foreach
(
@path
) {
my
$fullpath
= File::Spec->catfile(
$_
,
$thing
);
foreach
my
$ext
(
''
,
@exe_ext
) {
return
"$fullpath$ext"
if
-e
"$fullpath$ext"
;
}
}
return
;
}
sub
check_compiler {
return
(1,1)
if
$ENV
{PERL_CORE};
local
$SIG
{__WARN__} =
sub
{};
my
$mb
= Module::Build->current;
$mb
->verbose( 0 );
my
$have_c_compiler
;
stderr_of(
sub
{
$have_c_compiler
=
$mb
->have_c_compiler} );
return
(
$have_c_compiler
,
$mb
->feature(
'C_support'
));
}
sub
have_module {
my
$module
=
shift
;
return
eval
"use $module; 1"
;
}
sub
ensure_blib {
my
$mod
=
shift
;
(
my
$path
=
$mod
) =~ s{::}{/}g;
SKIP: {
skip
"no blib in core"
, 1
if
$ENV
{PERL_CORE};
like
$INC
{
"$path.pm"
},
qr/\bblib\b/
,
"Make sure $mod was loaded from blib/"
;
}
}
1;