From 475d0ded5b74f1561b84002904d841b7774cbecd Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Thu, 20 Aug 2020 20:24:37 +0000 Subject: [PATCH] compact: support --help/-? and perform lazy loading This probably won't be used much, but --help can still make sense. --- script/public-inbox-compact | 39 +++++++++++++++++++++++++++---------- 1 file changed, 29 insertions(+), 10 deletions(-) diff --git a/script/public-inbox-compact b/script/public-inbox-compact index b5fa0086..a6bb62bd 100755 --- a/script/public-inbox-compact +++ b/script/public-inbox-compact @@ -1,18 +1,37 @@ -#!/usr/bin/perl -w +#!perl -w # Copyright (C) 2018-2020 all contributors # License: AGPL-3.0+ use strict; -use warnings; +use v5.10.1; use Getopt::Long qw(:config gnu_getopt no_ignore_case auto_abbrev); -use PublicInbox::InboxWritable; -use PublicInbox::Xapcmd; -use PublicInbox::Admin; -PublicInbox::Admin::require_or_die('-index'); -my $usage = "Usage: public-inbox-compact INBOX_DIR\n"; +my $usage = 'public-inbox-compact INBOX_DIR'; my $opt = { compact => 1, -coarse_lock => 1 }; -GetOptions($opt, qw(all), @PublicInbox::Xapcmd::COMPACT_OPT) or - die "bad command-line args\n$usage"; -my @ibxs = PublicInbox::Admin::resolve_inboxes(\@ARGV, $opt) or die $usage; +my $help = <{help}) { print $help; exit 0 }; + +require PublicInbox::Admin; +PublicInbox::Admin::require_or_die('-index'); +PublicInbox::Admin::progress_prepare($opt); + +require PublicInbox::InboxWritable; +require PublicInbox::Xapcmd; +my @ibxs = PublicInbox::Admin::resolve_inboxes(\@ARGV, $opt); +unless (@ibxs) { print STDERR "Usage: $usage\n"; exit 1 } foreach (@ibxs) { my $ibx = PublicInbox::InboxWritable->new($_); PublicInbox::Xapcmd::run($ibx, 'compact', $opt); -- 2.44.0