Class MergePolicy.OneMerge

  • Enclosing class:
    MergePolicy

    public static class MergePolicy.OneMerge
    extends Object
    OneMerge provides the information necessary to perform an individual primitive merge operation, resulting in a single new segment. The merge spec includes the subset of segments to be merged as well as whether the new segment should use the compound file format.
    WARNING: This API is experimental and might change in incompatible ways in the next release.
    • Field Detail

      • estimatedMergeBytes

        public volatile long estimatedMergeBytes
        Estimated size in bytes of the merged segment.
      • totalMaxDoc

        public final int totalMaxDoc
        Total number of documents in segments to be merged, not accounting for deletions.
    • Method Detail

      • mergeInit

        public void mergeInit()
                       throws IOException
        Called by IndexWriter after the merge started and from the thread that will be executing the merge.
        Throws:
        IOException
      • setMergeInfo

        public void setMergeInfo​(SegmentCommitInfo info)
        Expert: Sets the SegmentCommitInfo of the merged segment. Allows sub-classes to e.g. set diagnostics properties.
      • segString

        public String segString()
        Returns a readable description of the current merge state.
      • totalBytesSize

        public long totalBytesSize()
        Returns the total size in bytes of this merge. Note that this does not indicate the size of the merged segment, but the input total size. This is only set once the merge is initialized by IndexWriter.
      • totalNumDocs

        public int totalNumDocs()
        Returns the total number of documents that are included with this merge. Note that this does not indicate the number of documents after the merge.
      • getStoreMergeInfo

        public MergeInfo getStoreMergeInfo()
        Return MergeInfo describing this merge.
      • isAborted

        public boolean isAborted()
        Returns true if this merge was or should be aborted.
      • setAborted

        public void setAborted()
        Marks this merge as aborted. The merge thread should terminate at the soonest possible moment.