# $Id$ ## no critic (ProhibitAmbiguousNames) package Handel::Iterator::DBIC; use strict; use warnings; use overload '0+' => \&count, 'bool' => \&count, '==' => \&count, fallback => 1; BEGIN { use base qw/Handel::Iterator/; use Handel::L10N qw/translate/; use Scalar::Util qw/blessed/; }; sub new { my $class = shift; no strict 'refs'; my $resultset = $_[0]->{'data'}; throw Handel::Exception::Argument( -details => translate('ITERATOR_DATA_NOT_RESULTSET') ) unless blessed($resultset) && $resultset->isa('DBIx::Class::ResultSet'); ## no critic return $class->SUPER::new(@_); }; sub all { my $self = shift; return map {$self->create_result($_)} $self->data->all; }; sub count { return shift->data->count; }; sub first { my $self = shift; my $result = $self->data->slice(0, 0)->first; return $result ? $self->create_result($result) : undef; }; sub last { my $self = shift; my $last = $self->count - 1; my $result = $self->data->slice($last, $last)->first; return $result ? $self->create_result($result) : undef; }; sub next { my $self = shift; my $result = $self->data->next; return $result ? $self->create_result($result) : undef; }; sub reset { return shift->data->reset; }; 1; __END__ =head1 NAME Handel::Iterator::DBIC - Iterator class used for collection looping DBIC resultsets =head1 SYNOPSIS my $resultset = $schema->resultset('Carts')->search; my $iterator = Handel::Iterator::DBIC->new({ data => $resultset, result_class => 'MyResult', storage => $storage }); while (my $result = $iterator->next) { print $result->method; }; =head1 DESCRIPTION Handel::Iterator::DBIC is a used to iterate through results stored in a resultset returned from DBIx::Class. =head1 CONSTRUCTOR =head2 new =over =item Arguments: \%options =back Creates a new iterator object. The following options are available: my $resultset = $schema->resultset('Carts')->search; my $iterator = Handel::Iterator::DBIC->new({ data => $resultset, result_class => 'MyResult', storage => $storage }); my $result = $iterator->first; print ref $result; # MyResult =over =item data The data to be iterated through. This should be a DBIx::Class::ResultSet. =item result_class The name of the class that each result should be inflated into. =item storage The storage object that was used to create the results. =back =head1 METHODS =head2 all Returns all results from current iterator. foreach my $result ($iterator->all) { print $result->method; }; =head2 count Returns the number of results in the current iterator. my $count = $iterator->count; =head2 create_result =over =item Arguments: $result [, $storage] =back Returns a new result class object based on the specified result and storage objects. If no storage object is specified, the storage object passed to C will be used instead. This method is used by methods like C and C to to create storage result objects. There is probably no good reason to use this method directly. =head2 first Returns the first result or undef if there are no results. my $first = $iterator->first; =head2 last Returns the last result or undef if there are no results. my $last = $iterator->last; =head2 next Returns the next result or undef if there are no results. while (my $result = $iterator->next) { print $result->method; }; =head2 reset Resets the current result position back to the first result. while (my $result = $iterator->next) { print $result->method; }; $iterator->reset; while (my $result = $iterator->next) { print $result->method; }; =head1 SEE ALSO L, L =head1 AUTHOR Christopher H. Laco CPAN ID: CLACO claco@chrislaco.com http://today.icantfocus.com/blog/