/usr/sbin/fcm-backup-svn-repos is in fcm 2017.10.0-1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | #!/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 <http://www.gnu.org/licenses/>.
# ------------------------------------------------------------------------------
use strict;
use warnings;
use FindBin;
use lib "$FindBin::Bin/../lib";
use FCM::Admin::System qw{
backup_svn_repository
filter_projects
get_projects_from_svn_live
};
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{no-housekeep-dumps},
q{no-pack},
q{no-verify-integrity},
q{svn-backup-dir=s},
q{svn-dump-dir=s},
q{svn-live-dir=s},
q{svn-project-suffix=s},
);
if (!$result) {
pod2usage(1);
}
if (exists($option{help})) {
pod2usage(q{-verbose} => 1);
}
option2config(\%option);
my @projects = filter_projects([get_projects_from_svn_live()], \@ARGV);
for my $project (@projects) {
backup_svn_repository(\%option, $project);
}
}
__END__
=head1 NAME
fcm-backup-svn-repos
=head1 SYNOPSIS
fcm-backup-svn-repos [OPTIONS] [PROJECT ...]
=head1 OPTIONS
=over 4
=item --help, -h, --usage
Prints help and exits.
=item --no-housekeep-dumps
If this option is specified, the program will not housekeep the backup revision
dumps of each repository.
=item --no-pack
If this option is specified, the program will not pack each repository before
running the backup.
=item --no-verify-integrity
If this option is specified, the program will not verify the integrity of a
repository before running the backup.
=item --svn-backup-dir=DIR
Specifies the root location of the backup directory. See
L<FCM::Admin::Config|FCM::Admin::Config> for the current default.
=item --svn-dump-dir=DIR
Specifies the root location of the directory where revision dumps are kept. See
L<FCM::Admin::Config|FCM::Admin::Config> for the current default.
=item --svn-live-dir=DIR
Specifies the root location of the live directory. See
L<FCM::Admin::Config|FCM::Admin::Config> for the current default.
=item --svn-project-suffix=NAME
Specifies the suffix added to the project name. The default is "_svn".
=back
=head1 ARGUMENTS
=over 4
=item PROJECT
Specifies one or more project to back up. If no project is specified, the
program searches the live directory for projects to back up.
=back
=head1 DESCRIPTION
This program archives Subversion repositories in the live directory to the
backup directory.
=head1 COPYRIGHT
E<169> Crown copyright Met Office. All rights reserved.
=cut
|