about summary refs log tree commit homepage
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-10-19 09:33:38 +0000
committerEric Wong <e@80x24.org>2021-10-19 17:29:16 +0000
commit95ae3c4a45435a8208a8f10b27c78329b5ad3e85 (patch)
treea5054d61dd913f4d56845248835b1898d5e5d183
parent8e91ad5eb95dff4070fa32242a59f373df8d9ff5 (diff)
downloadpublic-inbox-95ae3c4a45435a8208a8f10b27c78329b5ad3e85.tar.gz
This allows "lei up" to continue processing unrelated externals
if on output fails.
-rw-r--r--lib/PublicInbox/LeiExternal.pm4
-rw-r--r--lib/PublicInbox/LeiQuery.pm12
-rw-r--r--lib/PublicInbox/LeiSavedSearch.pm8
-rw-r--r--lib/PublicInbox/LeiUp.pm4
-rw-r--r--lib/PublicInbox/LeiXSearch.pm7
5 files changed, 17 insertions, 18 deletions
diff --git a/lib/PublicInbox/LeiExternal.pm b/lib/PublicInbox/LeiExternal.pm
index 701d1ad5..851715d7 100644
--- a/lib/PublicInbox/LeiExternal.pm
+++ b/lib/PublicInbox/LeiExternal.pm
@@ -101,9 +101,9 @@ sub get_externals {
                 return (ext_canonicalize($loc));
         }
         if (scalar(@m) == 0) {
-                $self->fail("`$loc' is unknown");
+                die "`$loc' is unknown\n";
         } else {
-                $self->fail("`$loc' is ambiguous:\n", map { "\t$_\n" } @m);
+                die("`$loc' is ambiguous:\n", map { "\t$_\n" } @m, "\n");
         }
         ();
 }
