Merge branch 'master' into 0.08
[dbsrgits/DBIx-Class-Schema-Loader.git] / Makefile.PL
index 0c3ba57..1ed32e9 100644 (file)
@@ -1,5 +1,12 @@
 use inc::Module::Install 0.91;
 
+require Module::Install::ReadmeFromPod;
+
+use 5.008001;
+
+use FindBin;
+use lib "$FindBin::Bin/lib";
+
 name           'DBIx-Class-Schema-Loader';
 all_from       'lib/DBIx/Class/Schema/Loader.pm';
 
@@ -11,12 +18,12 @@ test_requires 'File::Copy';
 test_requires 'File::Temp'    => '0.16';
 test_requires 'File::Path'    => '2.07';
 test_requires 'IPC::Open3'    => 0;
-test_requires 'List::MoreUtils' => 0;
 
 requires 'File::Spec'                  => 0;
 requires 'Scalar::Util'                => 0;
 requires 'Data::Dump'                  => '1.06';
 requires 'Lingua::EN::Inflect::Number' => '1.1';
+requires 'Lingua::EN::Inflect::Phrase' => '0.02';
 requires 'Text::Balanced'              => 0;
 requires 'Digest::MD5'                 => '2.36';
 requires 'Class::Accessor::Grouped'    => '0.09002';
@@ -28,115 +35,28 @@ requires 'DBIx::Class'                 => '0.08114';
 requires 'Class::Unload'               => 0;
 requires 'File::Slurp'                 => '9999.13';
 requires 'List::MoreUtils'             => 0;
-requires 'namespace::autoclean'        => 0;
-requires 'Data::Dumper::Concise'       => '1.200';
+requires 'namespace::clean'            => 0;
 requires 'Scope::Guard'                => 0;
+requires 'List::MoreUtils'             => 0;
+requires 'Exporter'                    => '5.63';
+requires 'Try::Tiny'                   => 0;
 
-install_script 'script/dbicdump';
+if ($Module::Install::AUTHOR) {
+    warn "\n*** AUTHOR MODE: some optional dependencies converted to hard dependencies.\n\n";
 
-tests_recursive;
+    require DBIx::Class::Schema::Loader::Optional::Dependencies;
 
-# 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',
-        def   => $ENV{DBIC_FEATURE_ORACLE} || 0,
-        deps  => [
-            'DBI'         => '1.56',
-            'DBD::Oracle' => '0.19',
-        ],
-    },
-    SYBASE => {
-        label => 'Sybase Support',
-        def   => $ENV{DBIC_FEATURE_SYBASE} || 0,
-        deps  => [
-            'DBI'         => '1.56',
-            'DBD::Sybase' => '1.09',
-        ],
-    },
-    MSSQL => {
-        label => 'Microsoft SQL Server Support via DBD::Sybase',
-        def   => $ENV{DBIC_FEATURE_MSSQL} || 0,
-        deps  => [
-            'DBI'         => '1.56',
-            'DBD::Sybase' => '1.09',
-        ],
-    },
-    MSSQL_ODBC => {
-        label => 'Microsoft SQL Server Support via DBD::ODBC',
-        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}};
-    }
-}
+    test_requires map %$_, values %{ DBIx::Class::Schema::Loader::Optional::Dependencies->req_group_list };
 
-# Rebuild README for maintainers
-if ($Module::Install::AUTHOR) {
-    system("pod2text lib/DBIx/Class/Schema/Loader.pm > README");
+    DBIx::Class::Schema::Loader::Optional::Dependencies->_gen_pod;
 }
 
-realclean_files 'README';
+tests_recursive;
+
+install_script 'script/dbicdump';
+
+readme_from 'lib/DBIx/Class/Schema/Loader.pm';
+realclean_files qw[README MANIFEST lib/DBIx/Class/Schema/Loader/Optional/Dependencies.pod];
 
 resources 'IRC'         => 'irc://irc.perl.org/#dbix-class';
 resources 'license'     => 'http://dev.perl.org/licenses/';
@@ -146,3 +66,5 @@ resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/db
 auto_provides;
 auto_install;
 WriteAll;
+
+# vim:et sts=4 sw=4 tw=0: