about summary refs log tree commit homepage
path: root/lib/PublicInbox
diff options
context:
space:
mode:
Diffstat (limited to 'lib/PublicInbox')
-rw-r--r--lib/PublicInbox/Mbox.pm2
-rw-r--r--lib/PublicInbox/Search.pm13
2 files changed, 7 insertions, 8 deletions
diff --git a/lib/PublicInbox/Mbox.pm b/lib/PublicInbox/Mbox.pm
index 1fca356b..94f733bc 100644
--- a/lib/PublicInbox/Mbox.pm
+++ b/lib/PublicInbox/Mbox.pm
@@ -235,7 +235,7 @@ sub mbox_all {
         my $over = $ctx->{ibx}->over or
                 return PublicInbox::WWW::need($ctx, 'Overview');
 
-        my $qopts = $ctx->{qopts} = { relevance => -1 }; # ORDER BY docid ASC
+        my $qopts = $ctx->{qopts} = { relevance => -2 }; # ORDER BY docid DESC
         $qopts->{threads} = 1 if $q->{t};
         my $mset = $srch->mset($q_string, $qopts);
         $qopts->{offset} = $mset->size or
diff --git a/lib/PublicInbox/Search.pm b/lib/PublicInbox/Search.pm
index aa737d63..76a270bc 100644
--- a/lib/PublicInbox/Search.pm
+++ b/lib/PublicInbox/Search.pm
@@ -407,18 +407,17 @@ sub _enquire_once { # retry_reopen callback
         my $enquire = $X{Enquire}->new($xdb);
         $enquire->set_query($query);
         $opts ||= {};
-        my $desc = !$opts->{asc};
         my $rel = $opts->{relevance} // 0;
-        if ($rel == -1) { # ORDER BY docid/UID
+        if ($rel == -2) { # ORDER BY docid/UID (highest first)
+                $enquire->set_weighting_scheme($X{BoolWeight}->new);
+                $enquire->set_docid_order($ENQ_DESCENDING);
+        } elsif ($rel == -1) { # ORDER BY docid/UID (lowest first)
                 $enquire->set_weighting_scheme($X{BoolWeight}->new);
                 $enquire->set_docid_order($ENQ_ASCENDING);
         } elsif ($rel == 0) {
-                $enquire->set_sort_by_value_then_relevance(TS, $desc);
-        } elsif ($rel == -2) {
-                $enquire->set_weighting_scheme($X{BoolWeight}->new);
-                $enquire->set_docid_order($ENQ_DESCENDING);
+                $enquire->set_sort_by_value_then_relevance(TS, !$opts->{asc});
         } else { # rel > 0
-                $enquire->set_sort_by_relevance_then_value(TS, $desc);
+                $enquire->set_sort_by_relevance_then_value(TS, !$opts->{asc});
         }
 
         # `mairix -t / --threads' or JMAP collapseThreads