NAME

DataStore::CAS::FS::DirEnt - Light-weight Immutable Directory Entry Object

VERSION

version 0.010100_03

DESCRIPTION

DataStore::CAS::FS::DirEnt is a super-light-weight class. More of an interface, really. DirEnt objects should be considered immutable constants, and all attributes are read-only. It is of course *possible* to modify them, but this will break caching features of DataStore::CAS::FS, so don't do that. In particular, DO NOT modify the hashref returned by "as_hash"

See the clone(%params) method for a convenient way to create modified copies of a DirEnt.

ATTRIBUTES

Each attribute is optional, except 'name' and 'type'. Accessors for non-existent attributes will return undef. To find out which attributes actually exist, use the as_hash method and inspect the keys.

name

The name of this entry within its directory.

Will either be a 7-bit ASCII string, a unicode-flagged string, or an instance of DataStore::CAS::FS::InvalidUTF8 (which stringifies to the original octets).

See "UNICODE vs. FILENAMES" in DataStore::CAS::FS.

type

One of "file", "dir", "symlink", "blockdev", "chardev", "pipe", "socket".

Note that 'symlink' refers only to UNIX style symlinks. As support is added for other systems' symbolic links, new type strings will be added to this list, and the type will determine how to interpret the ref value.

type must always be defined when stored, though instances of DirEnt with an undefined type might exist temporarily while building a new directory.

ref

For file or dir: the store's checksum of the referenced data.

For symlink: the path as a string of path parts separated by '/'.

For blockdev and chardev: the device node as a string of "$major,$minor".

Ref is allowed to be undefined (regardless of type) if the data is not known.

size

The size of the referenced file. In the case of directories, this is the size of the serialized directory, if one is referenced. No other types should have a size.

create_ts

The timestamp of the creation of the file, expressed in Unix Epoch seconds.

modify_ts

The timestamp the file was last modified, expressed in Unix Epoch seconds.

access_ts

The timestamp the file was last acessed, expressed in Unix Epoch seconds.

metadata_ts

The timestamp the file's metadata (or content) was last modified, expressed in Unix Epoch seconds.

unix_uid

The number reported by lstat for uid.

unix_gid

The number reported by lstat for gid

unix_user

The user name corresponding to the unix_uid

unix_group

The group name corresponding to the unix_gid

unix_mode

The unix permissions for the entry, as reported by lstat.

unix_atime

The unix atime, as reported by lstat.

unix_ctime

The unix ctime, as reported by lstat.

unix_mtime

An alias for modify_ts.

unix_dev

The device file number, as reported by lstat.

unix_inode

The inode number, as reported by lstat.

The the hardlink count reported by lstat.

unix_blocksize

The block size reported by lstat.

unix_blockcount

The block count reported by lstat.

METHODS

new

$dirEnt= DataStore::CAS::FS::DirEnt->new( %fields | \%fields )

The default constructor *uses* the hashref you pass to it. (it does not clone) This should be ok, because the DirEnt objects should never be modified. We don't yet enforce that though, so be careful what you pass to it.

clone

$dirEnt2= $dirEnt->clone( %overrides )

Create a new directory entry, with some fields overridden.

Most implementations will simply call new( %{$self->as_hash}, %overrides ), but in some implementations it might not be possible or practical to apply the requested overrides, so you might get back a different class than the original.

as_hash

$immutable_hash= $dirEnt->as_hash();

Returns the fields of the directory entry as a hashref. The hashref will contain only the public fields. The hashref might be cached, and SHOULD NEVER BE MODIFIED. (Future versions might use perl's constants feature to enforce this)

AUTHOR

Michael Conrad <mconrad@intellitree.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Michael Conrad, and IntelliTree Solutions llc.

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