X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=lib%2FPublicInbox%2FLeiForgetSearch.pm;h=0db9c75b8be3b2ae0c30d149d5c47b5c7c244098;hb=14f65bca12e367eed79e7b737d1cb19929599cf6;hp=717fa5e9c2e1b68710706f97a9a0ec82628b63f3;hpb=06d0f4419011dc6546ae200e4fbc1558464509c2;p=public-inbox.git diff --git a/lib/PublicInbox/LeiForgetSearch.pm b/lib/PublicInbox/LeiForgetSearch.pm index 717fa5e9..0db9c75b 100644 --- a/lib/PublicInbox/LeiForgetSearch.pm +++ b/lib/PublicInbox/LeiForgetSearch.pm @@ -11,20 +11,26 @@ use File::Path (); use SelectSaver; sub lei_forget_search { - my ($lei, $out) = @_; - my $d = PublicInbox::LeiSavedSearch::lss_dir_for($lei, \$out, 1); - if (-e $d) { - my $save; - my $opt = { safe => 1 }; - if ($lei->{opt}->{verbose}) { - $opt->{verbose} = 1; - $save = SelectSaver->new($lei->{2}); + my ($lei, @outs) = @_; + my @dirs; # paths in ~/.local/share/lei/saved-search/ + my $cwd; + for my $o (@outs) { + my $d = PublicInbox::LeiSavedSearch::lss_dir_for($lei, \$o, 1); + if (-e $d) { + push @dirs, $d + } else { # keep going, like rm(1): + $cwd //= $lei->rel2abs('.'); + warn "--save was not used with $o cwd=$cwd\n"; } - File::Path::remove_tree($d, $opt); - } else { - $lei->fail("--save was not used with $out cwd=". - $lei->rel2abs('.')); } + my $save; + my $opt = { safe => 1 }; + if ($lei->{opt}->{verbose}) { + $opt->{verbose} = 1; + $save = SelectSaver->new($lei->{2}); + } + File::Path::remove_tree(@dirs, $opt); + $lei->fail if defined $cwd; } *_complete_forget_search = \&PublicInbox::LeiUp::_complete_up;