Class FilterDirectory
- All Implemented Interfaces:
Closeable
,AutoCloseable
- Direct Known Subclasses:
LockValidatingDirectoryWrapper
,NRTCachingDirectory
,SleepingLockWrapper
,TrackingDirectoryWrapper
Directory
implementation such as NRTCachingDirectory
or to add additional sanity checks for tests. However, if you plan to write
your own Directory
implementation, you should consider extending directly Directory
or BaseDirectory
rather than try to reuse functionality of existing Directory
s by extending this class.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
Sole constructor, typically called from sub-classes. -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Closes the directory.createOutput
(String name, IOContext context) Creates a new, empty file in the directory and returns anIndexOutput
instance for appending data to this file.createTempOutput
(String prefix, String suffix, IOContext context) Creates a new, empty, temporary file in the directory and returns anIndexOutput
instance for appending data to this file.void
deleteFile
(String name) Removes an existing file in the directory.protected void
Ensures this directory is still open.long
fileLength
(String name) Returns the byte length of a file in the directory.final Directory
Return the wrappedDirectory
.Returns a set of files currently pending deletion in this directory.String[]
listAll()
Returns names of all files stored in this directory.obtainLock
(String name) Acquires and returns aLock
for a file with the given name.Opens a stream for reading an existing file.void
Renamessource
file todest
file wheredest
must not already exist in the directory.void
sync
(Collection<String> names) Ensures that any writes to these files are moved to stable storage (made durable).void
Ensures that directory metadata, such as recent file renames, are moved to stable storage.toString()
static Directory
Get the wrapped instance bydir
as long as this reader is an instance ofFilterDirectory
.Methods inherited from class org.apache.lucene.store.Directory
copyFrom, getTempFileName, openChecksumInput
-
Field Details
-
in
-
-
Constructor Details
-
FilterDirectory
Sole constructor, typically called from sub-classes.
-
-
Method Details
-
unwrap
Get the wrapped instance bydir
as long as this reader is an instance ofFilterDirectory
. -
getDelegate
Return the wrappedDirectory
. -
listAll
Description copied from class:Directory
Returns 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:
listAll
in classDirectory
- Throws:
IOException
- in case of I/O error
-
deleteFile
Description copied from class:Directory
Removes an existing file in the directory.This method must throw either
NoSuchFileException
orFileNotFoundException
ifname
points to a non-existing file.- Specified by:
deleteFile
in classDirectory
- Parameters:
name
- the name of an existing file.- Throws:
IOException
- in case of I/O error
-
fileLength
Description copied from class:Directory
Returns the byte length of a file in the directory.This method must throw either
NoSuchFileException
orFileNotFoundException
ifname
points to a non-existing file.- Specified by:
fileLength
in classDirectory
- Parameters:
name
- the name of an existing file.- Throws:
IOException
- in case of I/O error
-
createOutput
Description copied from class:Directory
Creates a new, empty file in the directory and returns anIndexOutput
instance for appending data to this file.This method must throw
FileAlreadyExistsException
if the file already exists.- Specified by:
createOutput
in 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:Directory
Creates a new, empty, temporary file in the directory and returns anIndexOutput
instance for appending data to this file.The temporary file name (accessible via
IndexOutput.getName()
) will start withprefix
, end withsuffix
and have a reserved file extension.tmp
.- Specified by:
createTempOutput
in classDirectory
- Throws:
IOException
-
sync
Description copied from class:Directory
Ensures 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:
sync
in classDirectory
- Throws:
IOException
- See Also:
-
rename
Description copied from class:Directory
Renamessource
file todest
file wheredest
must not already exist in the directory.It is permitted for this operation to not be truly atomic, for example both
source
anddest
can be visible temporarily inDirectory.listAll()
. However, the implementation of this method must ensure the content ofdest
appears as the entiresource
atomically. So oncedest
is visible for readers, the entire content of previoussource
is visible.This method is used by IndexWriter to publish commits.
- Specified by:
rename
in classDirectory
- Throws:
IOException
-
syncMetaData
Description copied from class:Directory
Ensures that directory metadata, such as recent file renames, are moved to stable storage.- Specified by:
syncMetaData
in classDirectory
- Throws:
IOException
- See Also:
-
openInput
Description copied from class:Directory
Opens a stream for reading an existing file.This method must throw either
NoSuchFileException
orFileNotFoundException
ifname
points to a non-existing file.- Specified by:
openInput
in classDirectory
- Parameters:
name
- the name of an existing file.- Throws:
IOException
- in case of I/O error
-
obtainLock
Description copied from class:Directory
Acquires and returns aLock
for a file with the given name.- Specified by:
obtainLock
in 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
Description copied from class:Directory
Closes the directory.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
- Specified by:
close
in classDirectory
- Throws:
IOException
-
toString
-
getPendingDeletions
Description copied from class:Directory
Returns a set of files currently pending deletion in this directory.- Specified by:
getPendingDeletions
in classDirectory
- Throws:
IOException
-
ensureOpen
Description copied from class:Directory
Ensures this directory is still open.- Overrides:
ensureOpen
in classDirectory
- Throws:
AlreadyClosedException
- if this directory is closed.
-