diff options
author | Pascal Rigaux <pixel@mandriva.com> | 1999-10-09 13:26:41 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 1999-10-09 13:26:41 +0000 |
commit | fc5950e2eb1f9c0b7a1553f5717940d880e4853c (patch) | |
tree | f8fa3478c37b137673fca970963558e564f0916e /perl-install/resize_fat/directory.pm | |
parent | 870d622c6e3ed5d9a81c84e3f3d0fc287733472f (diff) | |
download | drakx-fc5950e2eb1f9c0b7a1553f5717940d880e4853c.tar drakx-fc5950e2eb1f9c0b7a1553f5717940d880e4853c.tar.gz drakx-fc5950e2eb1f9c0b7a1553f5717940d880e4853c.tar.bz2 drakx-fc5950e2eb1f9c0b7a1553f5717940d880e4853c.tar.xz drakx-fc5950e2eb1f9c0b7a1553f5717940d880e4853c.zip |
no_comment
Diffstat (limited to 'perl-install/resize_fat/directory.pm')
-rw-r--r-- | perl-install/resize_fat/directory.pm | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/perl-install/resize_fat/directory.pm b/perl-install/resize_fat/directory.pm new file mode 100644 index 000000000..46e810021 --- /dev/null +++ b/perl-install/resize_fat/directory.pm @@ -0,0 +1,78 @@ +package resize_fat::directory; + +use diagnostics; +use strict; + +use common qw(:system); +use resize_fat::dir_entry; +use resize_fat::io; + + +my $format = "a8 a3 C C C S7 I"; +my @fields = ( + 'name', + 'extension', + 'attributes', + 'is_upper_case_name', + 'creation_time_low', #- milliseconds + 'creation_time_high', + 'creation_date', + 'access_date', + 'first_cluster_high', #- for FAT32 + 'time', + 'date', + 'first_cluster', + 'length', +); + +1; + +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 +sub traverse($$$) { + my ($fs, $directory, $f) = @_; + + for (my $i = 0;; $i++) { + my $raw = \substr($directory, $i * psizeof($format), psizeof($format)); + + #- empty entry means end of directory + $$raw =~ /^\0*$/ and return $directory; + + my $entry; @{$entry}{@fields} = unpack $format, $$raw; + + &$f($entry) + and $$raw = pack $format, @{$entry}{@fields}; + } + $directory; +} + +sub traverse_all($$) { + my ($fs, $f) = @_; + + my $traverse_all; $traverse_all = sub { + my ($entry) = @_; + + &$f($entry); + + 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) + }; + + 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($fs, $directory, $traverse_all); +} + + +#- function used by construct_dir_tree to translate the `cluster' fields in each +#- directory entry +sub remap { + my ($fs, $directory) = @_; + + traverse($fs->{fat_remap}, $directory, sub { resize_fat::dir_entry::remap($fs->{fat_remap}, $_[0]) }); +} |