X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=script%2Fpublic-inbox-purge;h=7bca11eafc6fc81f1566a6c8fc6b37e27817e6fb;hb=352956bcf1933bdaeba631deb4ade7dc7fd754b1;hp=0705d170eae8806f706c75e246cd7594b2b20f20;hpb=6e507c8cb41b0d48963503a88034348d74506211;p=public-inbox.git diff --git a/script/public-inbox-purge b/script/public-inbox-purge index 0705d170..7bca11ea 100755 --- a/script/public-inbox-purge +++ b/script/public-inbox-purge @@ -1,5 +1,5 @@ #!/usr/bin/perl -w -# Copyright (C) 2019 all contributors +# Copyright (C) 2019-2020 all contributors # License: AGPL-3.0+ # # Used for purging messages entirely from a public-inbox. Currently @@ -9,26 +9,35 @@ use warnings; use Getopt::Long qw(:config gnu_getopt no_ignore_case auto_abbrev); use PublicInbox::AdminEdit; PublicInbox::Admin::check_require('-index'); -require PublicInbox::Filter::Base; -require PublicInbox::MIME; +use PublicInbox::Filter::Base qw(REJECT); +use PublicInbox::Eml; require PublicInbox::V2Writable; -{ no warnings 'once'; *REJECT = *PublicInbox::Filter::Base::REJECT } +my $help = < 1, all => 0, -min_inbox_version => 2 }; -GetOptions($opt, @PublicInbox::AdminEdit::OPT) or - die "bad command-line args\n$usage\n"; +GetOptions($opt, @PublicInbox::AdminEdit::OPT) or die $help; +if ($opt->{help}) { print $help; exit 0 }; my @ibxs = PublicInbox::Admin::resolve_inboxes(\@ARGV, $opt); PublicInbox::AdminEdit::check_editable(\@ibxs); -my $data = do { local $/; scalar }; +my $data = do { local $/; }; $data =~ s/\A[\r\n]*From [^\r\n]*\r?\n//s; my $n_purged = 0; foreach my $ibx (@ibxs) { - my $mime = PublicInbox::MIME->new($data); + my $mime = PublicInbox::Eml->new($data); my $v2w = PublicInbox::V2Writable->new($ibx, 0); my $commits = $v2w->purge($mime) || [];