From b952046fe76751a3456921a6cd163ee84e8f3f49 Mon Sep 17 00:00:00 2001 From: Pascal Rigaux Date: Sun, 27 Jan 2002 20:32:19 +0000 Subject: handle --removable= --- perl-install/standalone/diskdrake | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'perl-install/standalone') diff --git a/perl-install/standalone/diskdrake b/perl-install/standalone/diskdrake index fd61ba6be..5578abd1f 100755 --- a/perl-install/standalone/diskdrake +++ b/perl-install/standalone/diskdrake @@ -43,20 +43,22 @@ if ($::isEmbedded) { print "mcc pid\t$::CCPID\n"; } -my %options = map { /-?-?(.*)/ => 1 } @ARGV; +my %options = map { /(.*?)=(.*)/ ? ($1,$2) : ($_,'') } map { if_(/--?(.*)/, $1) } @ARGV; $::expert = delete $options{expert}; $::testing = delete $options{testing}; my @types = qw(hd nfs smb removable fileshare); -my $type = 'hd'; +my ($type, $para) = ('hd', ''); foreach (@types) { - if (delete $options{$_}) { + if (exists $options{$_}) { + $para = delete $options{$_}; $type = $_; last; } } %options and die "usage: diskdrake [--expert] [--testing] [--{" . join(",", @types) . "}]\n"; +$type ne 'removable' || $para or die "usage: diskdrake --removable=\n"; if ($>) { $ENV{PATH} = "/sbin:/usr/sbin:$ENV{PATH}"; @@ -101,7 +103,9 @@ if ($type eq 'hd') { diskdrake::interactive::main($in, $all_hds); } elsif ($type eq 'removable') { require diskdrake::removable; - diskdrake::removable::main($in, $all_hds); + $para =~ s|^/dev/||; + my ($raw_hd) = grep { $para eq $_->{device} } @{$all_hds->{raw_hds}} or die "unknown removable $para\n"; + diskdrake::removable::main($in, $all_hds, $raw_hd); } else { $in->ask_warn('', "Sorry only a gtk frontend is available") if !$in->isa('interactive_gtk'); require diskdrake::smbnfs_gtk; -- cgit v1.2.1