summaryrefslogtreecommitdiff
path: root/IkiWiki
diff options
context:
space:
mode:
authorjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>2007-08-12 09:19:20 +0000
committerjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>2007-08-12 09:19:20 +0000
commit2e1670a821ac2582ac8c65f3ec39bfa64d27577a (patch)
treec72ea0415b4c36cb1882aba4a85b3c7fcce9322b /IkiWiki
parent522416b18aa898298855cee0efcee2c6ed25168a (diff)
* Add time=mtime option to postsparkline.
Diffstat (limited to 'IkiWiki')
-rw-r--r--IkiWiki/Plugin/postsparkline.pm18
1 files changed, 13 insertions, 5 deletions
diff --git a/IkiWiki/Plugin/postsparkline.pm b/IkiWiki/Plugin/postsparkline.pm
index e4fe9c154..6f7558bc4 100644
--- a/IkiWiki/Plugin/postsparkline.pm
+++ b/IkiWiki/Plugin/postsparkline.pm
@@ -21,6 +21,13 @@ sub preprocess (@) { #{{{
return "";
}
+ if (! exists $params{time} || $params{time} ne 'mtime') {
+ $params{timehash} = \%IkiWiki::pagectime;
+ }
+ else {
+ $params{timehash} = \%IkiWiki::pagemtime;
+ }
+
if (! exists $params{formula}) {
return "[[postsparkline ".gettext("missing formula")."]]";
}
@@ -42,14 +49,15 @@ sub preprocess (@) { #{{{
}
}
- @list = sort { $IkiWiki::pagectime{$b} <=> $IkiWiki::pagectime{$a} } @list;
+ @list = sort { $params{timehash}->{$b} <=> $params{timehash}->{$a} } @list;
- delete $params{pages};
- delete $params{formula};
my @data=eval qq{IkiWiki::Plugin::postsparkline::formula::$formula(\\\%params, \@list)};
if ($@) {
return "[[postsparkline error $@]]";
}
+ delete $params{pages};
+ delete $params{formula};
+ delete $params{ftime};
return IkiWiki::Plugin::sparkline::preprocess(%params,
map { $_ => "" } reverse @data);
} # }}}
@@ -63,7 +71,7 @@ sub perfoo ($@) {
my $count=0;
my @data;
foreach (@_) {
- $cur=$sub->($IkiWiki::pagectime{$_});
+ $cur=$sub->($params->{timehash}->{$_});
if (defined $prev) {
if ($prev != $cur) {
push @data, "$prev,$count";
@@ -114,7 +122,7 @@ sub interval ($@) {
my $max=$params->{max};
my @data;
for (my $i=1; $i < @_; $i++) {
- push @data, $IkiWiki::pagectime{$_[$i-1]} - $IkiWiki::pagectime{$_[$i]};
+ push @data, $params->{timehash}->{$_[$i-1]} - $params->{timehash}->{$_[$i]};
last if --$max <= 0;
}
return @data;