Made pager a method on ResultSet, added rs->page(num) to page an ordinary RS, made...
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / ResultSet.pm
CommitLineData
89c0a5a2 1package DBIx::Class::ResultSet;
2
3use strict;
4use warnings;
5use overload
6 '0+' => 'count',
7 fallback => 1;
3c5b25c5 8use Data::Page;
89c0a5a2 9
10sub new {
7624b19f 11 my ($it_class, $db_class, $attrs) = @_;
89c0a5a2 12 #use Data::Dumper; warn Dumper(@_);
13 $it_class = ref $it_class if ref $it_class;
14 $attrs = { %{ $attrs || {} } };
7624b19f 15 my $cols = [ $db_class->_select_columns ];
89c0a5a2 16 my $new = {
17 class => $db_class,
89c0a5a2 18 cols => $cols,
89c0a5a2 19 cond => $attrs->{where},
3c5b25c5 20 count => undef,
21 pager => undef,
89c0a5a2 22 attrs => $attrs };
23 return bless ($new, $it_class);
24}
25
73f58123 26sub cursor {
27 my ($self) = @_;
28 my ($db_class, $attrs) = @{$self}{qw/class attrs/};
3c5b25c5 29 if ($attrs->{page}) {
30 $attrs->{rows} = $self->pager->entries_per_page;
31 $attrs->{offset} = $self->pager->skipped;
32 }
73f58123 33 return $self->{cursor}
34 ||= $db_class->storage->select($db_class->_table_name, $self->{cols},
35 $attrs->{where},$attrs);
36}
37
89c0a5a2 38sub slice {
39 my ($self, $min, $max) = @_;
40 my $attrs = { %{ $self->{attrs} || {} } };
41 $self->{class}->throw("Can't slice without where") unless $attrs->{where};
42 $attrs->{offset} = $min;
43 $attrs->{rows} = ($max ? ($max - $min + 1) : 1);
7624b19f 44 my $slice = $self->new($self->{class}, $attrs);
89c0a5a2 45 return (wantarray ? $slice->all : $slice);
46}
47
48sub next {
49 my ($self) = @_;
73f58123 50 my @row = $self->cursor->next;
89c0a5a2 51 return unless (@row);
52 return $self->{class}->_row_to_object($self->{cols}, \@row);
53}
54
55sub count {
56 my ($self) = @_;
7624b19f 57 my $db_class = $self->{class};
59f8e584 58 my $attrs = { %{ $self->{attrs} } };
3c5b25c5 59 unless ($self->{count}) {
60 # offset and order by are not needed to count
61 delete $attrs->{$_} for qw/offset order_by/;
62
63 my @cols = 'COUNT(*)';
64 $self->{count} = $db_class->storage->select_single($db_class->_table_name, \@cols,
65 $self->{cond}, $attrs);
66 }
67 return 0 unless $self->{count};
68 return ( $attrs->{rows} && $attrs->{rows} < $self->{count} )
59f8e584 69 ? $attrs->{rows}
3c5b25c5 70 : $self->{count};
89c0a5a2 71}
72
73sub all {
74 my ($self) = @_;
1a14aa3f 75 return map { $self->{class}->_row_to_object($self->{cols}, $_); }
73f58123 76 $self->cursor->all;
89c0a5a2 77}
78
79sub reset {
80 my ($self) = @_;
73f58123 81 $self->cursor->reset;
89c0a5a2 82 return $self;
83}
84
85sub first {
86 return $_[0]->reset->next;
87}
88
28927b50 89sub delete {
89c0a5a2 90 my ($self) = @_;
91 $_->delete for $self->all;
92 return 1;
93}
94
28927b50 95*delete_all = \&delete; # Yeah, yeah, yeah ...
96
3c5b25c5 97sub pager {
98 my ($self) = @_;
99 my $attrs = $self->{attrs};
100 delete $attrs->{offset};
101 my $rows_per_page = delete $attrs->{rows} || 10;
102 $self->{pager} ||= Data::Page->new(
103 $self->count, $rows_per_page, $attrs->{page} || 1);
104 $attrs->{rows} = $rows_per_page;
105 return $self->{pager};
106}
107
108sub page {
109 my ($self, $page) = @_;
110 my $attrs = $self->{attrs};
111 $attrs->{page} = $page;
112 return $self->new($self->{class}, $attrs);
113}
114
89c0a5a2 1151;