public class Lucene40LiveDocsFormat extends LiveDocsFormat
The .del file is optional, and only exists when a segment contains deletions.
Although per-segment, this file is maintained exterior to compound segment files.
Deletions (.del) --> Format,Header,ByteCount,BitCount, Bits | DGaps (depending on Format)
Uint32
Byte
> ByteCountVInt
Byte
CodecHeader
Format is 1: indicates cleared DGaps.
ByteCount indicates the number of bytes in Bits. It is typically (SegSize/8)+1.
BitCount indicates the number of bits that are currently set in Bits.
Bits contains one bit for each document indexed. When the bit corresponding to a document number is cleared, that document is marked as deleted. Bit ordering is from least to most significant. Thus, if Bits contains two bytes, 0x00 and 0x02, then document 9 is marked as alive (not deleted).
DGaps represents sparse bit-vectors more efficiently than Bits. It is made of DGaps on indexes of nonOnes bytes in Bits, and the nonOnes bytes themselves. The number of nonOnes bytes in Bits (NonOnesBytesCount) is not stored.
For example, if there are 8000 bits and only bits 10,12,32 are cleared, DGaps would be used:
(VInt) 1 , (byte) 20 , (VInt) 3 , (Byte) 1
Constructor and Description |
---|
Lucene40LiveDocsFormat()
Sole constructor.
|
Modifier and Type | Method and Description |
---|---|
void |
files(SegmentCommitInfo info,
Collection<String> files)
Records all files in use by this
SegmentCommitInfo into the files argument. |
MutableBits |
newLiveDocs(Bits existing)
Creates a new mutablebits of the same bits set and size of existing.
|
MutableBits |
newLiveDocs(int size)
Creates a new MutableBits, with all bits set, for the specified size.
|
Bits |
readLiveDocs(Directory dir,
SegmentCommitInfo info,
IOContext context)
Read live docs bits.
|
void |
writeLiveDocs(MutableBits bits,
Directory dir,
SegmentCommitInfo info,
int newDelCount,
IOContext context)
Persist live docs bits.
|
public MutableBits newLiveDocs(int size) throws IOException
LiveDocsFormat
newLiveDocs
in class LiveDocsFormat
IOException
public MutableBits newLiveDocs(Bits existing) throws IOException
LiveDocsFormat
newLiveDocs
in class LiveDocsFormat
IOException
public Bits readLiveDocs(Directory dir, SegmentCommitInfo info, IOContext context) throws IOException
LiveDocsFormat
readLiveDocs
in class LiveDocsFormat
IOException
public void writeLiveDocs(MutableBits bits, Directory dir, SegmentCommitInfo info, int newDelCount, IOContext context) throws IOException
LiveDocsFormat
SegmentCommitInfo.getNextDelGen()
to determine the
generation of the deletes file you should write to.writeLiveDocs
in class LiveDocsFormat
IOException
public void files(SegmentCommitInfo info, Collection<String> files) throws IOException
LiveDocsFormat
SegmentCommitInfo
into the files argument.files
in class LiveDocsFormat
IOException
Copyright © 2000-2014 Apache Software Foundation. All Rights Reserved.