]> sipb.mit.edu Git - ikiwiki.git/blobdiff - IkiWiki/Plugin/inline.pm
* Run page through any relevant filters when generating a page preview.
[ikiwiki.git] / IkiWiki / Plugin / inline.pm
index afff96cee6a7801c56780ac98719f816ff4d4dda..08126c4e6f6f6a399de8b2346626ed908d3a5734 100644 (file)
@@ -34,6 +34,19 @@ sub preprocess_inline (@) { #{{{
        if (! exists $params{show} && $params{archive} eq "no") {
                $params{show}=10;
        }
        if (! exists $params{show} && $params{archive} eq "no") {
                $params{show}=10;
        }
+
+       my @list;
+       foreach my $page (keys %pagesources) {
+               next if $page eq $params{page};
+               if (globlist_match($page, $params{pages})) {
+                       push @list, $page;
+               }
+       }
+       @list=sort { $pagectime{$b} <=> $pagectime{$a} } @list;
+       if ($params{show} && @list > $params{show}) {
+               @list=@list[0..$params{show} - 1];
+       }
+
        add_depends($params{page}, $params{pages});
 
        my $ret="";
        add_depends($params{page}, $params{pages});
 
        my $ret="";
@@ -62,10 +75,7 @@ sub preprocess_inline (@) { #{{{
                blind_cache => 1,
        );
        
                blind_cache => 1,
        );
        
-       my @pages;
-       foreach my $page (blog_list($params{pages}, $params{show})) {
-               next if $page eq $params{page};
-               push @pages, $page;
+       foreach my $page (@list) {
                $template->param(pagelink => htmllink($params{page}, $params{page}, $page));
                $template->param(content => get_inline_content($params{page}, $page))
                        if $params{archive} eq "no";
                $template->param(pagelink => htmllink($params{page}, $params{page}, $page));
                $template->param(content => get_inline_content($params{page}, $page))
                        if $params{archive} eq "no";
@@ -78,36 +88,20 @@ sub preprocess_inline (@) { #{{{
        # only supports listing one file per page.
        if ($config{rss}) {
                writefile(rsspage($params{page}), $config{destdir},
        # only supports listing one file per page.
        if ($config{rss}) {
                writefile(rsspage($params{page}), $config{destdir},
-                       genrss($params{page}, @pages));
-               $toping{$params{page}}=1;
+                       genrss($params{page}, @list));
+               $toping{$params{page}}=1 unless $config{rebuild};
        }
        
        return $ret;
 } #}}}
 
        }
        
        return $ret;
 } #}}}
 
-sub blog_list ($$) { #{{{
-       my $globlist=shift;
-       my $maxitems=shift;
-
-       my @list;
-       foreach my $page (keys %pagesources) {
-               if (globlist_match($page, $globlist)) {
-                       push @list, $page;
-               }
-       }
-
-       @list=sort { $pagectime{$b} <=> $pagectime{$a} } @list;
-       return @list if ! $maxitems || @list <= $maxitems;
-       return @list[0..$maxitems - 1];
-} #}}}
-
 sub get_inline_content ($$) { #{{{
        my $parentpage=shift;
        my $page=shift;
        
        my $file=$pagesources{$page};
        my $type=pagetype($file);
 sub get_inline_content ($$) { #{{{
        my $parentpage=shift;
        my $page=shift;
        
        my $file=$pagesources{$page};
        my $type=pagetype($file);
-       if ($type ne 'unknown') {
+       if (defined $type) {
                return htmlize($type, preprocess($page, linkify($page, $parentpage, readfile(srcfile($file))), 1));
        }
        else {
                return htmlize($type, preprocess($page, linkify($page, $parentpage, readfile(srcfile($file))), 1));
        }
        else {