X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=script%2Fpublic-inbox-xcpdb;h=2b9f032c5c01880efa6a8daa7d986bcea792272b;hb=95bdac7f09c69036efed537a4d03d5bdd2ae4eb6;hp=78d37da266153465878902475de3a40f0fd26521;hpb=371f00f2f0698915b49599a834696c7ae3631ce7;p=public-inbox.git diff --git a/script/public-inbox-xcpdb b/script/public-inbox-xcpdb index 78d37da2..2b9f032c 100755 --- a/script/public-inbox-xcpdb +++ b/script/public-inbox-xcpdb @@ -1,5 +1,5 @@ #!/usr/bin/perl -w -# Copyright (C) 2019 all contributors +# Copyright (C) 2019-2020 all contributors # License: AGPL-3.0+ # xcpdb: Xapian copy database, a wrapper around Xapian's copydatabase(1) use Getopt::Long qw(:config gnu_getopt no_ignore_case auto_abbrev); @@ -7,16 +7,13 @@ use PublicInbox::InboxWritable; use PublicInbox::Xapcmd; use PublicInbox::Admin; PublicInbox::Admin::require_or_die('-search'); -my $usage = "Usage: public-inbox-xcpdb INBOX_DIR\n"; +my $usage = "Usage: public-inbox-xcpdb [--compact] INBOX_DIR\n"; my $opt = {}; -GetOptions($opt, qw(compact)) or die "bad command-line args\n$usage"; +my @opt = (qw(compact reshard|R=i), @PublicInbox::Xapcmd::COMPACT_OPT); +GetOptions($opt, @opt) or die "bad command-line args\n$usage"; my @ibxs = PublicInbox::Admin::resolve_inboxes(\@ARGV) or die $usage; - -my $cmd = [ \&PublicInbox::Xapcmd::cpdb ]; -open my $null, '>', '/dev/null' or die "failed to open /dev/null: $!\n"; -$opt->{1} = fileno($null); foreach (@ibxs) { my $ibx = PublicInbox::InboxWritable->new($_); # we rely on --no-renumber to keep docids synched to NNTP - PublicInbox::Xapcmd::run($ibx, $cmd, undef, $opt); + PublicInbox::Xapcmd::run($ibx, 'cpdb', $opt); }