X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=4db29cc733b17bbdc30d554ed0489f93b442521d;hb=6eca76d53657b45df6723f471b50c2aa18f7ee19;hp=d21951b455c7dc5540cbdebad3ca643aa18fca46;hpb=5548ee89747b4d4c527980ce3b7ad7991b3e00de;p=dbsrgits%2FDBIx-Class.git diff --git a/Makefile.PL b/Makefile.PL index d21951b..4db29cc 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -3,115 +3,158 @@ use strict; use warnings; use POSIX (); -use 5.006001; # delete this line if you want to send patches for earlier. +use 5.008001; + +# ****** DO NOT ADD OPTIONAL DEPENDENCIES. EVER. --mst ****** name 'DBIx-Class'; -perl_version '5.006001'; +perl_version '5.008001'; all_from 'lib/DBIx/Class.pm'; -test_requires 'Test::Builder' => 0.33; -test_requires 'Test::Deep' => 0; -test_requires 'Test::Exception' => 0; -test_requires 'Test::More' => 0.82; -test_requires 'Test::Warn' => 0.11; +test_requires 'Test::Builder' => '0.33'; +test_requires 'Test::Deep' => '0'; +test_requires 'Test::Exception' => '0'; +test_requires 'Test::More' => '0.92'; +test_requires 'Test::Warn' => '0.21'; -# Core -requires 'List::Util' => 0; -requires 'Scalar::Util' => 0; -requires 'Storable' => 0; +test_requires 'File::Temp' => '0.22'; -# Perl 5.8.0 doesn't have utf8::is_utf8() -requires 'Encode' => 0 if ($] <= 5.008000); + +# Core +requires 'List::Util' => '0'; +requires 'Scalar::Util' => '0'; +requires 'Storable' => '0'; # Dependencies (keep in alphabetical order) -requires 'Carp::Clan' => 6.0; -requires 'Class::Accessor::Grouped' => 0.08003; -requires 'Class::C3::Componentised' => 1.0005; -requires 'Class::Inspector' => 1.24; -requires 'Data::Page' => 2.00; -requires 'DBD::SQLite' => 1.25; -requires 'DBI' => 1.605; -requires 'JSON::Any' => 1.18; -requires 'MRO::Compat' => 0.09; -requires 'Module::Find' => 0.06; -requires 'Path::Class' => 0.16; -requires 'Scope::Guard' => 0.03; -requires 'SQL::Abstract' => 1.56; -requires 'SQL::Abstract::Limit' => 0.13; -requires 'Sub::Name' => 0.04; - -recommends 'SQL::Translator' => 0.09004; +requires 'Carp::Clan' => '6.0'; +requires 'Class::Accessor::Grouped' => '0.09002'; +requires 'Class::C3::Componentised' => '1.0005'; +requires 'Class::Inspector' => '1.24'; +requires 'Data::Page' => '2.00'; +requires 'DBD::SQLite' => '1.25'; +requires 'DBI' => '1.609'; +requires 'JSON::Any' => '1.18'; +requires 'MRO::Compat' => '0.09'; +requires 'Module::Find' => '0.06'; +requires 'Path::Class' => '0.16'; +requires 'Scope::Guard' => '0.03'; +requires 'SQL::Abstract' => '1.60'; +requires 'SQL::Abstract::Limit' => '0.13'; +requires 'Sub::Name' => '0.04'; +requires 'Data::Dumper::Concise' => '1.000'; + +my %replication_requires = ( + 'Moose', => '0.90', + 'MooseX::Types', => '0.21', + 'namespace::clean' => '0.11', + 'Hash::Merge', => '0.11', +); -install_script (qw| - script/dbicadmin -|); +#************************************************************************# +# Make *ABSOLUTELY SURE* that nothing on this list is a real require, # +# since every module listed in %force_requires_if_author is deleted # +# from the final META.yml (thus will never make it as a CPAN dependency) # +#************************************************************************# +my %force_requires_if_author = ( + %replication_requires, -tests_recursive (qw| - t -|); + # when changing also adjust $DBIx::Class::Storage::DBI::minimum_sqlt_version + 'SQL::Translator' => '0.11002', -resources 'IRC' => 'irc://irc.perl.org/#dbix-class'; -resources 'license' => 'http://dev.perl.org/licenses/'; -resources 'repository' => 'http://dev.catalyst.perl.org/svnweb/bast/browse/DBIx-Class/'; -resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/dbix-class'; +# 'Module::Install::Pod::Inherit' => '0.01', + # when changing also adjust version in t/02pod.t + 'Test::Pod' => '1.26', -# re-build README and require extra modules for testing if we're in a checkout + # when changing also adjust version in t/06notabs.t +# 'Test::NoTabs' => '0.9', -my %force_requires_if_author = ( -# 'Module::Install::Pod::Inherit' => 0.01, - 'Test::Pod::Coverage' => 1.04, - 'SQL::Translator' => 0.09007, + # when changing also adjust version in t/07eol.t +# 'Test::EOL' => '0.6', + + # when changing also adjust version in t/03podcoverage.t + 'Test::Pod::Coverage' => '1.08', + 'Pod::Coverage' => '0.20', # CDBI-compat related - 'DBIx::ContextualFetch' => 0, - 'Class::DBI::Plugin::DeepAbstractSearch' => 0, - 'Class::Trigger' => 0, - 'Time::Piece::MySQL' => 0, - 'Clone' => 0, - 'Date::Simple' => 3.03, + 'DBIx::ContextualFetch' => '0', + 'Class::DBI::Plugin::DeepAbstractSearch' => '0', + 'Class::Trigger' => '0', + 'Time::Piece::MySQL' => '0', + 'Clone' => '0', + 'Date::Simple' => '3.03', # t/52cycle.t - 'Test::Memory::Cycle' => 0, - 'Devel::Cycle' => 1.10, + 'Test::Memory::Cycle' => '0', + 'Devel::Cycle' => '1.10', # t/36datetime.t # t/60core.t - 'DateTime::Format::SQLite' => 0, + 'DateTime::Format::SQLite' => '0', # t/96_is_deteministic_value.t - 'DateTime::Format::Strptime'=> 0, - - # t/93storage_replication.t - 'Moose', => 0.87, - 'MooseX::AttributeHelpers' => 0.21, - 'MooseX::Types', => 0.16, - 'namespace::clean' => 0.11, - 'Hash::Merge', => 0.11, + 'DateTime::Format::Strptime'=> '0', # database-dependent reqs # $ENV{DBICTEST_PG_DSN} ? ( - 'Sys::SigAction' => 0, - 'DBD::Pg' => 2.009002, - 'DateTime::Format::Pg' => 0, + 'Sys::SigAction' => '0', + 'DBD::Pg' => '2.009002', + 'DateTime::Format::Pg' => '0', ) : () , $ENV{DBICTEST_MYSQL_DSN} ? ( - 'DateTime::Format::MySQL' => 0, + 'DateTime::Format::MySQL' => '0', + ) : () + , + + $ENV{DBICTEST_ORA_DSN} + ? ( + 'DateTime::Format::Oracle' => '0', ) : () , - $ENV{DBICTEST_ORACLE_DSN} + $ENV{DBICTEST_SYBASE_DSN} ? ( - 'DateTime::Format::Oracle' => 0, + 'DateTime::Format::Sybase' => 0, ) : () , ); +#************************************************************************# +# Make ABSOLUTELY SURE that nothing on the list above is a real require, # +# since every module listed in %force_requires_if_author is deleted # +# from the final META.yml (thus will never make it as a CPAN dependency) # +#************************************************************************# + + +install_script (qw| + script/dbicadmin +|); + +tests_recursive (qw| + t +|); + +resources 'IRC' => 'irc://irc.perl.org/#dbix-class'; +resources 'license' => 'http://dev.perl.org/licenses/'; +resources 'repository' => 'http://dev.catalyst.perl.org/repos/bast/DBIx-Class/'; +resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/dbix-class'; + +# Deprecated/internal modules need no exposure +no_index directory => $_ for (qw| + lib/DBIx/Class/SQLAHacks + lib/DBIx/Class/PK/Auto +|); +no_index package => $_ for (qw/ + DBIx::Class::Storage::DBI::AmbiguousGlob + DBIx::Class::SQLAHacks DBIx::Class::Storage::DBIHacks +/); + +# re-build README and require extra modules for testing if we're in a checkout if ($Module::Install::AUTHOR) { warn <<'EOW'; @@ -137,8 +180,8 @@ EOW unlink 'MANIFEST'; } -# eval { require Module::Install::Pod::Inherit }; -# PodInherit() if !$@; +# require Module::Install::Pod::Inherit; +# PodInherit(); } auto_install(); @@ -148,7 +191,7 @@ WriteAll(); # Re-write META.yml to _exclude_ all forced requires (we do not want to ship this) if ($Module::Install::AUTHOR) { - Meta->{values}{build_requires} = [ grep + Meta->{values}{build_requires} = [ grep { not exists $force_requires_if_author{$_->[0]} } ( @{Meta->{values}{build_requires}} ) ];