X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=ba0f217d41992327a183a8ddc9ebb679f0854839;hb=refs%2Ftags%2F0.04999_08;hp=76c030c6bdf34adb09549780cfce30474ab79f9a;hpb=3385ac62745352cbb60586bb1c906151c353e60b;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/Makefile.PL b/Makefile.PL index 76c030c..ba0f217 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,14 +1,133 @@ -use ExtUtils::MakeMaker; - -WriteMakefile( - 'NAME' => 'DBIx::Class::Schema::Loader', - 'VERSION_FROM' => 'lib/DBIx/Class/Schema/Loader.pm', - 'PREREQ_PM' => { - Test::More => 0.32, - DBIx::Class => 0.05, - DBI => 1.30, - Lingua::EN::Inflect => 0, - Text::Balanced => 0, - UNIVERSAL::require => 0.10, - }, -); + +use inc::Module::Install 0.71; + +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; +test_requires 'IPC::Open3' => 0; +test_requires 'Test::Exception'; + +requires 'File::Spec' => 0; +requires 'Scalar::Util' => 0; +requires 'Data::Dump' => '1.06'; +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 'Class::C3::Componentised' => '1.0005'; +requires 'Carp::Clan' => 0; +requires 'Class::Inspector' => 0; +requires 'DBIx::Class' => '0.08109'; +requires 'Class::Unload' => 0; + +install_script 'script/dbicdump'; + +# 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', + ], + }, + SYBASE => { + label => 'Sybase Support (experimental)', + def => $ENV{DBIC_FEATURE_SYBASE} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::Sybase' => '1.09', + ], + }, + MSSQL => { + label => 'Microsoft SQL Server Support via DBD::Sybase (experimental)', + def => $ENV{DBIC_FEATURE_MSSQL} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::Sybase' => '1.09', + ], + }, + MSSQL_ODBC => { + label => 'Microsoft SQL Server Support via DBD::ODBC (experimental)', + def => $ENV{DBIC_FEATURE_MSSQL} || 0, + deps => [ + 'DBI' => '1.56', + 'DBD::ODBC' => '1.22', + ], + }, +]; + +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}}; + } + } + 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;