projects
/
MojoFacets.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
97b1b94
)
speedup facets using stored filters
author
Dobrica Pavlinusic
<dpavlin@rot13.org>
Tue, 25 May 2010 18:05:36 +0000
(20:05 +0200)
committer
Dobrica Pavlinusic
<dpavlin@rot13.org>
Tue, 25 May 2010 18:05:36 +0000
(20:05 +0200)
lib/MojoFacets/Data.pm
patch
|
blob
|
history
diff --git
a/lib/MojoFacets/Data.pm
b/lib/MojoFacets/Data.pm
index
c75fde5
..
bf150ee
100644
(file)
--- a/
lib/MojoFacets/Data.pm
+++ b/
lib/MojoFacets/Data.pm
@@
-521,13
+521,20
@@
sub facet {
my $all = $self->_perm_scalar('all', 1);
my $all = $self->_perm_scalar('all', 1);
- foreach my $i ( $self->_data_items($all) ) {
- if ( ! exists $i->{$name} ) {
+ my $filter = $loaded->{$path}->{filters}->{$name};
+
+ my $data = $self->_loaded('data');
+ foreach my $i ( 0 .. $#{ $data->{items} } ) {
+ if ( $filter && ! $all ) {
+ next unless defined $loaded->{$path}->{filters}->{$name}->{$i};
+ }
+ my $item = $data->{items}->[$i];
+ if ( ! exists $item->{$name} ) {
$facet->{ _missing }++;
$facet->{ _missing }++;
- } elsif ( ref $i->{$name} eq 'ARRAY' ) {
- $facet->{$_}++ foreach @{ $i->{$name} };
+ } elsif ( ref $i
tem
->{$name} eq 'ARRAY' ) {
+ $facet->{$_}++ foreach @{ $i
tem
->{$name} };
} else {
} else {
- $facet->{ $i->{$name} }++;
+ $facet->{ $i
tem
->{$name} }++;
}
}
}
}