Re: Resource Fork as Extended Attributes
Re: Resource Fork as Extended Attributes
- Subject: Re: Resource Fork as Extended Attributes
- From: Anton Altaparmakov <email@hidden>
- Date: Wed, 15 Jul 2009 08:55:09 +0100
Hi,
On 15 Jul 2009, at 03:46, shailesh jain wrote:
Are resource forks and finder metadata stored as Extended
attributes on OS X 10.4+ ?.
Depends on which file system you are talking about but even on HFS+
you can access the resource fork both via the extended attribute
interface and via the named stream interface.
For NTFS both are the same thing the way I implemented them on Mac OS
X, i.e. when using the extended attribute system calls and when using
the named stream interface (currently limited by Mac OS X to accessing
the resource fork only) you both times get to access the NTFS named
streams.
The difference is only in the API and associated semantics with the
biggest and most important difference being that using the extended
attribute interface provides atomic access, i.e. you can only get/set
an entire attribute (exception: resource fork where you can use an
offset for partial access but this is a horrible kludge), whilst with
the named stream interface you get to access the attribute on a per-
byte basis just like when reading/writing a normal file.
Also, what is best way to handle resource forks and metadata, if the
file is going to be transferred on different file systems (NTFS,
ext3 etc) and back ?
-- Interconversion of Streams (NTFS) <-> Resource forks
The NTFS driver on Mac OS X will automatically store the resource fork
in appropriate NTFS named stream. The name and syntax are stored in a
100% compatible way with the Services For Macintosh available on
Windows to provide compatibility on that front as well.
-- Storing Resource forks, Streams, as Extended Attributes ? (This
will limit the size and lead to
shocking user experience)
Depends on the file system. Some file systems have very limited EAs
in their metadata format whilst others are not limited. This
limitation is only one of the reasons I decided to use NTFS named
streams to store Mac OS X extended attributes as on NTFS the total
number of all extended attributes and their metadata is otherwise
limited to 64kiB which is very small!
-- Apple Double format ?
Urgh. I would stay away from that if possible to provide native
storage. If not then I guess it is better than not having it.
Best regards,
Anton
--
Anton Altaparmakov <aia21 at cam.ac.uk> (replace at with @)
Unix Support, Computing Service, University of Cambridge, CB2 3QH, UK
Linux NTFS maintainer, http://www.linux-ntfs.org/
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Darwin-kernel mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden