X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass.pm;h=9f55fc694cfda2eafbb883f8e432ec365b28e8c2;hb=a28009914a3e447af53737d503b1953160d146c9;hp=dc7d7958a7e5f3423a7473d819bac239caaf17cd;hpb=0de399915adc44bf14db450176ecdc76b0f89697;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class.pm b/lib/DBIx/Class.pm index dc7d795..9f55fc6 100644 --- a/lib/DBIx/Class.pm +++ b/lib/DBIx/Class.pm @@ -4,30 +4,35 @@ use strict; use warnings; use vars qw($VERSION); -use base qw/DBIx::Class::Componentised Class::Data::Accessor/; +use base qw/DBIx::Class::Componentised Class::Accessor::Grouped/; + +sub mk_classdata { + my $self = shift; + $self->mk_group_accessors('inherited', $_[0]); + $self->set_inherited(@_) if @_ > 1; +} -sub mk_classdata { shift->mk_classaccessor(@_); } sub component_base_class { 'DBIx::Class' } # Always remember to do all digits for the version even if they're 0 # i.e. first release of 0.XX *must* be 0.XX000. This avoids fBSD ports # brain damage and presumably various other packaging systems too -$VERSION = '0.06999_01'; +$VERSION = '0.08001'; sub MODIFY_CODE_ATTRIBUTES { - my ($class,$code,@attrs) = @_; - $class->mk_classdata('__attr_cache' => {}) - unless $class->can('__attr_cache'); - $class->__attr_cache->{$code} = [@attrs]; - return (); + my ($class,$code,@attrs) = @_; + $class->mk_classdata('__attr_cache' => {}) + unless $class->can('__attr_cache'); + $class->__attr_cache->{$code} = [@attrs]; + return (); } sub _attr_cache { - my $self = shift; - my $cache = $self->can('__attr_cache') ? $self->__attr_cache : {}; - my $rest = eval { $self->next::method }; - return $@ ? $cache : { %$cache, %$rest }; + my $self = shift; + my $cache = $self->can('__attr_cache') ? $self->__attr_cache : {}; + my $rest = eval { $self->next::method }; + return $@ ? $cache : { %$cache, %$rest }; } 1; @@ -87,7 +92,7 @@ Then you can use these classes in your application's code: # Create a result set to search for artists. # This does not query the DB. my $johns_rs = $schema->resultset('Artist')->search( - # Build your WHERE using an L structure: + # Build your WHERE using an SQL::Abstract structure: { name => { like => 'John%' } } ); @@ -180,45 +185,61 @@ andyg: Andy Grundman ank: Andres Kievsky -blblack: Brandon Black +ash: Ash Berlin -LTJake: Brian Cassidy +blblack: Brandon L. Black + +bluefeet: Aran Deltac + +captainL: Luke Saunders + +castaway: Jess Robinson claco: Christopher H. Laco clkao: CL Kao -typester: Daisuke Murase +da5id: David Jack Olrik dkubb: Dan Kubb -Numa: Dan Sully +dnm: Justin Wheeler + +draven: Marcus Ramberg dwc: Daniel Westermann-Clark -ningu: David Kamholz +dyfrgi: Michael Leuchtenburg + +gphat: Cory G Watson jesper: Jesper Krogh -castaway: Jess Robinson +jguenther: Justin Guenther -quicksilver: Jules Bean +jshirley: J. Shirley -jguenther: Justin Guenther +konobi: Scott McWhirter -captainL: Luke Saunders +LTJake: Brian Cassidy -draven: Marcus Ramberg +ned: Neil de Carteret nigel: Nigel Metheringham +ningu: David Kamholz + +Numa: Dan Sully + paulm: Paul Makepeace +penguin: K J Cheetham + phaylon: Robert Sedlacek -sc_: Just Another Perl Hacker +quicksilver: Jules Bean -konobi: Scott McWhirter +sc_: Just Another Perl Hacker scotty: Scotty Allen @@ -226,13 +247,18 @@ sszabo: Stephan Szabo Todd Lipcon +typester: Daisuke Murase + +victori: Victor Igumnov + wdh: Will Hawes -gphat: Cory G Watson +willert: Sebastian Willert + +zamolxes: Bogdan Lucaciu =head1 LICENSE You may distribute this code under the same terms as Perl itself. =cut -