1 use inc::Module::Install 0.91;
3 name 'DBIx-Class-Schema-Loader';
4 all_from 'lib/DBIx/Class/Schema/Loader.pm';
6 test_requires 'Test::Exception';
7 test_requires 'Test::More' => '0.94';
8 test_requires 'DBI' => '1.56';
9 test_requires 'DBD::SQLite' => '1.12';
10 test_requires 'File::Copy';
11 test_requires 'File::Temp' => '0.16';
12 test_requires 'File::Path' => '2.07';
13 test_requires 'IPC::Open3' => 0;
14 test_requires 'List::MoreUtils' => 0;
16 requires 'File::Spec' => 0;
17 requires 'Scalar::Util' => 0;
18 requires 'Data::Dump' => '1.06';
19 requires 'Lingua::EN::Inflect::Number' => '1.1';
20 requires 'Text::Balanced' => 0;
21 requires 'Digest::MD5' => '2.36';
22 requires 'Class::Accessor::Grouped' => '0.09002';
23 requires 'Class::C3' => '0.18';
24 requires 'Class::C3::Componentised' => '1.0005';
25 requires 'Carp::Clan' => 0;
26 requires 'Class::Inspector' => 0;
27 requires 'DBIx::Class' => '0.08114';
28 requires 'Class::Unload' => 0;
29 requires 'File::Slurp' => '9999.13';
30 requires 'List::MoreUtils' => 0;
31 requires 'namespace::autoclean' => 0;
33 install_script 'script/dbicdump';
37 # This is my manual hack for better feature control
38 # If you want to change the default answer for a feature,
39 # set the appropriate environment variable, like
40 # DBIC_FEATURE_MYSQL. If you want the defaults to
41 # apply automatically without asking any questions,
42 # set DBIC_FEATURE_NOQUESTIONS. Hopefully this will
43 # save someone some pain when trying to automate
44 # the installation of this software.
46 # Maintainer shouldn't set these, as they would affect
47 # the META.yml shipped to CPAN.
51 label => 'SQLite Support',
52 def => $ENV{DBIC_FEATURE_SQLITE} || 0,
55 'DBD::SQLite' => '1.12',
59 label => 'MySQL Support',
60 def => $ENV{DBIC_FEATURE_MYSQL} || 0,
63 'DBD::mysql' => '4.004',
67 label => 'PostgreSQL Support',
68 def => $ENV{DBIC_FEATURE_PG} || 0,
71 'DBD::Pg' => '1.49', # Soon to be 1.50
75 label => 'DB2 Support',
76 def => $ENV{DBIC_FEATURE_DB2} || 0,
83 label => 'Oracle Support (experimental)',
84 def => $ENV{DBIC_FEATURE_ORACLE} || 0,
87 'DBD::Oracle' => '0.19',
91 label => 'Sybase Support (experimental)',
92 def => $ENV{DBIC_FEATURE_SYBASE} || 0,
95 'DBD::Sybase' => '1.09',
99 label => 'Microsoft SQL Server Support via DBD::Sybase',
100 def => $ENV{DBIC_FEATURE_MSSQL} || 0,
103 'DBD::Sybase' => '1.09',
107 label => 'Microsoft SQL Server Support via DBD::ODBC',
108 def => $ENV{DBIC_FEATURE_MSSQL} || 0,
111 'DBD::ODBC' => '1.22',
116 for(my $i = 0; $i <= $#$_features - 1; $i += 2) {
117 my $name = $_features->[$i];
118 my $attrs = $_features->[$i+1];
120 if($ENV{DBIC_FEATURE_NOQUESTIONS}) {
122 requires @{$attrs->{deps}};
126 feature $attrs->{label} =>
127 -default => $attrs->{def},
132 # Rebuild README for maintainers
133 if ($Module::Install::AUTHOR) {
134 system("pod2text lib/DBIx/Class/Schema/Loader.pm > README");
137 realclean_files 'README';
139 resources 'IRC' => 'irc://irc.perl.org/#dbix-class';
140 resources 'license' => 'http://dev.perl.org/licenses/';
141 resources 'repository' => 'git://git.shadowcat.co.uk/dbsrgits/DBIx-Class-Schema-Loader.git';
142 resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/dbix-class';