pagecount: switched to use_pagespec
parent
32cd5f0b79
commit
1abbc6a404
|
@ -20,20 +20,20 @@ sub getsetup () {
|
|||
|
||||
sub preprocess (@) {
|
||||
my %params=@_;
|
||||
$params{pages}="*" unless defined $params{pages};
|
||||
my $pages=defined $params{pages} ? $params{pages} : "*";
|
||||
|
||||
# Needs to update count whenever a page is added or removed, so
|
||||
# register a presence dependency.
|
||||
add_depends($params{page}, $params{pages}, deptype("presence"));
|
||||
# Just get a list of all the pages, and count the items in it.
|
||||
# Use a presence dependency to only update when pages are added
|
||||
# or removed.
|
||||
|
||||
my @pages;
|
||||
if ($params{pages} eq "*") {
|
||||
@pages=keys %pagesources;
|
||||
if ($pages eq '*') {
|
||||
# optimisation to avoid needing to try matching every page
|
||||
add_depends($params{page}, $pages, deptype("presence"));
|
||||
return scalar keys %pagesources;
|
||||
}
|
||||
else {
|
||||
@pages=pagespec_match_list([keys %pagesources], $params{pages}, location => $params{page});
|
||||
}
|
||||
return $#pages+1;
|
||||
|
||||
return scalar use_pagespec($params{page}, $pages,
|
||||
deptype => deptype("presence"));
|
||||
}
|
||||
|
||||
1
|
||||
|
|
Loading…
Reference in New Issue