#!/usr/bin/perl # ------------------------------------------------------------------------------ # (C) British Crown Copyright 2006-17 Met Office. # # This file is part of FCM, tools for managing and building source code. # # FCM is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # FCM is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with FCM. If not, see . # ------------------------------------------------------------------------------ use strict; use warnings; use FindBin; use lib "$FindBin::Bin/../lib"; use FCM::Admin::System qw{ filter_projects get_projects_from_trac_live vacuum_trac_env_db }; use FCM::Admin::Util qw{option2config}; use Getopt::Long qw{GetOptions}; use Pod::Usage qw{pod2usage}; main(); sub main { my %option; my $result = GetOptions( \%option, q{help|usage|h}, q{trac-live-dir=s}, ); if (!$result) { pod2usage(1); } if (exists($option{help})) { pod2usage(q{-verbose} => 1); } option2config(\%option); my @projects = filter_projects([get_projects_from_trac_live()], \@ARGV); for my $project (@projects) { vacuum_trac_env_db($project); } } __END__ =head1 NAME fcm-vacuum-trac-env-db =head1 SYNOPSIS fcm-vacuum-trac-env-db [OPTIONS] [PROJECT ...] =head1 OPTIONS =over 4 =item --help, -h, --usage Prints help and exits. =item --trac-live-dir=DIR Specifies the root location of the live directory of Trac environments. See L for the current default. =back =head1 ARGUMENTS =over 4 =item PROJECT Specifies one or more project to vacuum. If no project is specified, the program searches the live directory for projects to vacuum. =back =head1 DESCRIPTION This program issues the "VACUUM" SQL command in the databases of the Trac environments in the live directory. =head1 COPYRIGHT E<169> Crown copyright Met Office. All rights reserved. =cut