]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/LeiSucks.pm
lei sucks: show nproc in CPU info
[public-inbox.git] / lib / PublicInbox / LeiSucks.pm
index a71158f36f03c97c9b3cdc8a0c0a96e8cbdd8c70..8e866fc96655a9dd5a6342de43217da0a57e14f5 100644 (file)
@@ -11,7 +11,7 @@ use Digest::SHA ();
 use Config;
 use POSIX ();
 use PublicInbox::Config;
-use PublicInbox::Search;
+use PublicInbox::IPC;
 
 sub lei_sucks {
        my ($lei, @argv) = @_;
@@ -23,9 +23,10 @@ sub lei_sucks {
        }
        eval { require PublicInbox };
        my $pi_ver = eval('$PublicInbox::VERSION') // '(???)';
+       my $nproc = PublicInbox::IPC::detect_nproc() // '?';
        my @out = ("lei $pi_ver\n",
                "perl $Config{version} / $os $rel / $mac ".
-               "ptrsize=$Config{ptrsize}\n");
+               "ptrsize=$Config{ptrsize} nproc=$nproc\n");
        chomp(my $gv = `git --version` || "git missing");
        $gv =~ s/ version / /;
        my $json = ref(PublicInbox::Config->json);
@@ -41,7 +42,8 @@ sub lei_sucks {
        } else {
                push @out, "Unable to load DBI / DBD::SQLite: $@\n";
        }
-       if (PublicInbox::Search::load_xapian()) {
+       if (eval { require PublicInbox::Search } &&
+                       PublicInbox::Search::load_xapian()) {
                push @out, 'Xapian '.
                        join('.', map {
                                $PublicInbox::Search::Xap->can($_)->();
@@ -55,7 +57,7 @@ sub lei_sucks {
        my $dig = Digest::SHA->new(1);
        push @out, "public-inbox blob OIDs of loaded features:\n";
        for my $m (grep(m{^PublicInbox/}, sort keys %INC)) {
-               my $f = $INC{$m};
+               my $f = $INC{$m} // next; # lazy require failed (missing dep)
                $dig->add('blob '.(-s $f)."\0");
                $dig->addfile($f);
                push @out, '  '.$dig->hexdigest.' '.$m."\n";