diff options
author | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2007-08-12 09:19:20 +0000 |
---|---|---|
committer | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2007-08-12 09:19:20 +0000 |
commit | 2e1670a821ac2582ac8c65f3ec39bfa64d27577a (patch) | |
tree | c72ea0415b4c36cb1882aba4a85b3c7fcce9322b /IkiWiki/Plugin | |
parent | 522416b18aa898298855cee0efcee2c6ed25168a (diff) | |
download | ikiwiki-2e1670a821ac2582ac8c65f3ec39bfa64d27577a.tar ikiwiki-2e1670a821ac2582ac8c65f3ec39bfa64d27577a.tar.gz |
* Add time=mtime option to postsparkline.
Diffstat (limited to 'IkiWiki/Plugin')
-rw-r--r-- | IkiWiki/Plugin/postsparkline.pm | 18 |
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; |