Overrode part of ContextualFetch in ImaDBI to shut up the useless warnings
[dbsrgits/DBIx-Class-Historic.git] / lib / DBIx / Class.pm
index d473c2d..9cb1b36 100644 (file)
@@ -3,12 +3,22 @@ package DBIx::Class;
 use strict;
 use warnings;
 
-use base qw/DBIx::Class::CDBICompat DBIx::Class::Core/;
-
 use vars qw($VERSION);
+use base;
 
 $VERSION = '0.01';
 
+sub load_components {
+  my $class = shift;
+  my @comp = map { "DBIx::Class::$_" } grep { $_ !~ /^#/ } @_;
+  foreach my $comp (@comp) {
+    eval "use $comp";
+    die $@ if $@;
+  }
+  no strict 'refs';
+  unshift(@{"${class}::ISA"}, @comp);
+}
+
 1;
 
 =head1 NAME 
@@ -24,6 +34,35 @@ and meant to support compability with it, while restructuring the
 insides, and making it possible to support some new features like 
 self-joins, distinct, group bys and more.
 
+=head1 QUICKSTART
+
+If you're using Class::DBI, replacing
+
+use base qw/Class::DBI/;
+
+with
+
+use base qw/DBIx::Class/;
+__PACKAGE__->load_components(qw/CDBICompat Core/);
+
+will probably get you started.
+
+If you're using AUTO_INCREMENT for your primary columns, you'll also want
+yo load the approriate PK::Auto subclass - e.g.
+
+__PACKAGE__->load_components(qw/CDBICompat PK::Auto::SQLite Core/);
+
+(with is what ::Test::SQLite does to present the Class::DBI::Test::SQLite
+interface)
+
+If you fancy playing around with DBIx::Class from scratch, then read the docs
+for ::Table and ::Relationship,
+
+use base qw/DBIx::Class/;
+__PACKAGE__->load_components(qw/Core/);
+
+and have a look at t/lib/DBICTest.pm for a brief example.
+
 =head1 AUTHORS
 
 Matt S. Trout <perl-stuff@trout.me.uk>