X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=d66427441c279a7017485f15d74dfb8728af029a;hb=7507c8ce0703993b79b31bf90144e28ef97d4a9d;hp=51d31fd328d6b81a957ec0c78db136d5abdba5e7;hpb=8a6b44efef66c45bdf1336135b0c9c5e5face742;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/Makefile.PL b/Makefile.PL index 51d31fd..d664274 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,31 +1,104 @@ -# Note: this file was auto-generated by Module::Build::Compat version 0.03 - - unless (eval "use Module::Build::Compat 0.02; 1" ) { - print "This module requires Module::Build to install itself.\n"; - - require ExtUtils::MakeMaker; - my $yn = ExtUtils::MakeMaker::prompt - (' Install Module::Build now from CPAN?', 'y'); - - unless ($yn =~ /^y/i) { - die " *** Cannot install without Module::Build. Exiting ...\n"; - } - - require Cwd; - require File::Spec; - require CPAN; - - # Save this 'cause CPAN will chdir all over the place. - my $cwd = Cwd::cwd(); - my $makefile = File::Spec->rel2abs($0); - - CPAN::Shell->install('Module::Build::Compat') - or die " *** Cannot install without Module::Build. Exiting ...\n"; - - chdir $cwd or die "Cannot chdir() back to $cwd: $!"; + +use inc::Module::Install 0.65; + +name 'DBIx-Class-Schema-Loader'; +all_from 'lib/DBIx/Class/Schema/Loader.pm'; + +test_requires 'Test::More' => '0.47'; +test_requires 'DBI' => '1.56'; +test_requires 'DBD::SQLite' => '1.12'; +test_requires 'File::Path' => 0; + +requires 'File::Spec' => 0; +requires 'Scalar::Util' => 0; +requires 'Data::Dump' => '1.06'; +requires 'UNIVERSAL::require' => '0.11'; +requires 'Lingua::EN::Inflect::Number' => '1.1'; +requires 'Text::Balanced' => 0; +requires 'Digest::MD5' => '2.36'; +requires 'Class::Accessor::Fast' => '0.30'; +requires 'Class::Data::Accessor' => '0.03'; +requires 'Class::C3' => '0.18'; +requires 'Carp::Clan' => 0; +requires 'Class::Inspector' => 0; +requires 'DBIx::Class' => '0.07006'; + +# This is my manual hack for better feature control +# If you want to change the default answer for a feature, +# set the appropriate environment variable, like +# DBIC_FEATURE_MYSQL. If you want the defaults to +# apply automatically without asking any questions, +# set DBIC_FEATURE_NOQUESTIONS. Hopefully this will +# save someone some pain when trying to automate +# the installation of this software. + +# Maintainer shouldn't set these, as they would affect +# the META.yml shipped to CPAN. + +my $_features = [ + SQLITE => { + label => 'SQLite Support', + def => $ENV{DBIC_FEATURE_SQLITE} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::SQLite' => '1.12', + ], + }, + MYSQL => { + label => 'MySQL Support', + def => $ENV{DBIC_FEATURE_MYSQL} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::mysql' => '4.004', + ], + }, + PG => { + label => 'PostgreSQL Support', + def => $ENV{DBIC_FEATURE_PG} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::Pg' => '1.49', # Soon to be 1.50 + ], + }, + DB2 => { + label => 'DB2 Support', + def => $ENV{DBIC_FEATURE_DB2} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::DB2' => '1.0', + ], + }, + ORACLE => { + label => 'Oracle Support (experimental)', + def => $ENV{DBIC_FEATURE_ORACLE} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::Oracle' => '0.19', + ], + }, +]; + +for(my $i = 0; $i <= $#$_features - 1; $i += 2) { + my $name = $_features->[$i]; + my $attrs = $_features->[$i+1]; + + if($ENV{DBIC_FEATURE_NOQUESTIONS}) { + if($attrs->{def}) { + requires @{$attrs->{deps}}; + } } - eval "use Module::Build::Compat 0.02; 1" or die $@; - use lib '_build/lib'; - Module::Build::Compat->run_build_pl(args => \@ARGV); - require Module::Build; - Module::Build::Compat->write_makefile(build_class => 'Module::Build'); + else { + feature $attrs->{label} => + -default => $attrs->{def}, + @{$attrs->{deps}}; + } +} + +# Rebuild README for maintainers +if(-e 'MANIFEST.SKIP') { + system("pod2text lib/DBIx/Class/Schema/Loader.pm > README"); +} + +auto_provides; +auto_install; +WriteAll;