NAME
Data::ResultSet - Container for aggregating and examining multiple results
SYNOPSIS
# Subclass the module
package MyApp::ResultSet;
use base qw( Data::ResultSet );
# Generate methods to wrap 'is_success' and 'is_error'
__PACKAGE__->make_wrappers( qw( is_success is_error ) );
# And elsewhere...
package MyApp;
use MyApp::ResultSet;
sub something
{
# Create a resultset object
my $result = MyApp::ResultSet->new();
foreach my $thing ( @_ ) {
# Add results of calling do_something() to the result
# set
$result->add(
$thing->do_something();
);
}
# Return the results
return $result;
}
# And, check your results
my $r = something( @some_data );
if( $r->all_success ) {
# Only true if each result's ->is_success method returns true
print "happiness and puppies!\n";
} elsif ( $r->all_error ) {
# Only true if each result's ->is_error method returns true
die 'Oh noes! Everything errored out!';
} else {
foreach my $failed ( $r->list_not_success() ) {
# Do something with each failed result
}
}
DESCRIPTION
Data::ResultSet is a container object for aggregating and examining multiple results. It allows multiple result objects matching the same method signature to be returned as a single object that can then be queried for success or failure in a number of ways.
This is accomplished by generating wrappers to methods in the underlying list of result objects. For example, if you have a result object that has an is_ok() method, you can create a Data::ResultSet subclass to handle it with:
package MyApp::ResultSet;
use base qw( Data::ResultSet );
__PACKAGE__->make_wrappers( 'is_ok' );
1;
This will generate all_ok
, has_ok
, get_ok
, and get_not_ok
methods in MyApp::ResultSet that use the is_ok
accessor on your result object.
CLASS METHODS
new ( )
Creates a new Data::ResultSet object. Generally you will want to do this on a subclass, not on Data::ResultSet.
make_wrappers ( @method_names )
Generates all wrapper methods ( all_, has_, get_, get_not ) for the provided method names. The resulting wrapper will consist of the provided name and the appropriate prefix, with the exception that provided names beginning with is_ will have the is_ stripped first.
The wrappers can be generated individually using other methods (see below).
make_wrappers_for_all ( @method_names )
Generates the all_
wrapper method for each provided name.
make_wrappers_for_has
Generates the has_
wrapper method for each provided name.
make_wrappers_for_get
Generates the get_
wrapper method for each provided name.
make_wrappers_for_get_not
Generates the get_not_
wrapper method for each provided name.
INSTANCE METHODS
add ( $object )
Adds an object to the result set. Returns $self.
count ( )
Returns number of objects in the set.
contents ( )
Returns contents of set.
clear ( )
Clears contents of set. Returns true.
all_METHOD ( )
Generated method that returns true if the METHOD called on every object within the set returns true.
has_METHOD ( )
Generated method that returns true if one object within the set returns true for METHOD.
get_METHOD ( )
Generated method that returns all objects for which METHOD returns true.
get_not_METHOD ( )
Generated method that returns all objects for which METHOD returns false.
INCOMPATIBILITIES
There are no known incompatibilities with this module.
BUGS AND LIMITATIONS
The methods being wrapped shouldn't be anything more than simple accessors. They will get called an arbitrary number of times, so doing any real work, particularly anything that changes state or has side-effects, is a bad idea.
Please report any new problems to the author. Patches are welcome.
SEE ALSO
There are quite a few other packages on the CPAN for implementing polymorphic return values. You may wish to use one of these instead:
AUTHOR
Dave O'Neill (dmo@roaringpenguin.com)
LICENCE AND COPYRIGHT
Copyright (c) 2007 Roaring Penguin Software, Inc.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.