-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathMakefile.PL
126 lines (102 loc) · 3.9 KB
/
Makefile.PL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
BEGIN { require 5.006; }
use strict;
use lib qw(lib); # use ourself if possible not the existing stuff.
# On Win32 things work better if Win32API::File is available.
# Activestate builds have it by default, but the core distro doesn't
# so we recommend it on Win32.
#
# * BUT *
#
# We can't recommend it on the release system as it then goes in the YAML.pl
# and then non-Win32 CPAN clients think they need it get upset when it fails
# to build on their system.
#
# Until CPAN and Module::Build and the other infrastructure has a better
# way to deal with this we assume UNIX when building a release.
#
# The pre-build stage will moan on Win32 anyway.
my $Recommend_Win32API_File = $ENV{USERNAME} ne 'demerphq'
&& ($^O eq 'MSWin32' || $^O eq 'cygwin');
use ExtUtils::MakeMaker;
WriteMakefile1(
LICENSE => 'perl',
#BUILD_REQUIRES => {
#},
NAME => 'ExtUtils::Install',
AUTHOR => 'demerphq <[email protected]>',
VERSION_FROM => 'lib/ExtUtils/Install.pm',
ABSTRACT => 'install files from here to there',
# This causes failure to locate ABSTRACT with DISTNAME below set to different name
# ABSTRACT_FROM => 'lib/ExtUtils/Install.pm',
DISTNAME => 'ExtUtils-Install',
PL_FILES => {}, # Avoid auto extracting 'Build.PL'
PREREQ_PM => {
# 'vars' => 0,
# 'AutoSplit' => 0,
# 'Exporter' => 0,
'Carp' => 0,
# 'Config' => 0,
'Cwd' => 0,
'File::Basename' => 0,
'File::Compare' => 0,
'File::Copy' => 0,
'File::Find' => 0,
'File::Path' => 0,
'File::Spec' => 0,
'File::Temp' => 0,
($^O eq 'VMS' ? ('VMS::Filespec' => 0) : ()),
($Recommend_Win32API_File ? ('Win32API::File' => 0) : ()),
'ExtUtils::MakeMaker' => 0,
'Test::More' => '0.47', # Tested with perl 5.6.2
},
MIN_PERL_VERSION => '5.006',
INSTALLDIRS => ( $] < 5.012 ? 'perl' : 'site' ),
#NO_META => 1,
dist => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
clean => { FILES => 'ExtUtils-Install-*' },
META_MERGE => {
resources => {
license => 'http://dev.perl.org/licenses/',
homepage => 'https://metacpan.org/release/ExtUtils-Install',
bugtracker => 'https://rt.cpan.org/NoAuth/Bugs.html?Dist=ExtUtils-Install',
repository => 'https://github.com/Perl-Toolchain-Gang/ExtUtils-Install',
},
},
);
{
package MY;
my($lib);
BEGIN {
$lib = File::Spec->canonpath('lib/');
}
# Make sure PERLRUN uses the MakeMaker about to be installed
# and not the currently installed one.
sub init_PERL {
my($self) = shift;
$self->SUPER::init_PERL;
$self->{ABSPERLRUN} .= qq{ "-I$lib"};
$self->{PERLRUN} .= qq{ "-I$lib"};
$self->{FULLPERLRUN} .= qq{ "-I$lib"};
}
}
sub WriteMakefile1 { #Written by Alexandr Ciornii, version 0.21. Added by eumm-upgrade.
my %params=@_;
my $eumm_version=$ExtUtils::MakeMaker::VERSION;
$eumm_version=eval $eumm_version;
die "EXTRA_META is deprecated" if exists $params{EXTRA_META};
die "License not specified" if not exists $params{LICENSE};
if ($params{BUILD_REQUIRES} and $eumm_version < 6.5503) {
#EUMM 6.5502 has problems with BUILD_REQUIRES
$params{PREREQ_PM}={ %{$params{PREREQ_PM} || {}} , %{$params{BUILD_REQUIRES}} };
delete $params{BUILD_REQUIRES};
}
delete $params{CONFIGURE_REQUIRES} if $eumm_version < 6.52;
delete $params{MIN_PERL_VERSION} if $eumm_version < 6.48;
delete $params{META_MERGE} if $eumm_version < 6.46;
delete $params{META_ADD} if $eumm_version < 6.46;
delete $params{LICENSE} if $eumm_version < 6.31;
delete $params{AUTHOR} if $] < 5.005;
delete $params{ABSTRACT_FROM} if $] < 5.005;
delete $params{BINARY_LOCATION} if $] < 5.005;
WriteMakefile(%params);
}