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);
}