X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=Makefile.PL;h=b481d580b80ce13bfd52ee429f23a6d845a4be9a;hb=a1bb9cab5dc2ba16af149f126cb58a8a0d08fbed;hp=957ee9648a74eae7f04ae855a9aca6ead2e457e6;hpb=7b88eb9cbb0c1342a6480820450644708aed019c;p=perl%2Fmodules%2Fre-engine-Hooks.git diff --git a/Makefile.PL b/Makefile.PL index 957ee96..b481d58 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -16,6 +16,16 @@ my %PREREQ_PM = ( 'DynaLoader' => 0, ); +my %BUILD_REQUIRES = ( + 'ExtUtils::Depends' => 0, + 'ExtUtils::MakeMaker' => 0, + 'File::Spec' => 0, + 'POSIX' => 0, + 'Test::More' => 0, + 'blib' => 0, + %PREREQ_PM, +); + my %META = ( configure_requires => { 'ExtUtils::Depends' => 0, @@ -23,13 +33,7 @@ my %META = ( 'File::Spec' => 0, }, build_requires => { - 'ExtUtils::Depends' => 0, - 'ExtUtils::MakeMaker' => 0, - 'File::Spec' => 0, - 'POSIX' => 0, - 'Test::More' => 0, - 'blib' => 0, - %PREREQ_PM, + %BUILD_REQUIRES, }, dynamic_config => 1, resources => { @@ -55,7 +59,7 @@ sub versioned_file { require File::Spec; my $versioned_file = File::Spec->catfile('src', $version, $file); - return -e $versioned_file ? $versioned_file : undef; + return -e $versioned_file ? [ $file => $versioned_file ] : undef; } unless (defined versioned_file('regcomp.c')) { @@ -74,8 +78,8 @@ my @DEFINES = qw<-DPERL_EXT_RE_BUILD -DPERL_EXT>; use ExtUtils::Depends; my $ed = ExtUtils::Depends->new($name); -$ed->add_c('re_comp.c'); -$ed->add_c('re_exec.c'); +$ed->add_c('regcomp.c'); +$ed->add_c('regexec.c'); $ed->add_xs('Hooks.xs'); $ed->add_pm($file => do { local $_ = $file; s/^lib/\$(INST_LIB)/; $_ }); $ed->install('re_engine_hooks.h'); @@ -86,7 +90,7 @@ $ed_vars{clean}->{FILES} .= ' ' . join ' ', ( "$dist-*", 'Files.pm', qw<*.gcov *.gcda *.gcno cover_db Debian_CPANTS.txt>, - qw, + qw, ); WriteMakefile( @@ -96,6 +100,7 @@ WriteMakefile( VERSION_FROM => $file, ABSTRACT_FROM => $file, PL_FILES => {}, + BUILD_REQUIRES => \%BUILD_REQUIRES, PREREQ_PM => \%PREREQ_PM, MIN_PERL_VERSION => '5.010001', META_MERGE => \%META, @@ -103,7 +108,7 @@ WriteMakefile( PREOP => "pod2text $file > \$(DISTVNAME)/README", COMPRESS => 'gzip -9f', SUFFIX => 'gz' }, - XSPROTOARG => '-noprototypes', + XSPROTOARG => '-noprototypes', @DEFINES, FUNCLIST => [ qw< boot_re__engine__Hooks @@ -127,35 +132,39 @@ WriteMakefile( package MY; sub postamble { - my $regcomp_c = main::versioned_file('regcomp.c'); - my $regexec_c = main::versioned_file('regexec.c'); - my $dquote_static_c = main::versioned_file('dquote_static.c'); - - my $dquote_static_dep = defined $dquote_static_c ? 'dquote_static.c' : ''; - - my $rules = <[0]; + } -re_comp\$(OBJ_EXT) : re_comp.c $dquote_static_dep + my $rules; -re_exec.c : $regexec_c - - \$(RM_F) re_exec.c - \$(CP) $regexec_c re_exec.c + for my $file_c (@all_c) { + my ($target_file, $versioned_file) = @$file_c; + $rules .= <<"RULE"; +$target_file : $versioned_file + - \$(RM_F) $target_file + \$(CP) $versioned_file $target_file -re_exec\$(OBJ_EXT) : re_exec.c +RULE + } -EOF + $rules .= <<"RULE"; +regcomp\$(OBJ_EXT) : @regcomp_c_deps - if (defined $dquote_static_c) { - $rules .= <