our
$VERSION
=
'7.39_02'
;
$VERSION
=~
tr
/_//d;
BEGIN {
our
@ISA
=
qw(File::Spec)
; }
my
$Curdir
= __PACKAGE__->curdir;
my
$METASPEC_V
= 2;
Hide Show 81 lines of Pod
sub
os_flavor_is {
my
$self
=
shift
;
my
%flavors
=
map
{ (
$_
=> 1) }
$self
->os_flavor;
return
(
grep
{
$flavors
{
$_
} }
@_
) ? 1 : 0;
}
Hide Show 11 lines of Pod
sub
can_load_xs {
return
defined
&DynaLoader::boot_DynaLoader
? 1 : 0;
}
Hide Show 16 lines of Pod
sub
can_run {
my
(
$self
,
$command
) =
@_
;
if
( $^O eq
'VMS'
) {
my
$syms
= VMS::DCLsym->new;
return
$command
if
scalar
$syms
->getsym(
uc
$command
);
}
my
@possibles
;
if
( File::Spec->file_name_is_absolute(
$command
) ) {
return
$self
->maybe_command(
$command
);
}
else
{
for
my
$dir
(
File::Spec->path,
File::Spec->curdir
) {
next
if
!
$dir
|| ! -d
$dir
;
my
$abs
= File::Spec->catfile(
$self
->os_flavor_is(
'Win32'
) ? Win32::GetShortPathName(
$dir
) :
$dir
,
$command
);
push
@possibles
,
$abs
if
$abs
=
$self
->maybe_command(
$abs
);
}
}
return
@possibles
if
wantarray
;
return
shift
@possibles
;
}
Hide Show 9 lines of Pod
sub
can_redirect_error {
my
$self
=
shift
;
$self
->os_flavor_is(
'Unix'
)
or (
$self
->os_flavor_is(
'Win32'
) and !
$self
->os_flavor_is(
'Win9x'
))
or
$self
->os_flavor_is(
'OS/2'
)
}
Hide Show 13 lines of Pod
my
%maketype2true
;
sub
_clear_maketype_cache {
%maketype2true
= () }
sub
is_make_type {
my
(
$self
,
$type
) =
@_
;
return
$maketype2true
{
$type
}
if
defined
$maketype2true
{
$type
};
(
undef
,
undef
,
my
$make_basename
) =
$self
->splitpath(
$self
->make);
return
$maketype2true
{
$type
} = 1
if
$make_basename
=~ /\b
$type
\b/i;
return
$maketype2true
{
$type
} = 0
if
$make_basename
=~ /\b[gdn]make\b/i;
my
$redirect
=
$self
->can_redirect_error ?
'2>&1'
:
''
;
my
$make
=
$self
->make ||
$self
->{MAKE};
my
$minus_v
= `
"$make"
-v
$redirect
`;
return
$maketype2true
{
$type
} = 1
if
$type
eq
'gmake'
and
$minus_v
=~ /GNU make/i;
return
$maketype2true
{
$type
} = 1
if
$type
eq
'bsdmake'
and
$minus_v
=~ /^usage: make \[-BeikNnqrstWwX\]/im;
$maketype2true
{
$type
} = 0;
}
Hide Show 10 lines of Pod
my
$cached_dep_space
;
sub
can_dep_space {
my
$self
=
shift
;
return
$cached_dep_space
if
defined
$cached_dep_space
;
return
$cached_dep_space
= 1
if
$self
->is_make_type(
'gmake'
);
return
$cached_dep_space
= 0
if
$self
->is_make_type(
'dmake'
);
return
$cached_dep_space
= 0
if
$self
->is_make_type(
'bsdmake'
);
return
$cached_dep_space
= 0;
}
Hide Show 12 lines of Pod
sub
quote_dep {
my
(
$self
,
$arg
) =
@_
;
die
<<EOF if $arg =~ / / and not $self->can_dep_space;
Tried to use make dependency with space for make that can't:
'$arg'
EOF
$arg
=~ s/( )/\\$1/g;
return
$arg
;
}
Hide Show 26 lines of Pod
sub
split_command {
my
(
$self
,
$cmd
,
@args
) =
@_
;
my
@cmds
= ();
return
(
@cmds
)
unless
@args
;
chomp
$cmd
;
my
$len_left
=
int
(
$self
->max_exec_len * 0.70);
$len_left
-=
length
$self
->_expand_macros(
$cmd
);
do
{
my
$arg_str
=
''
;
my
@next_args
;
while
(
@next_args
=
splice
(
@args
, 0, 2) ) {
my
$next_arg_str
=
"\t "
.
join
' '
,
@next_args
,
"\n"
;
if
( !
length
$arg_str
) {
$arg_str
.=
$next_arg_str
}
elsif
(
length
(
$arg_str
) +
length
(
$next_arg_str
) >
$len_left
) {
unshift
@args
,
@next_args
;
last
;
}
else
{
$arg_str
.=
$next_arg_str
;
}
}
chop
$arg_str
;
push
@cmds
,
$self
->escape_newlines(
"$cmd \n$arg_str"
);
}
while
@args
;
return
@cmds
;
}
sub
_expand_macros {
my
(
$self
,
$cmd
) =
@_
;
$cmd
=~ s{\$\((\w+)\)}{
defined
$self
->{$1} ?
$self
->{$1} :
"\$($1)"
}e;
return
$cmd
;
}
Hide Show 6 lines of Pod
sub
make_type {
return
'Unix-style'
; }
Hide Show 12 lines of Pod
sub
stashmeta {
my
(
$self
,
$text
,
$file
) =
@_
;
$self
->echo(
$text
,
$file
, {
allow_variables
=> 0,
append
=> 0 });
}
Hide Show 23 lines of Pod
sub
echo {
my
(
$self
,
$text
,
$file
,
$opts
) =
@_
;
if
( !
ref
$opts
) {
my
$append
=
$opts
;
$opts
= {
append
=>
$append
|| 0 };
}
$opts
->{allow_variables} = 0
unless
defined
$opts
->{allow_variables};
my
$ql_opts
= {
allow_variables
=>
$opts
->{allow_variables} };
my
@cmds
=
map
{
'$(NOECHO) $(ECHO) '
.
$self
->quote_literal(
$_
,
$ql_opts
) }
split
/\n/,
$text
;
if
(
$file
) {
my
$redirect
=
$opts
->{append} ?
'>>'
:
'>'
;
$cmds
[0] .=
" $redirect $file"
;
$_
.=
" >> $file"
foreach
@cmds
[1..
$#cmds
];
}
return
@cmds
;
}
Hide Show 13 lines of Pod
sub
wraplist {
my
$self
=
shift
;
return
join
" \\\n\t"
,
@_
;
}
Hide Show 15 lines of Pod
sub
maketext_filter {
return
$_
[1] }
Hide Show 86 lines of Pod
sub
escape_dollarsigns {
my
(
$self
,
$text
) =
@_
;
$text
=~ s{\$ (?!\() }{\$\$}gx;
return
$text
;
}
Hide Show 8 lines of Pod
sub
escape_all_dollarsigns {
my
(
$self
,
$text
) =
@_
;
$text
=~ s{\$}{\$\$}gx;
return
$text
;
}
Hide Show 27 lines of Pod
sub
make {
my
$self
=
shift
;
my
$make
=
lc
$self
->{MAKE};
$make
=~ s/^(\w+make).*/$1/;
$make
=~ s/^gnu/g/;
return
$make
;
}
Hide Show 11 lines of Pod
sub
all_target {
my
$self
=
shift
;
return
<<'MAKE_EXT';
all :: pure_all
$(NOECHO) $(NOOP)
MAKE_EXT
}
Hide Show 12 lines of Pod
sub
_xs_list_basenames {
my
(
$self
) =
@_
;
map
{ (
my
$b
=
$_
) =~ s/\.xs$//;
$b
}
sort
keys
%{
$self
->{XS} };
}
sub
blibdirs_target {
my
$self
=
shift
;
my
@dirs
=
map
{
uc
"\$(INST_$_)"
}
qw(libdir archlib
autodir archautodir
bin script
man1dir man3dir
)
;
if
(
$self
->{XSMULTI}) {
for
my
$ext
(
$self
->_xs_list_basenames) {
my
(
$v
,
$d
,
$f
) = File::Spec->splitpath(
$ext
);
my
@d
= File::Spec->splitdir(
$d
);
shift
@d
if
$d
[0] eq
'lib'
;
push
@dirs
,
$self
->catdir(
'$(INST_ARCHLIB)'
,
'auto'
,
@d
,
$f
);
}
}
my
@exists
=
map
{
$_
.
'$(DFSEP).exists'
}
@dirs
;
my
$make
=
sprintf
<<'MAKE', join(' ', @exists);
blibdirs : %s
$(NOECHO) $(NOOP)
# Backwards compat with 6.18 through 6.25
blibdirs.ts : blibdirs
$(NOECHO) $(NOOP)
MAKE
$make
.=
$self
->dir_target(
@dirs
);
return
$make
;
}
Hide Show 6 lines of Pod
sub
clean {
my
(
$self
,
%attribs
) =
@_
;
my
@m
;
push
(
@m
, '
clean :: clean_subdirs
');
my
@files
=
sort
values
%{
$self
->{XS}};
push
@files
,
map
{
my
$file
=
$_
;
map
{
$file
.
$_
}
$self
->{OBJ_EXT},
qw(.def _def.old .bs .bso .exp .base)
;
}
$self
->_xs_list_basenames;
my
@dirs
=
qw(blib)
;
if
(
$attribs
{FILES} ) {
push
@dirs
,
ref
$attribs
{FILES} ?
@{
$attribs
{FILES}} :
split
/\s+/,
$attribs
{FILES} ;
}
push
(
@files
,
qw[$(MAKE_APERL_FILE)
MYMETA.json MYMETA.yml perlmain.c tmon.out mon.out so_locations
blibdirs.ts pm_to_blib pm_to_blib.ts
*$(OBJ_EXT) *$(LIB_EXT) perl.exe perl perl$(EXE_EXT)
$(BOOTSTRAP) $(BASEEXT).bso
$(BASEEXT).def lib$(BASEEXT).def
$(BASEEXT).exp $(BASEEXT).x
]
);
push
(
@files
,
$self
->catfile(
'$(INST_ARCHAUTODIR)'
,
'extralibs.all'
));
push
(
@files
,
$self
->catfile(
'$(INST_ARCHAUTODIR)'
,
'extralibs.ld'
));
if
($^O eq
'vos'
) {
push
(
@files
,
qw[perl*.kp]
);
}
else
{
push
(
@files
,
qw[core core.*perl.*.? *perl.core]
);
}
push
(
@files
,
map
{
"core."
.
"[0-9]"
x
$_
} (1..5));
push
@dirs
,
$self
->extra_clean_files;
{
my
(
%f
) =
map
{ (
$_
=> 1) }
@files
;
@files
=
sort
keys
%f
; }
{
my
(
%d
) =
map
{ (
$_
=> 1) }
@dirs
;
@dirs
=
sort
keys
%d
; }
push
@m
,
map
"\t$_\n"
,
$self
->split_command(
'- $(RM_F)'
,
@files
);
push
@m
,
map
"\t$_\n"
,
$self
->split_command(
'- $(RM_RF)'
,
@dirs
);
push
@m
,
<<'MAKE';
$(NOECHO) $(RM_F) $(MAKEFILE_OLD)
- $(MV) $(FIRST_MAKEFILE) $(MAKEFILE_OLD) $(DEV_NULL)
MAKE
push
(
@m
,
"\t$attribs{POSTOP}\n"
)
if
$attribs
{POSTOP};
join
(
""
,
@m
);
}
Hide Show 9 lines of Pod
sub
clean_subdirs_target {
my
(
$self
) =
shift
;
return
<<'NOOP_FRAG' unless @{$self->{DIR}};
clean_subdirs :
$(NOECHO) $(NOOP)
NOOP_FRAG
my
$clean
=
"clean_subdirs :\n"
;
for
my
$dir
(@{
$self
->{DIR}}) {
my
$subclean
=
$self
->oneliner(
sprintf
<<'CODE', $dir);
exit 0 unless chdir '%s'; system '$(MAKE) clean' if -f '$(FIRST_MAKEFILE)';
CODE
$clean
.=
"\t$subclean\n"
;
}
return
$clean
;
}
Hide Show 17 lines of Pod
sub
dir_target {
my
(
$self
,
@dirs
) =
@_
;
my
$make
=
''
;
foreach
my
$dir
(
@dirs
) {
$make
.=
sprintf
<<'MAKE', ($dir) x 4;
%s$(DFSEP).exists :: Makefile.PL
$(NOECHO) $(MKPATH) %s
$(NOECHO) $(CHMOD) $(PERM_DIR) %s
$(NOECHO) $(TOUCH) %s$(DFSEP).exists
MAKE
}
return
$make
;
}
Hide Show 7 lines of Pod
*dist_dir
=
*distdir
;
sub
distdir {
my
(
$self
) =
shift
;
my
$meta_target
=
$self
->{NO_META} ?
''
:
'distmeta'
;
my
$sign_target
= !
$self
->{SIGN} ?
''
:
'distsignature'
;
return
sprintf
<<'MAKE_FRAG', $meta_target, $sign_target;
create_distdir :
$(RM_RF) $(DISTVNAME)
$(PERLRUN) "-MExtUtils::Manifest=manicopy,maniread" \
-e "manicopy(maniread(),'$(DISTVNAME)', '$(DIST_CP)');"
distdir : create_distdir %s %s
$(NOECHO) $(NOOP)
MAKE_FRAG
}
Hide Show 8 lines of Pod
sub
dist_test {
my
(
$self
) =
shift
;
my
$mpl_args
=
join
" "
,
map
qq["$_"]
,
@ARGV
;
my
$test
=
$self
->cd(
'$(DISTVNAME)'
,
'$(ABSPERLRUN) Makefile.PL '
.
$mpl_args
,
'$(MAKE) $(PASTHRU)'
,
'$(MAKE) test $(PASTHRU)'
);
return
sprintf
<<'MAKE_FRAG', $test;
disttest : distdir
%s
MAKE_FRAG
}
Hide Show 7 lines of Pod
sub
xs_dlsyms_arg {
return
''
;
}
Hide Show 7 lines of Pod
sub
xs_dlsyms_ext {
die
"Pure virtual method"
;
}
Hide Show 7 lines of Pod
sub
xs_dlsyms_extra {
''
;
}
Hide Show 7 lines of Pod
sub
xs_dlsyms_iterator {
my
(
$self
,
$attribs
) =
@_
;
if
(
$self
->{XSMULTI}) {
my
@m
;
for
my
$ext
(
$self
->_xs_list_basenames) {
my
@parts
= File::Spec->splitdir(
$ext
);
shift
@parts
if
$parts
[0] eq
'lib'
;
my
$name
=
join
'::'
,
@parts
;
push
@m
,
$self
->xs_make_dlsyms(
$attribs
,
$ext
.
$self
->xs_dlsyms_ext,
"$ext.xs"
,
$name
,
$parts
[-1],
{}, [], {}, [],
$self
->xs_dlsyms_extra .
q!, 'FILE' => !
. neatvalue(
$ext
),
);
}
return
join
"\n"
,
@m
;
}
else
{
return
$self
->xs_make_dlsyms(
$attribs
,
$self
->{BASEEXT} .
$self
->xs_dlsyms_ext,
'Makefile.PL'
,
$self
->{NAME},
$self
->{DLBASE},
$attribs
->{DL_FUNCS} ||
$self
->{DL_FUNCS} || {},
$attribs
->{FUNCLIST} ||
$self
->{FUNCLIST} || [],
$attribs
->{IMPORTS} ||
$self
->{IMPORTS} || {},
$attribs
->{DL_VARS} ||
$self
->{DL_VARS} || [],
$self
->xs_dlsyms_extra,
);
}
}
Hide Show 19 lines of Pod
sub
xs_make_dlsyms {
my
(
$self
,
$attribs
,
$target
,
$dep
,
$name
,
$dlbase
,
$funcs
,
$funclist
,
$imports
,
$vars
,
$extra
) =
@_
;
my
@m
= (
"\n$target: $dep\n"
,
q! $(PERLRUN) -MExtUtils::Mksymlists \\
-e "Mksymlists('NAME'=>\"!
,
$name
,
q!\", 'DLBASE' => '!
,
$dlbase
,
q!', 'DL_FUNCS' => !
,neatvalue(
$funcs
),
q!, 'FUNCLIST' => !
,neatvalue(
$funclist
),
q!, 'IMPORTS' => !
,neatvalue(
$imports
),
q!, 'DL_VARS' => !
, neatvalue(
$vars
)
);
push
@m
,
$extra
if
defined
$extra
;
push
@m
,
qq!);"\n!
;
join
''
,
@m
;
}
Hide Show 6 lines of Pod
sub
dynamic {
my
(
$self
) =
shift
;
'
dynamic :: $(FIRST_MAKEFILE) config $(INST_BOOT) $(INST_DYNAMIC)
$(NOECHO) $(NOOP)
';
}
Hide Show 11 lines of Pod
sub
makemakerdflt_target {
return
<<'MAKE_FRAG';
makemakerdflt : all
$(NOECHO) $(NOOP)
MAKE_FRAG
}
Hide Show 9 lines of Pod
sub
manifypods_target {
my
(
$self
) =
shift
;
my
$man1pods
=
''
;
my
$man3pods
=
''
;
my
$dependencies
=
''
;
foreach
my
$name
(
sort
keys
%{
$self
->{MAN1PODS}},
sort
keys
%{
$self
->{MAN3PODS}}) {
$dependencies
.=
" \\\n\t$name"
;
}
my
$manify
=
<<END;
manifypods : pure_all config $dependencies
END
my
@man_cmds
;
foreach
my
$num
(
qw(1 3)
) {
my
$pods
=
$self
->{
"MAN${num}PODS"
};
my
$p2m
=
sprintf
<<'CMD', "\$(MAN${num}SECTION)", "$]" > 5.008 ? " -u" : "";
$(NOECHO) $(POD2MAN) --section=%s --perm_rw=$(PERM_RW)%s
CMD
push
@man_cmds
,
$self
->split_command(
$p2m
,
map
{(
$_
,
$pods
->{
$_
})}
sort
keys
%$pods
);
}
$manify
.=
"\t\$(NOECHO) \$(NOOP)\n"
unless
@man_cmds
;
$manify
.=
join
''
,
map
{
"$_\n"
}
@man_cmds
;
return
$manify
;
}
{
my
$has_cpan_meta
;
sub
_has_cpan_meta {
return
$has_cpan_meta
if
defined
$has_cpan_meta
;
return
$has_cpan_meta
= !!
eval
{
CPAN::Meta->VERSION(2.112150);
1;
};
}
}
Hide Show 12 lines of Pod
sub
metafile_target {
my
$self
=
shift
;
return
<<'MAKE_FRAG' if $self->{NO_META} or ! _has_cpan_meta();
metafile :
$(NOECHO) $(NOOP)
MAKE_FRAG
my
$metadata
=
$self
->metafile_data(
$self
->{META_ADD} || {},
$self
->{META_MERGE} || {},
);
my
$meta
=
$self
->_fix_metadata_before_conversion(
$metadata
);
my
@write_metayml
=
$self
->stashmeta(
$meta
->as_string({
version
=>
"1.4"
}),
'META_new.yml'
);
my
@write_metajson
=
$self
->stashmeta(
$meta
->as_string({
version
=>
"2.0"
}),
'META_new.json'
);
my
$metayml
=
join
(
"\n\t"
,
@write_metayml
);
my
$metajson
=
join
(
"\n\t"
,
@write_metajson
);
return
sprintf
<<'MAKE_FRAG', $metayml, $metajson;
metafile : create_distdir
$(NOECHO) $(ECHO) Generating META.yml
%s
-$(NOECHO) $(MV) META_new.yml $(DISTVNAME)/META.yml
$(NOECHO) $(ECHO) Generating META.json
%s
-$(NOECHO) $(MV) META_new.json $(DISTVNAME)/META.json
MAKE_FRAG
}
Hide Show 14 lines of Pod
sub
_fix_metadata_before_conversion {
my
(
$self
,
$metadata
) =
@_
;
return
unless
_has_cpan_meta;
my
$bad_version
=
$metadata
->{version} &&
!CPAN::Meta::Validator->new->version(
'version'
,
$metadata
->{version} );
if
(
$bad_version
) {
warn
"Can't parse version '$metadata->{version}'\n"
;
$metadata
->{version} =
''
;
}
my
$validator2
= CPAN::Meta::Validator->new(
$metadata
);
my
@errors
;
push
@errors
,
$validator2
->errors
if
!
$validator2
->is_valid;
my
$validator14
= CPAN::Meta::Validator->new(
{
%$metadata
,
'meta-spec'
=> {
version
=> 1.4 },
}
);
push
@errors
,
$validator14
->errors
if
!
$validator14
->is_valid;
for
my
$error
(
@errors
) {
my
(
$key
) = (
$error
=~ /Custom resource
'(.*)'
must be in CamelCase./ );
next
if
!
$key
;
(
my
$new_key
=
$key
) =~ s/[^_a-zA-Z]//g;
$new_key
=
ucfirst
$new_key
if
!
$validator14
->custom_1(
$new_key
);
$metadata
->{resources}{
$new_key
} =
$metadata
->{resources}{
$key
}
if
$validator14
->custom_1(
$new_key
);
delete
$metadata
->{resources}{
$key
};
}
my
$meta
=
eval
{ CPAN::Meta->create(
$metadata
, {
lazy_validation
=> 1 } ) };
warn
$@
if
$@ and
$@ !~ /encountered CODE.*, but JSON can only represent references to arrays or hashes/;
if
( !
$meta
||
!
eval
{
$meta
->as_string( {
version
=>
$METASPEC_V
} ) } ||
!
eval
{
$meta
->as_string }
) {
$meta
=
bless
$metadata
,
'CPAN::Meta'
;
}
my
$now_license
=
$meta
->as_struct({
version
=> 2 })->{license};
if
(
$self
->{LICENSE} and
$self
->{LICENSE} ne
'unknown'
and
@{
$now_license
} == 1 and
$now_license
->[0] eq
'unknown'
) {
warn
"Invalid LICENSE value '$self->{LICENSE}' ignored\n"
;
}
$meta
;
}
Hide Show 13 lines of Pod
sub
_sort_pairs {
my
$sort
=
shift
;
my
$pairs
=
shift
;
return
map
{
$_
=>
$pairs
->{
$_
} }
sort
$sort
keys
%$pairs
;
}
sub
_hash_merge {
my
(
$self
,
$h
,
$k
,
$v
) =
@_
;
if
(
ref
$h
->{
$k
} eq
'ARRAY'
) {
push
@{
$h
->{
$k
}},
ref
$v
?
@$v
:
$v
;
}
elsif
(
ref
$h
->{
$k
} eq
'HASH'
) {
$self
->_hash_merge(
$h
->{
$k
},
$_
,
$v
->{
$_
})
foreach
keys
%$v
;
}
else
{
$h
->{
$k
} =
$v
;
}
}
Hide Show 12 lines of Pod
sub
metafile_data {
my
$self
=
shift
;
my
(
$meta_add
,
$meta_merge
) =
@_
;
$meta_add
||= {};
$meta_merge
||= {};
my
$version
= _normalize_version(
$self
->{VERSION});
my
$release_status
= (
$version
=~ /_/) ?
'unstable'
:
'stable'
;
my
%meta
= (
abstract
=>
$self
->{ABSTRACT} ||
'unknown'
,
author
=>
defined
(
$self
->{AUTHOR}) ?
$self
->{AUTHOR} : [
'unknown'
],
dynamic_config
=> 1,
generated_by
=>
"ExtUtils::MakeMaker version $ExtUtils::MakeMaker::VERSION"
,
license
=> [
$self
->{LICENSE} ||
'unknown'
],
'meta-spec'
=> {
url
=>
$METASPEC_URL
,
version
=>
$METASPEC_V
,
},
name
=>
$self
->{DISTNAME},
release_status
=>
$release_status
,
version
=>
$version
,
no_index
=> {
directory
=> [
qw(t inc)
] },
);
$self
->_add_requirements_to_meta(\
%meta
);
return
\
%meta
;
}
my
$v1_add
= _metaspec_version(
$meta_add
) !~ /^2/;
my
(
$add_v
,
$merge_v
) =
map
_metaspec_version(
$_
),
$meta_add
,
$meta_merge
;
for
my
$frag
(
$meta_add
,
$meta_merge
) {
my
$def_v
=
$frag
==
$meta_add
?
$merge_v
:
$add_v
;
$frag
= CPAN::Meta::Converter->new(
$frag
,
default_version
=>
$def_v
)->upgrade_fragment;
}
while
(
my
(
$key
,
$val
) =
each
%$meta_add
) {
if
(
$v1_add
and
$key
eq
'prereqs'
) {
$meta
{
$key
}{
$_
} =
$val
->{
$_
}
for
keys
%$val
;
}
elsif
(
$key
ne
'meta-spec'
) {
$meta
{
$key
} =
$val
;
}
}
while
(
my
(
$key
,
$val
) =
each
%$meta_merge
) {
next
if
$key
eq
'meta-spec'
;
$self
->_hash_merge(\
%meta
,
$key
,
$val
);
}
return
\
%meta
;
}
Hide Show 4 lines of Pod
sub
_add_requirements_to_meta {
my
(
$self
,
$meta
) =
@_
;
$meta
->{prereqs}{configure}{requires} =
$self
->{ARGS}{CONFIGURE_REQUIRES}
?
$self
->{CONFIGURE_REQUIRES}
: {
'ExtUtils::MakeMaker'
=> 0, };
$meta
->{prereqs}{build}{requires} =
$self
->{ARGS}{BUILD_REQUIRES}
?
$self
->{BUILD_REQUIRES}
: {
'ExtUtils::MakeMaker'
=> 0, };
$meta
->{prereqs}{test}{requires} =
$self
->{TEST_REQUIRES}
if
$self
->{ARGS}{TEST_REQUIRES};
$meta
->{prereqs}{runtime}{requires} =
$self
->{PREREQ_PM}
if
$self
->{ARGS}{PREREQ_PM};
$meta
->{prereqs}{runtime}{requires}{perl} = _normalize_version(
$self
->{MIN_PERL_VERSION})
if
$self
->{MIN_PERL_VERSION};
}
sub
_metaspec_version {
my
(
$meta
) =
@_
;
return
$meta
->{
'meta-spec'
}->{version}
if
defined
$meta
->{
'meta-spec'
}
and
defined
$meta
->{
'meta-spec'
}->{version};
return
'1.4'
;
}
sub
_add_requirements_to_meta_v1_4 {
my
(
$self
,
$meta
) =
@_
;
if
(
$self
->{ARGS}{CONFIGURE_REQUIRES} ) {
$meta
->{configure_requires} =
$self
->{CONFIGURE_REQUIRES};
}
else
{
$meta
->{configure_requires} = {
'ExtUtils::MakeMaker'
=> 0,
};
}
if
(
$self
->{ARGS}{BUILD_REQUIRES} ) {
$meta
->{build_requires} =
$self
->{BUILD_REQUIRES};
}
else
{
$meta
->{build_requires} = {
'ExtUtils::MakeMaker'
=> 0,
};
}
if
(
$self
->{ARGS}{TEST_REQUIRES} ) {
$meta
->{build_requires} = {
%{
$meta
->{build_requires} },
%{
$self
->{TEST_REQUIRES} },
};
}
$meta
->{requires} =
$self
->{PREREQ_PM}
if
defined
$self
->{PREREQ_PM};
$meta
->{requires}{perl} = _normalize_version(
$self
->{MIN_PERL_VERSION})
if
$self
->{MIN_PERL_VERSION};
}
sub
_normalize_version {
my
(
$version
) =
@_
;
$version
= 0
unless
defined
$version
;
if
(
ref
$version
eq
'version'
) {
$version
=
$version
->stringify;
}
elsif
(
$version
=~ /^[^v][^.]*\.[^.]+\./ ) {
$version
=
"v$version"
;
}
else
{
}
return
$version
;
}
Hide Show 31 lines of Pod
sub
_dump_hash {
croak
"first argument should be a hash ref"
unless
ref
$_
[0] eq
'HASH'
;
my
$options
=
shift
;
my
%hash
=
@_
;
my
@pairs
;
my
$k_sort
=
exists
$options
->{key_sort} ?
$options
->{key_sort}
:
sub
{
lc
$a
cmp
lc
$b
};
if
(
$k_sort
) {
croak
"'key_sort' should be a coderef"
unless
ref
$k_sort
eq
'CODE'
;
@pairs
= _sort_pairs(
$k_sort
, \
%hash
);
}
else
{
@pairs
=
@_
;
}
my
$yaml
=
$options
->{use_header} ?
"--- #YAML:1.0\n"
:
''
;
my
$indent
=
$options
->{indent} ||
''
;
my
$k_length
= min(
(
$options
->{max_key_length} || 20),
max(
map
{
length
(
$_
) + 1 }
grep
{ !
ref
$hash
{
$_
} }
keys
%hash
)
);
my
$customs
=
$options
->{customs} || {};
my
$k_format
=
"%-${k_length}s"
;
while
(
@pairs
) {
my
(
$key
,
$val
) =
splice
@pairs
, 0, 2;
$val
=
'~'
unless
defined
$val
;
if
(
ref
$val
eq
'HASH'
) {
if
(
keys
%$val
) {
my
%k_options
= (
delta
=>
$options
->{delta},
use_header
=> 0,
indent
=>
$indent
.
$options
->{delta},
);
if
(
exists
$customs
->{
$key
}) {
my
%k_custom
= %{
$customs
->{
$key
}};
foreach
my
$k
(
qw(key_sort max_key_length customs)
) {
$k_options
{
$k
} =
$k_custom
{
$k
}
if
exists
$k_custom
{
$k
};
}
}
$yaml
.=
$indent
.
"$key:\n"
. _dump_hash(\
%k_options
,
%$val
);
}
else
{
$yaml
.=
$indent
.
"$key: {}\n"
;
}
}
elsif
(
ref
$val
eq
'ARRAY'
) {
if
(
@$val
) {
$yaml
.=
$indent
.
"$key:\n"
;
for
(
@$val
) {
croak
"only nested arrays of non-refs are supported"
if
ref
$_
;
$yaml
.=
$indent
.
$options
->{delta} .
"- $_\n"
;
}
}
else
{
$yaml
.=
$indent
.
"$key: []\n"
;
}
}
elsif
(
ref
$val
and !blessed(
$val
) ) {
croak
"only nested hashes, arrays and objects are supported"
;
}
else
{
$yaml
.=
$indent
.
sprintf
"$k_format %s\n"
,
"$key:"
,
$val
;
}
};
return
$yaml
;
}
sub
blessed {
return
eval
{
$_
[0]->isa(
"UNIVERSAL"
); };
}
sub
max {
return
(
sort
{
$b
<=>
$a
}
@_
)[0];
}
sub
min {
return
(
sort
{
$a
<=>
$b
}
@_
)[0];
}
Hide Show 12 lines of Pod
sub
metafile_file {
my
$self
=
shift
;
my
%dump_options
= (
use_header
=> 1,
delta
=>
' '
x 4,
key_sort
=>
undef
,
);
return
_dump_hash(\
%dump_options
,
@_
);
}
Hide Show 9 lines of Pod
sub
distmeta_target {
my
$self
=
shift
;
my
@add_meta
= (
$self
->oneliner(
<<'CODE', ['-MExtUtils::Manifest=maniadd']),
exit unless -e q{META.yml};
eval { maniadd({q{META.yml} => q{Module YAML meta-data (added by MakeMaker)}}) }
or die "Could not add META.yml to MANIFEST: ${'@'}"
CODE
$self
->oneliner(
<<'CODE', ['-MExtUtils::Manifest=maniadd'])
exit unless -f q{META.json};
eval { maniadd({q{META.json} => q{Module JSON meta-data (added by MakeMaker)}}) }
or die "Could not add META.json to MANIFEST: ${'@'}"
CODE
);
my
@add_meta_to_distdir
=
map
{
$self
->cd(
'$(DISTVNAME)'
,
$_
) }
@add_meta
;
return
sprintf
<<'MAKE', @add_meta_to_distdir;
distmeta : create_distdir metafile
$(NOECHO) %s
$(NOECHO) %s
MAKE
}
Hide Show 9 lines of Pod
sub
mymeta {
my
$self
=
shift
;
my
$file
=
shift
||
''
;
my
$mymeta
=
$self
->_mymeta_from_meta(
$file
);
my
$v2
= 1;
unless
(
$mymeta
) {
$mymeta
=
$self
->metafile_data(
$self
->{META_ADD} || {},
$self
->{META_MERGE} || {},
);
$v2
= 0;
}
$self
->_add_requirements_to_meta(
$mymeta
);
$mymeta
->{dynamic_config} = 0;
return
$mymeta
;
}
sub
_mymeta_from_meta {
my
$self
=
shift
;
my
$metafile
=
shift
||
''
;
return
unless
_has_cpan_meta();
my
$meta
;
for
my
$file
(
$metafile
,
"META.json"
,
"META.yml"
) {
next
unless
-e
$file
;
eval
{
$meta
= CPAN::Meta->load_file(
$file
)->as_struct( {
version
=> 2 } );
};
last
if
$meta
;
}
return
unless
$meta
;
if
(
$meta
->{generated_by} &&
$meta
->{generated_by} =~ /ExtUtils::MakeMaker version ([\d\._]+)/) {
my
$eummv
=
do
{
local
$^W = 0; $1+0; };
if
(
$eummv
< 6.2501) {
return
;
}
}
return
$meta
;
}
Hide Show 8 lines of Pod
sub
write_mymeta {
my
$self
=
shift
;
my
$mymeta
=
shift
;
return
unless
_has_cpan_meta();
my
$meta_obj
=
$self
->_fix_metadata_before_conversion(
$mymeta
);
$meta_obj
->save(
'MYMETA.json'
, {
version
=>
"2.0"
} );
$meta_obj
->save(
'MYMETA.yml'
, {
version
=>
"1.4"
} );
return
1;
}
Hide Show 6 lines of Pod
sub
realclean {
my
(
$self
,
%attribs
) =
@_
;
my
@dirs
=
qw($(DISTVNAME)
);
my
@files
=
qw($(FIRST_MAKEFILE)
$(MAKEFILE_OLD));
if
(
$self
->{PERL_CORE} ) {
push
@dirs
,
qw($(INST_AUTODIR)
$(INST_ARCHAUTODIR));
push
@files
,
values
%{
$self
->{PM}};
}
if
(
$self
->has_link_code ){
push
@files
,
qw($(OBJECT)
);
}
if
(
$attribs
{FILES} ) {
if
(
ref
$attribs
{FILES} ) {
push
@dirs
, @{
$attribs
{FILES} };
}
else
{
push
@dirs
,
split
/\s+/,
$attribs
{FILES};
}
}
{
my
(
%f
) =
map
{ (
$_
=> 1) }
@files
;
@files
=
sort
keys
%f
; }
{
my
(
%d
) =
map
{ (
$_
=> 1) }
@dirs
;
@dirs
=
sort
keys
%d
; }
my
$rm_cmd
=
join
"\n\t"
,
map
{
"$_"
}
$self
->split_command(
'- $(RM_F)'
,
@files
);
my
$rmf_cmd
=
join
"\n\t"
,
map
{
"$_"
}
$self
->split_command(
'- $(RM_RF)'
,
@dirs
);
my
$m
=
sprintf
<<'MAKE', $rm_cmd, $rmf_cmd;
# Delete temporary files (via clean) and also delete dist files
realclean purge :: realclean_subdirs
%s
%s
MAKE
$m
.=
"\t$attribs{POSTOP}\n"
if
$attribs
{POSTOP};
return
$m
;
}
Hide Show 9 lines of Pod
sub
realclean_subdirs_target {
my
$self
=
shift
;
my
@m
=
<<'EOF';
# so clean is forced to complete before realclean_subdirs runs
realclean_subdirs : clean
EOF
return
join
''
,
@m
,
"\t\$(NOECHO) \$(NOOP)\n"
unless
@{
$self
->{DIR}};
foreach
my
$dir
(@{
$self
->{DIR}}) {
foreach
my
$makefile
(
'$(MAKEFILE_OLD)'
,
'$(FIRST_MAKEFILE)'
) {
my
$subrclean
.=
$self
->oneliner(_sprintf562
<<'CODE', $dir, $makefile);
chdir '%1$s'; system '$(MAKE) $(USEMAKEFILE) %2$s realclean' if -f '%2$s';
CODE
push
@m
,
"\t- $subrclean\n"
;
}
}
return
join
''
,
@m
;
}
Hide Show 10 lines of Pod
sub
signature_target {
my
$self
=
shift
;
return
<<'MAKE_FRAG';
signature :
cpansign -s
MAKE_FRAG
}
Hide Show 9 lines of Pod
sub
distsignature_target {
my
$self
=
shift
;
my
$add_sign
=
$self
->oneliner(
<<'CODE', ['-MExtUtils::Manifest=maniadd']);
eval { maniadd({q{SIGNATURE} => q{Public-key signature (added by MakeMaker)}}) }
or die "Could not add SIGNATURE to MANIFEST: ${'@'}"
CODE
my
$sign_dist
=
$self
->cd(
'$(DISTVNAME)'
=>
'cpansign -s'
);
my
$touch_sig
=
$self
->cd(
'$(DISTVNAME)'
=>
'$(TOUCH) SIGNATURE'
);
my
$add_sign_to_dist
=
$self
->cd(
'$(DISTVNAME)'
=>
$add_sign
);
return
sprintf
<<'MAKE', $add_sign_to_dist, $touch_sig, $sign_dist
distsignature : distmeta
$(NOECHO) %s
$(NOECHO) %s
%s
MAKE
}
Hide Show 9 lines of Pod
sub
special_targets {
my
$make_frag
=
<<'MAKE_FRAG';
.SUFFIXES : .xs .c .C .cpp .i .s .cxx .cc $(OBJ_EXT)
.PHONY: all config static dynamic test linkext manifest blibdirs clean realclean disttest distdir pure_all subdirs clean_subdirs makemakerdflt manifypods realclean_subdirs subdirs_dynamic subdirs_pure_nolink subdirs_static subdirs-test_dynamic subdirs-test_static test_dynamic test_static
MAKE_FRAG
$make_frag
.=
<<'MAKE_FRAG' if $ENV{CLEARCASE_ROOT};
.NO_CONFIG_REC: Makefile
MAKE_FRAG
return
$make_frag
;
}
Hide Show 11 lines of Pod
sub
init_ABSTRACT {
my
$self
=
shift
;
if
(
$self
->{ABSTRACT_FROM} and
$self
->{ABSTRACT} ) {
warn
"Both ABSTRACT_FROM and ABSTRACT are set. "
.
"Ignoring ABSTRACT_FROM.\n"
;
return
;
}
if
(
$self
->{ABSTRACT_FROM}){
$self
->{ABSTRACT} =
$self
->parse_abstract(
$self
->{ABSTRACT_FROM}) or
carp
"WARNING: Setting ABSTRACT via file "
.
"'$self->{ABSTRACT_FROM}' failed\n"
;
}
if
(
$self
->{ABSTRACT} &&
$self
->{ABSTRACT} =~ m![[:cntrl:]]+!) {
warn
"WARNING: ABSTRACT contains control character(s),"
.
" they will be removed\n"
;
$self
->{ABSTRACT} =~ s![[:cntrl:]]+!!g;
return
;
}
}
Hide Show 9 lines of Pod
sub
init_INST {
my
(
$self
) =
shift
;
$self
->{INST_ARCHLIB} ||=
$self
->catdir(
$Curdir
,
"blib"
,
"arch"
);
$self
->{INST_BIN} ||=
$self
->catdir(
$Curdir
,
'blib'
,
'bin'
);
unless
(
$self
->{INST_LIB}){
if
(
$self
->{PERL_CORE}) {
$self
->{INST_LIB} =
$self
->{INST_ARCHLIB} =
$self
->{PERL_LIB};
}
else
{
$self
->{INST_LIB} =
$self
->catdir(
$Curdir
,
"blib"
,
"lib"
);
}
}
my
@parentdir
=
split
(/::/,
$self
->{PARENT_NAME});
$self
->{INST_LIBDIR} =
$self
->catdir(
'$(INST_LIB)'
,
@parentdir
);
$self
->{INST_ARCHLIBDIR} =
$self
->catdir(
'$(INST_ARCHLIB)'
,
@parentdir
);
$self
->{INST_AUTODIR} =
$self
->catdir(
'$(INST_LIB)'
,
'auto'
,
'$(FULLEXT)'
);
$self
->{INST_ARCHAUTODIR} =
$self
->catdir(
'$(INST_ARCHLIB)'
,
'auto'
,
'$(FULLEXT)'
);
$self
->{INST_SCRIPT} ||=
$self
->catdir(
$Curdir
,
'blib'
,
'script'
);
$self
->{INST_MAN1DIR} ||=
$self
->catdir(
$Curdir
,
'blib'
,
'man1'
);
$self
->{INST_MAN3DIR} ||=
$self
->catdir(
$Curdir
,
'blib'
,
'man3'
);
return
1;
}
Hide Show 9 lines of Pod
sub
init_INSTALL {
my
(
$self
) =
shift
;
if
(
$self
->{ARGS}{INSTALL_BASE} and
$self
->{ARGS}{PREFIX} ) {
die
"Only one of PREFIX or INSTALL_BASE can be given. Not both.\n"
;
}
if
(
$self
->{ARGS}{INSTALL_BASE} ) {
$self
->init_INSTALL_from_INSTALL_BASE;
}
else
{
$self
->init_INSTALL_from_PREFIX;
}
}
Hide Show 6 lines of Pod
sub
init_INSTALL_from_PREFIX {
my
$self
=
shift
;
$self
->init_lib2arch;
foreach
my
$num
(1, 3) {
my
$k
=
'installsiteman'
.
$num
.
'dir'
;
$self
->{
uc
$k
} ||=
uc
"\$(installman${num}dir)"
unless
$Config
{
$k
};
}
foreach
my
$num
(1, 3) {
my
$k
=
'installvendorman'
.
$num
.
'dir'
;
unless
(
$Config
{
$k
} ) {
$self
->{
uc
$k
} ||=
$Config
{usevendorprefix}
?
uc
"\$(installman${num}dir)"
:
''
;
}
}
$self
->{INSTALLSITEBIN} ||=
'$(INSTALLBIN)'
unless
$Config
{installsitebin};
$self
->{INSTALLSITESCRIPT} ||=
'$(INSTALLSCRIPT)'
unless
$Config
{installsitescript};
unless
(
$Config
{installvendorbin} ) {
$self
->{INSTALLVENDORBIN} ||=
$Config
{usevendorprefix}
?
$Config
{installbin}
:
''
;
}
unless
(
$Config
{installvendorscript} ) {
$self
->{INSTALLVENDORSCRIPT} ||=
$Config
{usevendorprefix}
?
$Config
{installscript}
:
''
;
}
my
$iprefix
=
$Config
{installprefixexp} ||
$Config
{installprefix} ||
$Config
{prefixexp} ||
$Config
{prefix} ||
''
;
my
$vprefix
=
$Config
{usevendorprefix} ?
$Config
{vendorprefixexp} :
''
;
my
$sprefix
=
$Config
{siteprefixexp} ||
''
;
$sprefix
=
$iprefix
unless
$sprefix
;
$self
->{PREFIX} ||=
''
;
if
(
$self
->{PREFIX} ) {
@{
$self
}{
qw(PERLPREFIX SITEPREFIX VENDORPREFIX)
} =
(
'$(PREFIX)'
) x 3;
}
else
{
$self
->{PERLPREFIX} ||=
$iprefix
;
$self
->{SITEPREFIX} ||=
$sprefix
;
$self
->{VENDORPREFIX} ||=
$vprefix
;
$self
->{PREFIX} =
'$('
.
uc
$self
->{INSTALLDIRS}.
'PREFIX)'
;
}
my
$arch
=
$Config
{archname};
my
$version
=
$Config
{version};
my
$libstyle
=
$Config
{installstyle} ||
'lib/perl5'
;
my
$manstyle
=
''
;
if
(
$self
->{LIBSTYLE} ) {
$libstyle
=
$self
->{LIBSTYLE};
$manstyle
=
$self
->{LIBSTYLE} eq
'lib/perl5'
?
'lib/perl5'
:
''
;
}
for
my
$num
(1, 3) {
$self
->{
'INSTALLMAN'
.
$num
.
'DIR'
} ||=
'none'
unless
$Config
{
'installman'
.
$num
.
'dir'
};
}
my
%bin_layouts
=
(
bin
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
'bin'
},
vendorbin
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
'bin'
},
sitebin
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
'bin'
},
script
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
'bin'
},
vendorscript
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
'bin'
},
sitescript
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
'bin'
},
);
my
%man_layouts
=
(
man1dir
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
'man/man1'
,
style
=>
$manstyle
, },
siteman1dir
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
'man/man1'
,
style
=>
$manstyle
, },
vendorman1dir
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
'man/man1'
,
style
=>
$manstyle
, },
man3dir
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
'man/man3'
,
style
=>
$manstyle
, },
siteman3dir
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
'man/man3'
,
style
=>
$manstyle
, },
vendorman3dir
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
'man/man3'
,
style
=>
$manstyle
, },
);
my
%lib_layouts
=
(
privlib
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
''
,
style
=>
$libstyle
, },
vendorlib
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
''
,
style
=>
$libstyle
, },
sitelib
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
'site_perl'
,
style
=>
$libstyle
, },
archlib
=> {
s
=>
$iprefix
,
t
=>
'perl'
,
d
=>
"$version/$arch"
,
style
=>
$libstyle
},
vendorarch
=> {
s
=>
$vprefix
,
t
=>
'vendor'
,
d
=>
"$version/$arch"
,
style
=>
$libstyle
},
sitearch
=> {
s
=>
$sprefix
,
t
=>
'site'
,
d
=>
"site_perl/$version/$arch"
,
style
=>
$libstyle
},
);
if
(
$self
->{LIB} ) {
foreach
my
$var
(
keys
%lib_layouts
) {
my
$Installvar
=
uc
"install$var"
;
if
(
$var
=~ /arch/ ) {
$self
->{
$Installvar
} ||=
$self
->catdir(
$self
->{LIB},
$Config
{archname});
}
else
{
$self
->{
$Installvar
} ||=
$self
->{LIB};
}
}
}
my
%type2prefix
= (
perl
=>
'PERLPREFIX'
,
site
=>
'SITEPREFIX'
,
vendor
=>
'VENDORPREFIX'
);
my
%layouts
= (
%bin_layouts
,
%man_layouts
,
%lib_layouts
);
while
(
my
(
$var
,
$layout
) =
each
(
%layouts
) ) {
my
(
$s
,
$t
,
$d
,
$style
) = @{
$layout
}{
qw(s t d style)
};
my
$r
=
'$('
.
$type2prefix
{
$t
}.
')'
;
warn
"Prefixing $var\n"
if
$Verbose
>= 2;
my
$installvar
=
"install$var"
;
my
$Installvar
=
uc
$installvar
;
next
if
$self
->{
$Installvar
};
$d
=
"$style/$d"
if
$style
;
$self
->prefixify(
$installvar
,
$s
,
$r
,
$d
);
warn
" $Installvar == $self->{$Installvar}\n"
if
$Verbose
>= 2;
}
$self
->{VENDORARCHEXP} ||=
$self
->{INSTALLVENDORARCH};
$self
->{VENDORLIBEXP} ||=
$self
->{INSTALLVENDORLIB};
return
1;
}
Hide Show 6 lines of Pod
my
%map
= (
lib
=> [
qw(lib perl5)
],
arch
=> [(
'lib'
,
'perl5'
,
$Config
{archname})],
bin
=> [
qw(bin)
],
man1dir
=> [
qw(man man1)
],
man3dir
=> [
qw(man man3)
]
);
$map
{script} =
$map
{bin};
sub
init_INSTALL_from_INSTALL_BASE {
my
$self
=
shift
;
@{
$self
}{
qw(PREFIX VENDORPREFIX SITEPREFIX PERLPREFIX)
} =
'$(INSTALL_BASE)'
;
my
%install
;
foreach
my
$thing
(
keys
%map
) {
foreach
my
$dir
((
''
,
'SITE'
,
'VENDOR'
)) {
my
$uc_thing
=
uc
$thing
;
my
$key
=
"INSTALL"
.
$dir
.
$uc_thing
;
$install
{
$key
} ||=
(
$thing
=~ /^man.dir$/ and not
$Config
{
lc
$key
})
?
'none'
:
$self
->catdir(
'$(INSTALL_BASE)'
, @{
$map
{
$thing
}});
}
}
$install
{INSTALLARCHLIB} ||=
delete
$install
{INSTALLARCH};
$install
{INSTALLPRIVLIB} ||=
delete
$install
{INSTALLLIB};
foreach
my
$key
(
keys
%install
) {
$self
->{
$key
} ||=
$install
{
$key
};
}
return
1;
}
Hide Show 31 lines of Pod
sub
init_VERSION {
my
(
$self
) =
shift
;
$self
->{MAKEMAKER} =
$ExtUtils::MakeMaker::Filename
;
$self
->{MM_VERSION} =
$ExtUtils::MakeMaker::VERSION
;
$self
->{MM_REVISION}=
$ExtUtils::MakeMaker::Revision
;
$self
->{VERSION_FROM} ||=
''
;
if
(
$self
->{VERSION_FROM}){
$self
->{VERSION} =
$self
->parse_version(
$self
->{VERSION_FROM});
if
(
$self
->{VERSION} eq
'undef'
) {
carp(
"WARNING: Setting VERSION via file "
.
"'$self->{VERSION_FROM}' failed\n"
);
}
}
if
(
defined
$self
->{VERSION}) {
if
(
$self
->{VERSION} !~ /^\s
*v
?[\d_\.]+\s*$/ ) {
my
$normal
=
eval
{ version->new(
$self
->{VERSION} ) };
$self
->{VERSION} =
$normal
if
defined
$normal
;
}
$self
->{VERSION} =~ s/^\s+//;
$self
->{VERSION} =~ s/\s+$//;
}
else
{
$self
->{VERSION} =
''
;
}
$self
->{VERSION_MACRO} =
'VERSION'
;
(
$self
->{VERSION_SYM} =
$self
->{VERSION}) =~ s/\W/_/g;
$self
->{DEFINE_VERSION} =
'-D$(VERSION_MACRO)=\"$(VERSION)\"'
;
$self
->{XS_VERSION} ||=
$self
->{VERSION};
$self
->{XS_VERSION_MACRO} =
'XS_VERSION'
;
$self
->{XS_DEFINE_VERSION} =
'-D$(XS_VERSION_MACRO)=\"$(XS_VERSION)\"'
;
}
Hide Show 36 lines of Pod
sub
init_tools {
my
$self
=
shift
;
$self
->{ECHO} ||=
$self
->oneliner(
'binmode STDOUT, qq{:raw}; print qq{@ARGV}'
, [
'-l'
]);
$self
->{ECHO_N} ||=
$self
->oneliner(
'print qq{@ARGV}'
);
$self
->{TOUCH} ||=
$self
->oneliner(
'touch'
, [
"-MExtUtils::Command"
]);
$self
->{CHMOD} ||=
$self
->oneliner(
'chmod'
, [
"-MExtUtils::Command"
]);
$self
->{RM_F} ||=
$self
->oneliner(
'rm_f'
, [
"-MExtUtils::Command"
]);
$self
->{RM_RF} ||=
$self
->oneliner(
'rm_rf'
, [
"-MExtUtils::Command"
]);
$self
->{TEST_F} ||=
$self
->oneliner(
'test_f'
, [
"-MExtUtils::Command"
]);
$self
->{TEST_S} ||=
$self
->oneliner(
'test_s'
, [
"-MExtUtils::Command::MM"
]);
$self
->{CP_NONEMPTY} ||=
$self
->oneliner(
'cp_nonempty'
, [
"-MExtUtils::Command::MM"
]);
$self
->{FALSE} ||=
$self
->oneliner(
'exit 1'
);
$self
->{TRUE} ||=
$self
->oneliner(
'exit 0'
);
$self
->{MKPATH} ||=
$self
->oneliner(
'mkpath'
, [
"-MExtUtils::Command"
]);
$self
->{CP} ||=
$self
->oneliner(
'cp'
, [
"-MExtUtils::Command"
]);
$self
->{MV} ||=
$self
->oneliner(
'mv'
, [
"-MExtUtils::Command"
]);
$self
->{MOD_INSTALL} ||=
$self
->oneliner(
<<'CODE', ['-MExtUtils::Install']);
install([ from_to => {@ARGV}, verbose => '$(VERBINST)', uninstall_shadows => '$(UNINST)', dir_mode => '$(PERM_DIR)' ]);
CODE
$self
->{DOC_INSTALL} ||=
$self
->oneliner(
'perllocal_install'
, [
"-MExtUtils::Command::MM"
]);
$self
->{UNINSTALL} ||=
$self
->oneliner(
'uninstall'
, [
"-MExtUtils::Command::MM"
]);
$self
->{WARN_IF_OLD_PACKLIST} ||=
$self
->oneliner(
'warn_if_old_packlist'
, [
"-MExtUtils::Command::MM"
]);
$self
->{FIXIN} ||=
$self
->oneliner(
'MY->fixin(shift)'
, [
"-MExtUtils::MY"
]);
$self
->{EQUALIZE_TIMESTAMP} ||=
$self
->oneliner(
'eqtime'
, [
"-MExtUtils::Command"
]);
$self
->{UNINST} ||= 0;
$self
->{VERBINST} ||= 0;
$self
->{SHELL} ||=
$Config
{sh};
$self
->{UMASK_NULL} ||=
"umask 0"
;
$self
->{DEV_NULL} ||=
"> /dev/null 2>&1"
;
$self
->{NOOP} ||=
'$(TRUE)'
;
$self
->{NOECHO} =
'@'
unless
defined
$self
->{NOECHO};
$self
->{FIRST_MAKEFILE} ||=
$self
->{MAKEFILE} ||
'Makefile'
;
$self
->{MAKEFILE} ||=
$self
->{FIRST_MAKEFILE};
$self
->{MAKEFILE_OLD} ||=
$self
->{MAKEFILE}.
'.old'
;
$self
->{MAKE_APERL_FILE} ||=
$self
->{MAKEFILE}.
'.aperl'
;
$self
->{USEMAKEFILE} ||=
'-f'
;
$self
->{MACROSTART} ||=
''
;
$self
->{MACROEND} ||=
''
;
return
;
}
Hide Show 12 lines of Pod
sub
init_others {
my
$self
=
shift
;
$self
->{LD_RUN_PATH} =
""
;
$self
->{LIBS} =
$self
->_fix_libs(
$self
->{LIBS});
foreach
my
$libs
( @{
$self
->{LIBS}} ){
$libs
=~ s/^\s*(.*\S)\s*$/$1/;
my
(
@libs
) =
$self
->extliblist(
$libs
);
if
(
$libs
[0] or
$libs
[1] or
$libs
[2]){
(
$self
->{EXTRALIBS},
$self
->{BSLOADLIBS},
$self
->{LDLOADLIBS},
$self
->{LD_RUN_PATH}) =
@libs
;
last
;
}
}
if
(
$self
->{OBJECT} ) {
$self
->{OBJECT} =
join
(
" "
, @{
$self
->{OBJECT}})
if
ref
$self
->{OBJECT};
$self
->{OBJECT} =~ s!\.o(bj)?\b!\$(OBJ_EXT)!g;
}
elsif
( (
$self
->{MAGICXS} ||
$self
->{XSMULTI}) && @{
$self
->{O_FILES}||[]} ) {
$self
->{OBJECT} =
join
(
" "
, @{
$self
->{O_FILES}});
$self
->{OBJECT} =~ s!\.o(bj)?\b!\$(OBJ_EXT)!g;
}
else
{
$self
->{OBJECT} =
""
;
$self
->{OBJECT} =
'$(BASEEXT)$(OBJ_EXT)'
if
@{
$self
->{C}||[]};
}
$self
->{OBJECT} =~ s/\n+/ \\\n\t/g;
$self
->{BOOTDEP} = (-f
"$self->{BASEEXT}_BS"
) ?
"$self->{BASEEXT}_BS"
:
""
;
$self
->{PERLMAINCC} ||=
'$(CC)'
;
$self
->{LDFROM} =
'$(OBJECT)'
unless
$self
->{LDFROM};
if
(!
$self
->{LINKTYPE}) {
$self
->{LINKTYPE} =
$self
->{SKIPHASH}{
'dynamic'
}
?
'static'
: (
$Config
{usedl} ?
'dynamic'
:
'static'
);
}
return
;
}
sub
_fix_libs {
my
(
$self
,
$libs
) =
@_
;
return
!
defined
$libs
? [
''
] :
!
ref
$libs
? [
$libs
] :
!
defined
$libs
->[0] ? [
''
] :
$libs
;
}
Hide Show 9 lines of Pod
sub
tools_other {
my
(
$self
) =
shift
;
my
@m
;
for
my
$tool
(
qw{ SHELL CHMOD CP MV NOOP NOECHO RM_F RM_RF TEST_F TOUCH
UMASK_NULL DEV_NULL MKPATH EQUALIZE_TIMESTAMP
FALSE TRUE
ECHO ECHO_N
UNINST VERBINST
MOD_INSTALL DOC_INSTALL UNINSTALL
WARN_IF_OLD_PACKLIST
MACROSTART MACROEND
USEMAKEFILE
PM_FILTER
FIXIN
CP_NONEMPTY
}
)
{
next
unless
defined
$self
->{
$tool
};
push
@m
,
"$tool = $self->{$tool}\n"
;
}
return
join
""
,
@m
;
}
Hide Show 52 lines of Pod
sub
init_platform {
return
''
;
}
Hide Show 8 lines of Pod
sub
init_MAKE {
my
$self
=
shift
;
$self
->{MAKE} ||=
$ENV
{MAKE} ||
$Config
{make};
}
Hide Show 13 lines of Pod
sub
manifypods {
my
$self
=
shift
;
my
$POD2MAN_macro
=
$self
->POD2MAN_macro();
my
$manifypods_target
=
$self
->manifypods_target();
return
<<END_OF_TARGET;
$POD2MAN_macro
$manifypods_target
END_OF_TARGET
}
Hide Show 14 lines of Pod
sub
POD2MAN_macro {
my
$self
=
shift
;
return
<<'END_OF_DEF';
POD2MAN_EXE = $(PERLRUN) "-MExtUtils::Command::MM" -e pod2man "--"
POD2MAN = $(POD2MAN_EXE)
END_OF_DEF
}
Hide Show 11 lines of Pod
sub
test_via_harness {
my
(
$self
,
$perl
,
$tests
) =
@_
;
return
qq{\t$perl "-MExtUtils::Command::MM" "-MTest::Harness" }
.
qq{"-e" "undef *Test::Harness::Switches; test_harness(\$(TEST_VERBOSE), '\$(INST_LIB)', '\$(INST_ARCHLIB)')" $tests\n}
;
}
Hide Show 13 lines of Pod
sub
test_via_script {
my
(
$self
,
$perl
,
$script
) =
@_
;
return
qq{\t$perl "-I\$(INST_LIB)" "-I\$(INST_ARCHLIB)" $script\n}
;
}
Hide Show 7 lines of Pod
sub
tool_autosplit {
my
(
$self
,
%attribs
) =
@_
;
my
$maxlen
=
$attribs
{MAXLEN} ?
'$$AutoSplit::Maxlen=$attribs{MAXLEN};'
:
''
;
my
$asplit
=
$self
->oneliner(
sprintf
<<'PERL_CODE', $maxlen);
use AutoSplit; %s autosplit($$ARGV[0], $$ARGV[1], 0, 1, 1)
PERL_CODE
return
sprintf
<<'MAKE_FRAG', $asplit;
# Usage: $(AUTOSPLITFILE) FileToSplit AutoDirToSplitInto
AUTOSPLITFILE = %s
MAKE_FRAG
}
Hide Show 19 lines of Pod
sub
arch_check {
my
$self
=
shift
;
my
(
$pconfig
,
$cconfig
) =
@_
;
return
1
if
$self
->{PERL_SRC};
my
(
$pvol
,
$pthinks
) =
$self
->splitpath(
$pconfig
);
my
(
$cvol
,
$cthinks
) =
$self
->splitpath(
$cconfig
);
$pthinks
=
$self
->canonpath(
$pthinks
);
$cthinks
=
$self
->canonpath(
$cthinks
);
my
$ret
= 1;
if
(
$pthinks
ne
$cthinks
) {
print
"Have $pthinks\n"
;
print
"Want $cthinks\n"
;
$ret
= 0;
my
$arch
= (
grep
length
,
$self
->splitdir(
$pthinks
))[-1];
print
<<END unless $self->{UNINSTALLED_PERL};
Your perl and your Config.pm seem to have different ideas about the
architecture they are running on.
Perl thinks: [$arch]
Config says: [$Config{archname}]
This may or may not cause problems. Please check your installation of perl
if you have problems building this extension.
END
}
return
$ret
;
}
Hide Show 14 lines of Pod
sub
catfile {
my
$self
=
shift
;
return
$self
->canonpath(
$self
->SUPER::catfile(
@_
));
}
Hide Show 14 lines of Pod
sub
find_tests {
my
(
$self
) =
shift
;
return
-d
't'
?
't/*.t'
:
''
;
}
Hide Show 11 lines of Pod
sub
find_tests_recursive {
my
$self
=
shift
;
return
$self
->find_tests_recursive_in(
't'
);
}
Hide Show 9 lines of Pod
sub
find_tests_recursive_in {
my
(
$self
,
$dir
) =
@_
;
return
''
unless
-d
$dir
;
my
$base_depth
=
grep
{
$_
ne
''
} File::Spec->splitdir( (File::Spec->splitpath(
$dir
))[1] );
my
%depths
;
my
$wanted
=
sub
{
return
unless
m!\.t$!;
my
(
$volume
,
$directories
,
$file
) =
File::Spec->splitpath(
$File::Find::name
);
my
$depth
=
grep
{
$_
ne
''
} File::Spec->splitdir(
$directories
);
$depth
-=
$base_depth
;
$depths
{
$depth
} = 1;
};
File::Find::find(
$wanted
,
$dir
);
return
join
' '
,
map
{
$dir
.
'/*'
x
$_
.
'.t'
}
sort
{
$a
<=>
$b
}
keys
%depths
;
}
Hide Show 9 lines of Pod
sub
extra_clean_files {
return
;
}
Hide Show 9 lines of Pod
sub
installvars {
return
qw(PRIVLIB SITELIB VENDORLIB
ARCHLIB SITEARCH VENDORARCH
BIN SITEBIN VENDORBIN
SCRIPT SITESCRIPT VENDORSCRIPT
MAN1DIR SITEMAN1DIR VENDORMAN1DIR
MAN3DIR SITEMAN3DIR VENDORMAN3DIR
)
;
}
Hide Show 13 lines of Pod
sub
libscan {
my
(
$self
,
$path
) =
@_
;
if
(
$path
=~ m<^README\.pod$>i) {
warn
"WARNING: Older versions of ExtUtils::MakeMaker may errantly install $path as part of this distribution. It is recommended to avoid using this path in CPAN modules.\n"
unless
$ENV
{PERL_CORE};
return
''
;
}
my
(
$dirs
,
$file
) = (
$self
->splitpath(
$path
))[1,2];
return
''
if
grep
/^(?:RCS|CVS|SCCS|\.svn|_darcs)$/,
$self
->splitdir(
$dirs
),
$file
;
return
$path
;
}
Hide Show 9 lines of Pod
sub
platform_constants {
return
''
;
}
Hide Show 7 lines of Pod
sub
post_constants {
""
;
}
Hide Show 7 lines of Pod
sub
post_initialize {
""
;
}
Hide Show 7 lines of Pod
sub
postamble {
""
;
}
Hide Show 14 lines of Pod
sub
_PREREQ_PRINT {
my
$self
=
shift
;
my
@what
= (
'PREREQ_PM'
);
push
@what
,
'MIN_PERL_VERSION'
if
$self
->{MIN_PERL_VERSION};
push
@what
,
'BUILD_REQUIRES'
if
$self
->{BUILD_REQUIRES};
print
Data::Dumper->Dump([@{
$self
}{
@what
}], \
@what
);
exit
0;
}
Hide Show 17 lines of Pod
sub
_PRINT_PREREQ {
my
$self
=
shift
;
my
$prereqs
=
$self
->{PREREQ_PM};
my
@prereq
=
map
{ [
$_
,
$prereqs
->{
$_
}] }
keys
%$prereqs
;
if
(
$self
->{MIN_PERL_VERSION} ) {
push
@prereq
, [
'perl'
=>
$self
->{MIN_PERL_VERSION}];
}
print
join
(
" "
,
map
{
"perl($_->[0])>=$_->[1] "
}
sort
{
$a
->[0] cmp
$b
->[0] }
@prereq
),
"\n"
;
exit
0;
}
Hide Show 14 lines of Pod
sub
_perl_header_files {
my
$self
=
shift
;
my
$header_dir
=
$self
->{PERL_SRC} ||
$ENV
{PERL_SRC} ||
$self
->catdir(
$Config
{archlibexp},
'CORE'
);
opendir
my
$dh
,
$header_dir
or
die
"Failed to opendir '$header_dir' to find header files: $!"
;
my
@perl_headers
=
sort
grep
{ /\.h\z/ }
readdir
(
$dh
);
closedir
$dh
;
return
@perl_headers
;
}
Hide Show 19 lines of Pod
sub
_perl_header_files_fragment {
my
(
$self
,
$separator
)=
@_
;
$separator
||=
""
;
return
join
(
"\\\n"
,
"PERL_HDRS = "
,
map
{
sprintf
(
" \$(PERL_INCDEP)%s%s "
,
$separator
,
$_
)
}
$self
->_perl_header_files()
) .
"\n\n"
.
"\$(OBJECT) : \$(PERL_HDRS)\n"
;
}
Hide Show 9 lines of Pod
1;