X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass.pm;h=603270044628a4d1c30ada6914f5fe93502d8a62;hb=f80f8e2fe165ff27e815c1fc31b8fcef8aac1959;hp=323c410f8c56835f26ba2cdc41de65e9a3ad3cb5;hpb=2ca930b407c2994df451dddedc23172c0530321f;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class.pm b/lib/DBIx/Class.pm index 323c410..6032700 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.06000'; +$VERSION = '0.07999_03'; 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,43 +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 + +konobi: Scott McWhirter -jguenther: Justin Guenther +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 @@ -224,11 +247,18 @@ sszabo: Stephan Szabo Todd Lipcon +typester: Daisuke Murase + +victori: Victor Igumnov + wdh: Will Hawes +willert: Sebastian Willert + +zamolxes: Bogdan Lucaciu + =head1 LICENSE You may distribute this code under the same terms as Perl itself. =cut -