Package org.apache.lucene.index
Class IndexCommit
- java.lang.Object
-
- org.apache.lucene.index.IndexCommit
-
- All Implemented Interfaces:
Comparable<IndexCommit>
public abstract class IndexCommit extends Object implements Comparable<IndexCommit>
Expert: represents a single commit into an index as seen by theIndexDeletionPolicy
orIndexReader
.Changes to the content of an index are made visible only after the writer who made that change commits by writing a new segments file (
segments_N
). This point in time, when the action of writing of a new segments file to the directory is completed, is an index commit.Each index commit point has a unique segments file associated with it. The segments file associated with a later index commit point would have a larger N.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
-
-
Constructor Summary
Constructors Modifier Constructor Description protected
IndexCommit()
Sole constructor.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description int
compareTo(IndexCommit commit)
abstract void
delete()
Delete this commit point.boolean
equals(Object other)
Two IndexCommits are equal if both their Directory and versions are equal.abstract Directory
getDirectory()
Returns theDirectory
for the index.abstract Collection<String>
getFileNames()
Returns all index files referenced by this commit point.abstract long
getGeneration()
Returns the generation (the _N in segments_N) for this IndexCommitabstract int
getSegmentCount()
Returns number of segments referenced by this commit.abstract String
getSegmentsFileName()
Get the segments file (segments_N
) associated with this commit point.abstract Map<String,String>
getUserData()
Returns userData, previously passed toIndexWriter.setLiveCommitData(Iterable)
for this commit.int
hashCode()
abstract boolean
isDeleted()
Returns true if this commit should be deleted; this is only used byIndexWriter
after invoking theIndexDeletionPolicy
.
-
-
-
Method Detail
-
getSegmentsFileName
public abstract String getSegmentsFileName()
Get the segments file (segments_N
) associated with this commit point.
-
getFileNames
public abstract Collection<String> getFileNames() throws IOException
Returns all index files referenced by this commit point.- Throws:
IOException
-
delete
public abstract void delete()
Delete this commit point. This only applies when using the commit point in the context of IndexWriter's IndexDeletionPolicy.Upon calling this, the writer is notified that this commit point should be deleted.
Decision that a commit-point should be deleted is taken by the
IndexDeletionPolicy
in effect and therefore this should only be called by itsonInit()
oronCommit()
methods.
-
isDeleted
public abstract boolean isDeleted()
Returns true if this commit should be deleted; this is only used byIndexWriter
after invoking theIndexDeletionPolicy
.
-
getSegmentCount
public abstract int getSegmentCount()
Returns number of segments referenced by this commit.
-
equals
public boolean equals(Object other)
Two IndexCommits are equal if both their Directory and versions are equal.
-
getGeneration
public abstract long getGeneration()
Returns the generation (the _N in segments_N) for this IndexCommit
-
getUserData
public abstract Map<String,String> getUserData() throws IOException
Returns userData, previously passed toIndexWriter.setLiveCommitData(Iterable)
for this commit. Map isString -> String
.- Throws:
IOException
-
compareTo
public int compareTo(IndexCommit commit)
- Specified by:
compareTo
in interfaceComparable<IndexCommit>
-
-