NAME
XBase::Base - Base input output module for XBase suite
SYNOPSIS
Used indirectly, via XBase or XBase::Memo.
DESCRIPTION
This module provides catch-all I/O methods for other XBase classes, should be used by people creating additional XBase classes/methods. The methods return nothing (undef) or error and the error message can be retrieved using the errstr method. If the $XBase::Base::DEBUG variable is true, they also print the message on stderr, so the caller doesn't need to do this, just die or ignore the problem.
Methods are:
- new
-
Constructor. Creates the object and if the file name is specified, opens the file.
- open
-
Opens the file and using method read_header reads the header and sets the object's data structure. The read_header should be defined in the derived class, there is no default.
- close
-
Closes the file, doesn't destroy the object.
- get_record_offset
-
The argument is the number of the record, if returns the number
$header_len + $number * $record_len
using values from the object. Please note, that I use the term record here, even if in memo files the name block and in indexes page is more common. It's because I tried to unify the methods. Maybe it's a nonsense and we will drop this idea in the next version ;-)
- seek_to_record
-
Seeks to record of given number.
- seek_to
-
Seeks to given position. It undefs the tell value in the object, since it assumes the users that will do print afterwards would not update it.
- read_record
-
Reads specified record from get_record_offset position. You can give second parameter saying length (in bytes) you want to read. The default is record_len. If the required length is -1, it will read record_len but will not complain if the file is shorter. Whis is nice on the end of memo file.
The method caches last record read. Also, when key unpack_template is specified in the object, it unpacks the string read and returns list of resulting values.
- write_record, write_to
-
Writes data to specified record position or to the absolute position in the file.
VERSION
0.034
AUTHOR
(c) Jan Pazdziora, adelton@fi.muni.cz
SEE ALSO
perl(1), XBase(3)