NAME

Archive::SCS::HashFS2 - SCS HashFS version 2 format handler

SYNOPSIS

my $path = Path::Tiny->new('.../base_share.scs');
my $archive = Archive::SCS::HashFS2->new(path => $path)->mount;

$archive->read_dir_tree;
my @contents = sort $archive->list_dirs, $archive->list_files;

my $hash = Archive::SCS::CityHash::cityhash64('def/city.sii');
my $data = $archive->read_entry($hash);

DESCRIPTION

Represents an SCS archive file encoded in HashFS version 2 (1.50 and later).

Hash values used with this module must be in the internal format (currently, an 8-byte scalar PV in network byte order).

METHODS

entries

$entry_hashes = $archive->entries;

is_mounted

$bool = $archive->is_mounted;

handles_file

$bool = Archive::SCS::HashFS2->handles_file($fh, $header);

list_dirs

@directories = $archive->list_dirs;

list_files

@files = $archive->list_files;

mount

$archive = $archive->mount;

new

$archive = Archive::SCS::HashFS2->new(path => $path_tiny);

path

$path_tiny = $archive->path;

Since version 1.06.

In version 1.05 and earlier, there was an equivalent file() method, which is now deprecated.

read_dir_tree

$archive->read_dir_tree;

read_entry

$data = $archive->read_entry($hash);

unmount

$archive->unmount;

LIMITATIONS

Texture objects are currently unimplemented.

SEE ALSO

AUTHOR

nautofon

COPYRIGHT

This software is copyright (c) 2025 by nautofon.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.