NAME
Lucy::Index::DataWriter - Write data to an index.
SYNOPSIS
# Abstract base class.
DESCRIPTION
DataWriter is an abstract base class for writing index data, generally in segment-sized chunks. Each component of an index – e.g. stored fields, lexicon, postings, deletions – is represented by a DataWriter/DataReader pair.
Components may be specified per index by subclassing Architecture.
CONSTRUCTORS
new
my $writer = MyDataWriter->new(
snapshot => $snapshot, # required
segment => $segment, # required
polyreader => $polyreader, # required
);
Abstract constructor.
snapshot - The Snapshot that will be committed at the end of the indexing session.
segment - The Segment in progress.
polyreader - A PolyReader representing all existing data in the index. (If the index is brand new, the PolyReader will have no sub-readers).
ABSTRACT METHODS
add_segment
$data_writer->add_segment(
reader => $reader, # required
doc_map => $doc_map, # default: undef
);
Add content from an existing segment into the one currently being written.
reader - The SegReader containing content to add.
doc_map - An array of integers mapping old document ids to new. Deleted documents are mapped to 0, indicating that they should be skipped.
finish
$data_writer->finish();
Complete the segment: close all streams, store metadata, etc.
format
my $int = $data_writer->format();
Every writer must specify a file format revision number, which should increment each time the format changes. Responsibility for revision checking is left to the companion DataReader.
METHODS
delete_segment
$data_writer->delete_segment($reader);
Remove a segment’s data. The default implementation is a no-op, as all files within the segment directory will be automatically deleted. Subclasses which manage their own files outside of the segment system should override this method and use it as a trigger for cleaning up obsolete data.
reader - The SegReader containing content to merge, which must represent a segment which is part of the the current snapshot.
merge_segment
$data_writer->merge_segment(
reader => $reader, # required
doc_map => $doc_map, # default: undef
);
Move content from an existing segment into the one currently being written.
The default implementation calls add_segment() then delete_segment().
reader - The SegReader containing content to merge, which must represent a segment which is part of the the current snapshot.
doc_map - An array of integers mapping old document ids to new. Deleted documents are mapped to 0, indicating that they should be skipped.
metadata
my $hashref = $data_writer->metadata();
Arbitrary metadata to be serialized and stored by the Segment. The default implementation supplies a hash with a single key-value pair for “format”.
get_snapshot
my $snapshot = $data_writer->get_snapshot();
Accessor for “snapshot” member var.
get_segment
my $segment = $data_writer->get_segment();
Accessor for “segment” member var.
get_polyreader
my $poly_reader = $data_writer->get_polyreader();
Accessor for “polyreader” member var.
get_schema
my $schema = $data_writer->get_schema();
Accessor for “schema” member var.
get_folder
my $folder = $data_writer->get_folder();
Accessor for “folder” member var.
INHERITANCE
Lucy::Index::DataWriter isa Clownfish::Obj.