Compare commits
2 Commits
release-4.
...
proper-del
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9a81f9ddb5 | ||
|
|
e1a620237a |
@@ -172,7 +172,6 @@ my %CONFIG;
|
|||||||
my $RELEASE = '4.2rc1';
|
my $RELEASE = '4.2rc1';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Read the global configuration file if it exists.
|
# Read the global configuration file if it exists.
|
||||||
#
|
#
|
||||||
@@ -220,7 +219,21 @@ while ( my $name = shift )
|
|||||||
{
|
{
|
||||||
if ( !xenRunning($name) )
|
if ( !xenRunning($name) )
|
||||||
{
|
{
|
||||||
deleteXenImage($name);
|
#
|
||||||
|
# Partition layout information values read from the
|
||||||
|
# partitions file, or constructed automatically if no
|
||||||
|
# partitions file is specified.
|
||||||
|
#
|
||||||
|
|
||||||
|
my @PARTITIONS = undef;
|
||||||
|
|
||||||
|
#
|
||||||
|
# Check for partitions to delete by reading the DomU's
|
||||||
|
# configuration file
|
||||||
|
#
|
||||||
|
my @PARTITIONS = findPartitions($host
|
||||||
|
|
||||||
|
deleteXenImage($name, @PARTITIONS);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -449,6 +462,70 @@ sub xenRunning
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Read the (usually to be deleted) DomU configuration file specified
|
||||||
|
and returns the list of used partitions found in the file.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub findPartitions
|
||||||
|
{
|
||||||
|
my ($hostname) = (@_);
|
||||||
|
my $file = "/etc/xen/$hostname.cfg";
|
||||||
|
|
||||||
|
if ( -e $file )
|
||||||
|
{
|
||||||
|
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
||||||
|
|
||||||
|
my $line = "";
|
||||||
|
my $contents = "";
|
||||||
|
|
||||||
|
while ( defined( $line = <FILE> ) )
|
||||||
|
{
|
||||||
|
chomp $line;
|
||||||
|
if ( $line =~ s/\\$// )
|
||||||
|
{
|
||||||
|
$line .= <FILE>;
|
||||||
|
redo unless eof(FILE);
|
||||||
|
}
|
||||||
|
|
||||||
|
# Skip lines beginning with comments
|
||||||
|
next if ( $line =~ /^([ \t]*)\#/ );
|
||||||
|
|
||||||
|
# Skip blank lines
|
||||||
|
next if ( length($line) < 1 );
|
||||||
|
|
||||||
|
# Strip trailing comments.
|
||||||
|
if ( $line =~ /(.*)\#(.*)/ )
|
||||||
|
{
|
||||||
|
$line = $1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$contents .= $line;
|
||||||
|
}
|
||||||
|
|
||||||
|
close(FILE);
|
||||||
|
|
||||||
|
if ($contents =~ /\ndisk\s*=\s*\[\s*(.*?)\s*\]\s*\n/) {
|
||||||
|
my $disks = $1;
|
||||||
|
my @disks = split(/\n/, $disks);
|
||||||
|
foreach (@disks) {
|
||||||
|
s/^\s*'phy:(.*),\w*,\w*',\s*$/$1/;
|
||||||
|
}
|
||||||
|
return @disks;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
warn "Couldn't find $file. May start guessing based on further parameters.\n";
|
||||||
|
return qw(GUESSING);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Delete the named image, and the corresponding configuration file
|
Delete the named image, and the corresponding configuration file
|
||||||
@@ -460,7 +537,11 @@ sub xenRunning
|
|||||||
|
|
||||||
sub deleteXenImage
|
sub deleteXenImage
|
||||||
{
|
{
|
||||||
my ($hostname) = (@_);
|
my $hostname = shift;
|
||||||
|
my @partitions = @_;
|
||||||
|
my $guessing = ($#partitions == 0 and $partitions[0] eq 'GUESSING');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Collect the names of files to delete.
|
# Collect the names of files to delete.
|
||||||
|
|||||||
Reference in New Issue
Block a user