X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=95377790d62c723b557237d9248f4a450dea52bc;hb=cb68a7ccf88f9c50cd6c133ba15329167579e267;hp=33e38f12f9f51c4dd88cf3e0aae727971d931dea;hpb=3fe9c5d92b3872c146c93f99b77aa330bffe04ef;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/Makefile.PL b/Makefile.PL index 33e38f1..9537779 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,58 +1,142 @@ - -use inc::Module::Install; +use inc::Module::Install 0.91; 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 'Test::Exception'; +test_requires 'Test::More' => '0.94'; +test_requires 'DBI' => '1.56'; +test_requires 'DBD::SQLite' => '1.12'; +test_requires 'File::Copy'; +test_requires 'File::Temp' => '0.16'; +test_requires 'File::Path' => '2.07'; +test_requires 'IPC::Open3' => 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::Accessor::Grouped' => '0.09002'; requires 'Class::C3' => '0.18'; +requires 'Class::C3::Componentised' => '1.0005'; requires 'Carp::Clan' => 0; requires 'Class::Inspector' => 0; -requires 'DBIx::Class' => '0.07006'; +requires 'DBIx::Class' => '0.08114'; +requires 'Class::Unload' => 0; + +install_script 'script/dbicdump'; + +tests_recursive; -feature 'SQLite Support' => - -default => $ENV{DBIC_FEATURE_SQLITE} || 0, - 'DBI' => '1.56', - 'DBD::SQLite' => '1.12'; +# 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. -feature 'MySQL Support' => - -default => $ENV{DBIC_FEATURE_MYSQL} || 0, - 'DBI' => '1.56', - 'DBD::mysql' => '4.004'; +# Maintainer shouldn't set these, as they would affect +# the META.yml shipped to CPAN. -feature 'PostgreSQL Support' => - -default => $ENV{DBIC_FEATURE_PG} || 0, - 'DBI' => '1.56', - 'DBD::Pg' => '1.49'; # Soon to be 1.50 +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', + ], + }, +]; -feature 'DB2 Support' => - -default => $ENV{DBIC_FEATURE_DB2} || 0, - 'DBI' => '1.56', - 'DBD::DB2' => '1.0'; +for(my $i = 0; $i <= $#$_features - 1; $i += 2) { + my $name = $_features->[$i]; + my $attrs = $_features->[$i+1]; -feature 'Oracle Support (*experimental*)' => - -default => $ENV{DBIC_FEATURE_ORACLE} || 0, - 'DBI' => '1.56', - 'DBD::Oracle' => '0.19'; + 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') { +if ($Module::Install::AUTHOR) { system("pod2text lib/DBIx/Class/Schema/Loader.pm > README"); } +realclean_files 'README'; + +resources 'IRC' => 'irc://irc.perl.org/#dbix-class'; +resources 'license' => 'http://dev.perl.org/licenses/'; +resources 'repository' => 'http://dev.catalyst.perl.org/repos/bast/branches/DBIx-Class-Schema-Loader/current/'; +resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/dbix-class'; + auto_provides; auto_install; WriteAll;