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';
31 install_script 'script/dbicdump';
35 # This is my manual hack for better feature control
36 # If you want to change the default answer for a feature,
37 # set the appropriate environment variable, like
38 # DBIC_FEATURE_MYSQL. If you want the defaults to
39 # apply automatically without asking any questions,
40 # set DBIC_FEATURE_NOQUESTIONS. Hopefully this will
41 # save someone some pain when trying to automate
42 # the installation of this software.
44 # Maintainer shouldn't set these, as they would affect
45 # the META.yml shipped to CPAN.
49 label => 'SQLite Support',
50 def => $ENV{DBIC_FEATURE_SQLITE} || 0,
53 'DBD::SQLite' => '1.12',
57 label => 'MySQL Support',
58 def => $ENV{DBIC_FEATURE_MYSQL} || 0,
61 'DBD::mysql' => '4.004',
65 label => 'PostgreSQL Support',
66 def => $ENV{DBIC_FEATURE_PG} || 0,
69 'DBD::Pg' => '1.49', # Soon to be 1.50
73 label => 'DB2 Support',
74 def => $ENV{DBIC_FEATURE_DB2} || 0,
81 label => 'Oracle Support (experimental)',
82 def => $ENV{DBIC_FEATURE_ORACLE} || 0,
85 'DBD::Oracle' => '0.19',
89 label => 'Sybase Support (experimental)',
90 def => $ENV{DBIC_FEATURE_SYBASE} || 0,
93 'DBD::Sybase' => '1.09',
97 label => 'Microsoft SQL Server Support via DBD::Sybase (experimental)',
98 def => $ENV{DBIC_FEATURE_MSSQL} || 0,
101 'DBD::Sybase' => '1.09',
105 label => 'Microsoft SQL Server Support via DBD::ODBC (experimental)',
106 def => $ENV{DBIC_FEATURE_MSSQL} || 0,
109 'DBD::ODBC' => '1.22',
114 for(my $i = 0; $i <= $#$_features - 1; $i += 2) {
115 my $name = $_features->[$i];
116 my $attrs = $_features->[$i+1];
118 if($ENV{DBIC_FEATURE_NOQUESTIONS}) {
120 requires @{$attrs->{deps}};
124 feature $attrs->{label} =>
125 -default => $attrs->{def},
130 # Rebuild README for maintainers
131 if ($Module::Install::AUTHOR) {
132 system("pod2text lib/DBIx/Class/Schema/Loader.pm > README");
135 realclean_files 'README';
137 resources 'IRC' => 'irc://irc.perl.org/#dbix-class';
138 resources 'license' => 'http://dev.perl.org/licenses/';
139 resources 'repository' => 'http://dev.catalyst.perl.org/repos/bast/branches/DBIx-Class-Schema-Loader/current/';
140 resources 'MailingList' => 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/dbix-class';