OLE::Storage::Iolist - Data management for OLE::Storage::Io |
OLE::Storage::Iolist - Data management for OLE::Storage::Io (alpha)
use OLE::Storage::Iolist();
s.b.
Note: OLE::Storage uses Iolists in conjuntion with Io interface for IO operations. An IO entry is a two element list like ($offset, $length).
Sorts and merges Iolist $IoL, returns the new packed Iolist $NewIolist. Returns an empty Iolist on errors (!to be changed!). $method can be:
method sort offsets allow offset overlaps 1 yes no 2 yes yes 3 no no 4 no yes
Appends an entry to Iolist. Tries to merge the Iolists last entry with the new one. Returns the new last entry of Iolist.
rval: Get entry number $i.
($o, $l) == $IoL -> entry ($i, $o, $l)
lval: Set entry number $i to ($o, $l). Returns this entry.
rval: Get length of entry number $i.
$l == $IoL -> length ($i, $l)
lval: Set length of entry number $i to $l. Returns $l.
Returns number of $IoL's entries.
Iolist constructor. Returns an Iolist handle. Can be initialized with references to corresponding offset and length lists.
rval: Get offset of entry number $i.
$o == $IoL -> offset ($i, $o)
lval: Set offset of entry number $i to $o. Returns $o.
1
== $IoL -> push ($AnotherIolist)
Appends all entries of $AnotherIolist to $IoL.
Returns total length of $IoL's entries.
Martin Schwartz <schwartz@cs.tu-berlin.de>
OLE::Storage::Iolist - Data management for OLE::Storage::Io |