From dc5dbda245332fd7d50855ff2e427a7a2742b791 Mon Sep 17 00:00:00 2001 From: Pascal Terjan Date: Sat, 7 Apr 2012 09:21:59 +0000 Subject: Simplify --- perl-install/partition_table/gpt.pm | 32 +++++++++++++------------------- 1 file changed, 13 insertions(+), 19 deletions(-) (limited to 'perl-install/partition_table') diff --git a/perl-install/partition_table/gpt.pm b/perl-install/partition_table/gpt.pm index 24e2f4029..9c4c17e65 100644 --- a/perl-install/partition_table/gpt.pm +++ b/perl-install/partition_table/gpt.pm @@ -10,39 +10,33 @@ use partition_table::raw; use c; my $nb_primary = 128; -#sub use_pt_type { 1 } sub read_one { my ($hd, $_sector) = @_; - my $info; c::get_disk_type($hd->{file}) eq "gpt" or die "not a GPT disk"; - my %parts = map { - my %p; - print $_; - if (/^([^ ]*) ([^ ]*) ([^ ]*) (.*) \((\d*),(\d*),(\d*)\)$/) { + + my @pt; + foreach (c::get_disk_partitions($hd->{file})) { + log::l($_); + if (/^([^ ]*) ([^ ]*) ([^ ]*) (.*) \((\d*),(\d*),(\d*)\)$/) { + my %p; $p{part_number} = $1; $p{real_device} = $2; $p{fs_type} = $3; $p{pt_type} = 0xba; $p{start} = $5; $p{size} = $7; + @pt[$p{part_number}-1] = \%p; } - $p{part_number} => \%p; - } c::get_disk_partitions($hd->{file}); + } - my @pt = map { - my $part_number = $_; - if ($parts{$part_number}) { - $parts{$part_number}; - } else { - my %p; - $p{part_number} = $part_number; - \%p; - } - } (1..$nb_primary); + for (my $part_number = 1; $part_number < $nb_primary; $part_number++) { + next if exists($pt[$part_number-1]); + $pt[$part_number-1] = { part_number => $part_number }; + } - [ @pt ], $info; + \@pt; } sub write { -- cgit v1.2.1