diff --git a/lib/PublicInbox/LeiQuery.pm b/lib/PublicInbox/LeiQuery.pm
index ec2ece05..56b82acc 100644
--- a/lib/PublicInbox/LeiQuery.pm
+++ b/lib/PublicInbox/LeiQuery.pm
@@ -18,17 +18,15 @@ sub _start_query { # used by "lei q" and "lei up"
         PublicInbox::LeiOverview->new($self) or return;
         my $opt = $self->{opt};
         my ($xj, $mj) = split(/,/, $opt->{jobs} // '');
-        if (defined($xj) && $xj ne '' && $xj !~ /\A[1-9][0-9]*\z/) {
-                return $self->fail("`$xj' search jobs must be >= 1");
-        }
+        (defined($xj) && $xj ne '' && $xj !~ /\A[1-9][0-9]*\z/) and
+                die "`$xj' search jobs must be >= 1\n";
         my $lxs = $self->{lxs};
         $xj ||= $lxs->concurrency($opt); # allow: "--jobs ,$WRITER_ONLY"
         my $nproc = $lxs->detect_nproc || 1; # don't memoize, schedtool(1) exists
         $xj = $nproc if $xj > $nproc;
         $lxs->{-wq_nr_workers} = $xj;
-        if (defined($mj) && $mj !~ /\A[1-9][0-9]*\z/) {
-                return $self->fail("`$mj' writer jobs must be >= 1");
-        }
+        (defined($mj) && $mj !~ /\A[1-9][0-9]*\z/) and
+                die "`$mj' writer jobs must be >= 1\n";
         my $l2m = $self->{l2m};
         # we use \1 (a ref) to distinguish between default vs. user-supplied
         if ($l2m && grep { $opt->{$_} //= \1 } (qw(mail-sync import-remote
@@ -112,7 +110,7 @@ sub lxs_prepare {
                 }
         }
         ($lxs->locals || $lxs->remotes) ? ($self->{lxs} = $lxs) :
-                $self->fail('no local or remote inboxes to search');
+                die("no local or remote inboxes to search\n");
 }
 
 # the main "lei q SEARCH_TERMS" method
diff --git a/lib/PublicInbox/LeiSavedSearch.pm b/lib/PublicInbox/LeiSavedSearch.pm
index 3e10f780..b2f1ad10 100644
--- a/lib/PublicInbox/LeiSavedSearch.pm
+++ b/lib/PublicInbox/LeiSavedSearch.pm
@@ -96,7 +96,7 @@ sub translate_dedupe ($$) {
         my $dd = $lei->{opt}->{dedupe} // 'content';
         return 1 if $dd eq 'content'; # the default
         return $self->{"-dedupe_$dd"} = 1 if ($dd eq 'oid' || $dd eq 'mid');
-        $lei->fail("--dedupe=$dd requires --no-save");
+        die("--dedupe=$dd requires --no-save\n");
 }
 
 sub up { # updating existing saved search via "lei up"
@@ -105,9 +105,9 @@ sub up { # updating existing saved search via "lei up"
         my $self = bless { ale => $lei->ale }, $cls;
         my $dir = $dst;
         output2lssdir($self, $lei, \$dir, \$f) or
-                return $lei->fail("--no-save was used with $dst cwd=".
-                                        $lei->rel2abs('.'));
-        $self->{-cfg} = $lei->cfg_dump($f) // return $lei->fail;
+                return die("--no-save was used with $dst cwd=".
+                                        $lei->rel2abs('.')."\n");
+        $self->{-cfg} = $lei->cfg_dump($f) // return $lei->child_error;
         $self->{-ovf} = "$dir/over.sqlite3";
         $self->{'-f'} = $f;
         $self->{lock_path} = "$self->{-f}.flock";
diff --git a/lib/PublicInbox/LeiUp.pm b/lib/PublicInbox/LeiUp.pm
index c35b2e42..4fd0290c 100644
--- a/lib/PublicInbox/LeiUp.pm
+++ b/lib/PublicInbox/LeiUp.pm
@@ -19,7 +19,7 @@ sub up1 ($$) {
         my $f = $lss->{'-f'};
         my $mset_opt = $lei->{mset_opt} = { relevance => -2 };
         my $q = $mset_opt->{q_raw} = $lss->{-cfg}->{'lei.q'} //
-                                return $lei->fail("lei.q unset in $f");
+                                die("lei.q unset in $f (out=$out)\n");
         my $lse = $lei->{lse} // die 'BUG: {lse} missing';
         if (ref($q)) {
                 $mset_opt->{qstr} = $lse->query_argv_to_string($lse->git, $q);
@@ -36,7 +36,7 @@ sub up1 ($$) {
                 $lei->{opt}->{$k} //= $v;
         }
         my $o = $lei->{opt}->{output} // '';
-        return $lei->fail("lei.q.output unset in $f (out=$out)") if $o eq '';
+        return die("lei.q.output unset in $f (out=$out)\n") if $o eq '';
         $lss->translate_dedupe($lei) or return;
         $lei->{lss} = $lss; # for LeiOverview->new and query_remote_mboxrd
         my $lxs = $lei->lxs_prepare or return;
diff --git a/lib/PublicInbox/LeiXSearch.pm b/lib/PublicInbox/LeiXSearch.pm
index 8ab84b15..119070a2 100644
--- a/lib/PublicInbox/LeiXSearch.pm
+++ b/lib/PublicInbox/LeiXSearch.pm
@@ -142,11 +142,11 @@ sub wait_startq ($) {
                                 delete $lei->{opt}->{verbose};
                                 delete $lei->{-progress};
                         } else {
-                                $lei->fail("$$ WTF `$do_augment_done'");
+                                die "BUG: do_augment_done=`$do_augment_done'";
                         }
                         return;
                 }
-                return $lei->fail("$$ wait_startq: $!") unless $!{EINTR};
+                die "wait_startq: $!" unless $!{EINTR};
         }
 }
 
@@ -473,7 +473,8 @@ sub do_post_augment {
                 $lei->fail("$err");
         }
         if (!$err && delete $lei->{early_mua}) { # non-augment case
-                $lei->start_mua;
+                eval { $lei->start_mua };
+                $lei->fail($@) if $@;
         }
         close(delete $lei->{au_done}); # triggers wait_startq in lei_xsearch
 }