summaryrefslogtreecommitdiffstats
path: root/perl-install/resize_fat/directory.pm
diff options
context:
space:
mode:
Diffstat (limited to 'perl-install/resize_fat/directory.pm')
-rw-r--r--perl-install/resize_fat/directory.pm43
1 files changed, 21 insertions, 22 deletions
diff --git a/perl-install/resize_fat/directory.pm b/perl-install/resize_fat/directory.pm
index 1bc1014c6..ab8ec5328 100644
--- a/perl-install/resize_fat/directory.pm
+++ b/perl-install/resize_fat/directory.pm
@@ -14,36 +14,35 @@ my @fields = (
'extension',
'attributes',
'is_upper_case_name',
- 'creation_time_low', #- milliseconds
+ 'creation_time_low', # milliseconds
'creation_time_high',
'creation_date',
'access_date',
- 'first_cluster_high', #- for FAT32
+ 'first_cluster_high', # for FAT32
'time',
'date',
'first_cluster',
'length',
);
-my $psizeof_format = psizeof($format);
1;
-sub entry_size { $psizeof_format }
+sub entry_size { psizeof($format) }
-#- call `f' for each entry of the directory
-#- if f return true, then modification in the entry are taken back
+# call `f' for each entry of the directory
+# if f return true, then modification in the entry are taken back
sub traverse($$$) {
- my ($directory, $curr_dir_name, $f) = @_;
+ my ($fs, $directory, $f) = @_;
- for (my $i = 0;; $i++) {
- my $raw = \substr($directory, $i * $psizeof_format, $psizeof_format);
+ for (my $i = 0; 1; $i++) {
+ my $raw = \substr($directory, $i * psizeof($format), psizeof($format));
- #- empty entry means end of directory
+ # empty entry means end of directory
$$raw =~ /^\0*$/ and return $directory;
my $entry; @{$entry}{@fields} = unpack $format, $$raw;
- &$f($curr_dir_name, $entry)
+ &$f($entry)
and $$raw = pack $format, @{$entry}{@fields};
}
$directory;
@@ -53,27 +52,27 @@ sub traverse_all($$) {
my ($fs, $f) = @_;
my $traverse_all; $traverse_all = sub {
- my ($curr_dir_name, $entry) = @_;
+ my ($entry) = @_;
- &$f($curr_dir_name, $entry);
+ &$f($entry);
- resize_fat::dir_entry::is_directory($entry)
- and traverse(resize_fat::io::read_file($fs, resize_fat::dir_entry::get_cluster($entry)), "$curr_dir_name/$entry->{name}", $traverse_all);
+ resize_fat::dir_entry::is_directory($entry)
+ and traverse($fs, resize_fat::io::read_file($fs, resize_fat::dir_entry::get_cluster($entry)), $traverse_all);
- undef; #- no need to write back (cf traverse)
+ undef; # no need to write back (cf traverse)
};
my $directory = $resize_fat::isFAT32 ?
resize_fat::io::read_file($fs, $fs->{fat32_root_dir_cluster}) :
resize_fat::io::read($fs, $fs->{root_dir_offset}, $fs->{root_dir_size});
- traverse($directory, "", $traverse_all);
- undef $traverse_all; #- circular reference is no good for perl's poor GC :(
+ traverse($fs, $directory, $traverse_all);
}
-#- function used by construct_dir_tree to translate the `cluster' fields in each
-#- directory entry
-sub remap($$) {
+# function used by construct_dir_tree to translate the `cluster' fields in each
+# directory entry
+sub remap {
my ($fs, $directory) = @_;
- traverse($directory, "", \&resize_fat::dir_entry::remap);
+
+ traverse($fs->{fat_remap}, $directory, sub { resize_fat::dir_entry::remap($fs->{fat_remap}, $_[0]) });
}