X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FResultSetManager.pm;h=46aa406bebb3009891cb8a275bd682684df78e2f;hb=4e8964d53864dc5ce61100fcf1418520a935a520;hp=2cb6239e5d9347ebf71acb9ea9635dfa9defbfaf;hpb=bc0c980086ba429cf33b1d471d1035601727231f;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/ResultSetManager.pm b/lib/DBIx/Class/ResultSetManager.pm index 2cb6239..46aa406 100644 --- a/lib/DBIx/Class/ResultSetManager.pm +++ b/lib/DBIx/Class/ResultSetManager.pm @@ -1,19 +1,20 @@ package DBIx::Class::ResultSetManager; use strict; +use warnings; use base 'DBIx::Class'; use Class::Inspector; -=head1 NAME +=head1 NAME - DBIx::Class::ResultSetManager - helpful methods for managing - resultset classes (EXPERIMENTAL) +DBIx::Class::ResultSetManager - helpful methods for managing resultset +classes (EXPERIMENTAL) =head1 SYNOPSIS # in a table class __PACKAGE__->load_components(qw/ResultSetManager Core/); # note order! __PACKAGE__->load_resultset_components(qw/AlwaysRS/); - + # will be removed from the table class and inserted into a # table-specific resultset class sub search_by_year_desc : ResultSet { @@ -21,7 +22,7 @@ use Class::Inspector; my $cond = shift; my $attrs = shift || {}; $attrs->{order_by} = 'year DESC'; - $self->next::method($cond, $attrs); + $self->search($cond, $attrs); } $rs = $schema->resultset('CD')->search_by_year_desc({ artist => 'Tool' }); @@ -44,16 +45,39 @@ __PACKAGE__->mk_classdata($_) __PACKAGE__->base_resultset_class('DBIx::Class::ResultSet'); __PACKAGE__->table_resultset_class_suffix('::_resultset'); +=head2 table + +Stacks on top of the normal L C method. Any +methods tagged with the C attribute will be moved into a +table-specific resultset class (by default called +C, but configurable via +C). The magic for this is done within +this C<< __PACKAGE__->table >> call. + +=cut + sub table { my ($self,@rest) = @_; my $ret = $self->next::method(@rest); if (@rest) { $self->_register_attributes; - $self->_register_resultset_class; + $self->_register_resultset_class; } return $ret; } +=head2 load_resultset_components + + # in a table class + __PACKAGE__->load_components(qw/ResultSetManager Core/); # note order! + __PACKAGE__->load_resultset_components(qw/AlwaysRS/); + +C loads components in addition to +C (or whatever you set as +C). + +=cut + sub load_resultset_components { my ($self,@comp) = @_; my $resultset_class = $self->_setup_resultset_class; @@ -64,7 +88,7 @@ sub _register_attributes { my $self = shift; my $cache = $self->_attr_cache; return if keys %$cache == 0; - + foreach my $meth (@{Class::Inspector->methods($self) || []}) { my $attrs = $cache->{$self->can($meth)}; next unless $attrs; @@ -95,7 +119,7 @@ sub _register_resultset_class { $self->result_source_instance->resultset_class($resultset_class); } else { $self->result_source_instance->resultset_class - ($self->base_resultset_class); + ($self->base_resultset_class); } }