]> Sergey Matveev's repositories - public-inbox.git/commitdiff
lei rediff: do not automatically store patches/mails
authorEric Wong <e@80x24.org>
Wed, 5 May 2021 17:49:44 +0000 (17:49 +0000)
committerEric Wong <e@80x24.org>
Wed, 5 May 2021 19:50:04 +0000 (19:50 +0000)
We can use a temporary lei/store to avoid cluttering up
future search results.  This is especially useful since
we expect "lei rediff" to be useful for non-email diffs
and individual attachments, too.

lib/PublicInbox/LeiRediff.pm
t/solver_git.t

index d73e3e286f4f0c325d0dcb20c67a8d7f5fd8c38a..deb6c3aed2f792f07841611a2cd6df8338b8691d 100644 (file)
@@ -70,7 +70,6 @@ EOM
        my $tb = $ta;
        $tb =~ tr!A!B!;
        my $lei = $self->{lei};
-       my $wait = delete($self->{-do_done}) ? $lei->{sto}->ipc_do('done') : 0;
        while (my ($oid_a, $oid_b, $pa, $pb, $ma, $mb) = splice(@$ctxq, 0, 6)) {
                my $xa = $blob->{$oid_a} //= solve_1($self, $oid_a,
                                                        { path_b => $pa });
@@ -193,8 +192,8 @@ sub extract_oids { # Eml each_part callback
 
 sub input_eml_cb { # callback for all emails
        my ($self, $eml) = @_;
-       $self->{lei}->{sto}->ipc_do('add_eml', $eml);
-       $self->{-do_done} = 1;
+       $self->{tmp_sto}->add_eml($eml);
+       $self->{tmp_sto}->done;
        $eml->each_part(\&extract_oids, $self, 1);
 }
 
@@ -239,7 +238,9 @@ sub ipc_atfork_child {
        binmode $lei->{1}, ':utf8';
        $self->{blobs} = {}; # oidhex => filename
        $self->{rdtmp} = File::Temp->newdir('lei-rediff-XXXX', TMPDIR => 1);
-       $self->{rmt} = [ map {
+       $self->{tmp_sto} = PublicInbox::LeiStore->new(
+                       "$self->{rdtmp}/tmp.store", { creat => 1 });
+       $self->{rmt} = [ $self->{tmp_sto}->search, map {
                        PublicInbox::LeiRemote->new($lei, $_)
                } $self->{lxs}->remotes ];
        $self->{gits} = [ map {
index ad0c295b5526dcf24e2ff62b9fdbdd6f78755e42..13e478b325bcfa3b1c9f4613c99f4971f761461d 100644 (file)
@@ -86,6 +86,9 @@ index 15ac20eb..771486c4
 EOM
        ok(index($lei_out, $exp) >= 0,
                'preserve mode, regen header + context from -U0 patch');
+       my $e = { GIT_DIR => "$ENV{HOME}/.local/share/lei/store/ALL.git" };
+       my @x = xqx([qw(git cat-file --batch-all-objects --batch-check)], $e);
+       is_deeply(\@x, [], 'no objects stored') or diag explain(\@x);
 });
 
 test_lei({tmpdir => "$tmpdir/index-eml-only"}, sub {