]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/View.pm
view: remove upfx parameter from thread skeleton dump
[public-inbox.git] / lib / PublicInbox / View.pm
index e8ec0ed2eaa23fe84751b351aecf361bd5065a64..9095c505b88c814e0ce289092e86e4d3533685f3 100644 (file)
@@ -12,7 +12,7 @@ use Encode::MIME::Header;
 use Plack::Util;
 use PublicInbox::Hval qw/ascii_html/;
 use PublicInbox::Linkify;
-use PublicInbox::MID qw/mid_clean id_compress mid2path mid_mime/;
+use PublicInbox::MID qw/mid_clean id_compress mid_mime/;
 use PublicInbox::MsgIter;
 use PublicInbox::Address;
 use PublicInbox::WwwStream;
@@ -383,9 +383,10 @@ sub thread_skel {
                cur => $mid,
                prev_attr => '',
                prev_level => 0,
+               upfx => "$tpfx../",
        };
        for (thread_results(load_results($sres))->rootset) {
-               skel_dump($dst, $state, $tpfx, $_, 0);
+               skel_dump($dst, $state, $_, 0);
        }
        $ctx->{next_msg} = $state->{next_msg};
        $ctx->{parent_msg} = $parent;
@@ -581,9 +582,10 @@ sub __thread_entry {
 
        # lazy load the full message from mini_mime:
        $mime = eval {
-               my $path = mid2path(mid_clean(mid_mime($mime)));
-               Email::MIME->new($state->{ctx}->{git}->cat_file('HEAD:'.$path));
+               my $mid = mid_clean(mid_mime($mime));
+               $state->{ctx}->{-inbox}->msg_by_mid($mid);
        } or return;
+       $mime = Email::MIME->new($mime);
 
        thread_html_head($mime, $state) if $state->{anchor_idx} == 0;
        if (my $ghost = delete $state->{ghost}) {
@@ -662,7 +664,7 @@ sub _msg_date {
 sub fmt_ts { POSIX::strftime('%Y-%m-%d %k:%M', gmtime($_[0])) }
 
 sub _skel_header {
-       my ($dst, $state, $upfx, $hdr, $level) = @_;
+       my ($dst, $state, $hdr, $level) = @_;
 
        my $cur = $state->{cur};
        my $mid = mid_clean($hdr->header_raw('Message-ID'));
@@ -704,18 +706,18 @@ sub _skel_header {
                $s = $s->as_html;
        }
        my $m = PublicInbox::Hval->new_msgid($mid);
-       $m = $upfx . '../' . $m->as_href . '/';
+       $m = $state->{upfx} . $m->as_href . '/';
        $$dst .= "$pfx<a\nhref=\"$m\">";
        $$dst .= defined($s) ? "$s</a> $f\n" : "$f</a>\n";
 }
 
 sub skel_dump {
-       my ($dst, $state, $upfx, $node, $level) = @_;
+       my ($dst, $state, $node, $level) = @_;
        return unless $node;
        if (my $mime = $node->message) {
                my $hdr = $mime->header_obj;
                my $mid = mid_clean($hdr->header_raw('Message-ID'));
-               _skel_header($dst, $state, $upfx, $hdr, $level);
+               _skel_header($dst, $state, $hdr, $level);
        } else {
                my $mid = $node->messageid;
                if ($mid eq 'subject dummy') {
@@ -724,13 +726,13 @@ sub skel_dump {
                        $$dst .= '     [not found] ';
                        $$dst .= indent_for($level) . th_pfx($level);
                        $mid = PublicInbox::Hval->new_msgid($mid);
-                       my $href = "$upfx../" . $mid->as_href . '/';
+                       my $href = $state->{upfx} . $mid->as_href . '/';
                        my $html = $mid->as_html;
                        $$dst .= qq{&lt;<a\nhref="$href">$html</a>&gt;\n};
                }
        }
-       skel_dump($dst, $state, $upfx, $node->child, $level+1);
-       skel_dump($dst, $state, $upfx, $node->next, $level);
+       skel_dump($dst, $state, $node->child, $level+1);
+       skel_dump($dst, $state, $node->next, $level);
 }
 
 sub sort_ts {
@@ -740,19 +742,27 @@ sub sort_ts {
        } @_;
 }
 
+sub _tryload_ghost ($$) {
+       my ($srch, $node) = @_;
+       my $mid = $node->messageid;
+       my $smsg = $srch->lookup_mail($mid) or return;
+       $smsg->mini_mime;
+}
+
 # accumulate recent topics if search is supported
 # returns 1 if done, undef if not
 sub add_topic {
        my ($state, $node, $level) = @_;
        return unless $node;
        my $child_adjust = 1;
-
-       if (my $x = $node->message) {
+       my $srch = $state->{srch};
+       my $x = $node->message || _tryload_ghost($srch, $node);
+       if ($x) {
                $x = $x->header_obj;
                my $subj;
 
                $subj = $x->header('Subject');
-               $subj = $state->{srch}->subject_normalized($subj);
+               $subj = $srch->subject_normalized($subj);
 
                if (++$state->{subjs}->{$subj} == 1) {
                        push @{$state->{order}}, [ $level, $subj ];