Class FilterDirectory
- java.lang.Object
-
- org.apache.lucene.store.Directory
-
- org.apache.lucene.store.FilterDirectory
-
- All Implemented Interfaces:
Closeable,AutoCloseable
- Direct Known Subclasses:
LockValidatingDirectoryWrapper,NRTCachingDirectory,SleepingLockWrapper,TrackingDirectoryWrapper
public abstract class FilterDirectory extends Directory
Directory implementation that delegates calls to another directory. This class can be used to add limitations on top of an existingDirectoryimplementation such asNRTCachingDirectoryor to add additional sanity checks for tests. However, if you plan to write your ownDirectoryimplementation, you should consider extending directlyDirectoryorBaseDirectoryrather than try to reuse functionality of existingDirectorys by extending this class.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedFilterDirectory(Directory in)Sole constructor, typically called from sub-classes.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Closes the directory.IndexOutputcreateOutput(String name, IOContext context)Creates a new, empty file in the directory and returns anIndexOutputinstance for appending data to this file.IndexOutputcreateTempOutput(String prefix, String suffix, IOContext context)Creates a new, empty, temporary file in the directory and returns anIndexOutputinstance for appending data to this file.voiddeleteFile(String name)Removes an existing file in the directory.protected voidensureOpen()Ensures this directory is still open.longfileLength(String name)Returns the byte length of a file in the directory.DirectorygetDelegate()Return the wrappedDirectory.Set<String>getPendingDeletions()Returns a set of files currently pending deletion in this directory.String[]listAll()Returns names of all files stored in this directory.LockobtainLock(String name)Acquires and returns aLockfor a file with the given name.IndexInputopenInput(String name, IOContext context)Opens a stream for reading an existing file.voidrename(String source, String dest)Renamessourcefile todestfile wheredestmust not already exist in the directory.voidsync(Collection<String> names)Ensures that any writes to these files are moved to stable storage (made durable).voidsyncMetaData()Ensures that directory metadata, such as recent file renames, are moved to stable storage.StringtoString()static Directoryunwrap(Directory dir)Get the wrapped instance bydiras long as this reader is an instance ofFilterDirectory.-
Methods inherited from class org.apache.lucene.store.Directory
copyFrom, getTempFileName, openChecksumInput
-
-
-
-
Field Detail
-
in
protected final Directory in
-
-
Constructor Detail
-
FilterDirectory
protected FilterDirectory(Directory in)
Sole constructor, typically called from sub-classes.
-
-
Method Detail
-
unwrap
public static Directory unwrap(Directory dir)
Get the wrapped instance bydiras long as this reader is an instance ofFilterDirectory.
-
listAll
public String[] listAll() throws IOException
Description copied from class:DirectoryReturns names of all files stored in this directory. The output must be in sorted (UTF-16, java'sString.compareTo(java.lang.String)) order.- Specified by:
listAllin classDirectory- Throws:
IOException- in case of I/O error
-
deleteFile
public void deleteFile(String name) throws IOException
Description copied from class:DirectoryRemoves an existing file in the directory.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
deleteFilein classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
fileLength
public long fileLength(String name) throws IOException
Description copied from class:DirectoryReturns the byte length of a file in the directory.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
fileLengthin classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
createOutput
public IndexOutput createOutput(String name, IOContext context) throws IOException
Description copied from class:DirectoryCreates a new, empty file in the directory and returns anIndexOutputinstance for appending data to this file.This method must throw
FileAlreadyExistsExceptionif the file already exists.- Specified by:
createOutputin classDirectory- Parameters:
name- the name of the file to create.- Throws:
IOException- in case of I/O error
-
createTempOutput
public IndexOutput createTempOutput(String prefix, String suffix, IOContext context) throws IOException
Description copied from class:DirectoryCreates a new, empty, temporary file in the directory and returns anIndexOutputinstance for appending data to this file.The temporary file name (accessible via
IndexOutput.getName()) will start withprefix, end withsuffixand have a reserved file extension.tmp.- Specified by:
createTempOutputin classDirectory- Throws:
IOException
-
sync
public void sync(Collection<String> names) throws IOException
Description copied from class:DirectoryEnsures that any writes to these files are moved to stable storage (made durable).Lucene uses this to properly commit changes to the index, to prevent a machine/OS crash from corrupting the index.
- Specified by:
syncin classDirectory- Throws:
IOException- See Also:
Directory.syncMetaData()
-
rename
public void rename(String source, String dest) throws IOException
Description copied from class:DirectoryRenamessourcefile todestfile wheredestmust not already exist in the directory.It is permitted for this operation to not be truly atomic, for example both
sourceanddestcan be visible temporarily inDirectory.listAll(). However, the implementation of this method must ensure the content ofdestappears as the entiresourceatomically. So oncedestis visible for readers, the entire content of previoussourceis visible.This method is used by IndexWriter to publish commits.
- Specified by:
renamein classDirectory- Throws:
IOException
-
syncMetaData
public void syncMetaData() throws IOExceptionDescription copied from class:DirectoryEnsures that directory metadata, such as recent file renames, are moved to stable storage.- Specified by:
syncMetaDatain classDirectory- Throws:
IOException- See Also:
Directory.sync(Collection)
-
openInput
public IndexInput openInput(String name, IOContext context) throws IOException
Description copied from class:DirectoryOpens a stream for reading an existing file.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
openInputin classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
obtainLock
public Lock obtainLock(String name) throws IOException
Description copied from class:DirectoryAcquires and returns aLockfor a file with the given name.- Specified by:
obtainLockin classDirectory- Parameters:
name- the name of the lock file- Throws:
LockObtainFailedException- (optional specific exception) if the lock could not be obtained because it is currently held elsewhere.IOException- if any i/o error occurs attempting to gain the lock
-
close
public void close() throws IOExceptionDescription copied from class:DirectoryCloses the directory.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein classDirectory- Throws:
IOException
-
getPendingDeletions
public Set<String> getPendingDeletions() throws IOException
Description copied from class:DirectoryReturns a set of files currently pending deletion in this directory.- Specified by:
getPendingDeletionsin classDirectory- Throws:
IOException
-
ensureOpen
protected void ensureOpen() throws AlreadyClosedExceptionDescription copied from class:DirectoryEnsures this directory is still open.- Overrides:
ensureOpenin classDirectory- Throws:
AlreadyClosedException- if this directory is closed.
-
-