Class DocValuesFormat
- All Implemented Interfaces:
- NamedSPILoader.NamedSPI
- Direct Known Subclasses:
- Lucene90DocValuesFormat,- PerFieldDocValuesFormat
Note, when extending this class, the name (getName()) may written into the index in
 certain configurations. In order for the segment to be read, the name must resolve to your
 implementation via forName(String). This method uses Java's Service
 Provider Interface (SPI) to resolve format names.
 
If you implement your own format, make sure that it has a no-arg constructor so SPI can load it.
- See Also:
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDocValuesFormat(String name) Creates a new docvalues format.
- 
Method SummaryModifier and TypeMethodDescriptionreturns a list of all available format namesabstract DocValuesConsumerfieldsConsumer(SegmentWriteState state) Returns aDocValuesConsumerto write docvalues to the index.abstract DocValuesProducerfieldsProducer(SegmentReadState state) Returns aDocValuesProducerto read docvalues from the index.static DocValuesFormatlooks up a format by namefinal StringgetName()static voidreloadDocValuesFormats(ClassLoader classloader) Reloads the DocValues format list from the givenClassLoader.toString()
- 
Constructor Details- 
DocValuesFormatCreates a new docvalues format.The provided name will be written into the index segment in some configurations (such as when using PerFieldDocValuesFormat): in such configurations, for the segment to be read this class should be registered with Java's SPI mechanism (registered in META-INF/ of your jar file, etc).- Parameters:
- name- must be all ascii alphanumeric, and less than 128 characters in length.
 
 
- 
- 
Method Details- 
fieldsConsumerReturns aDocValuesConsumerto write docvalues to the index.- Throws:
- IOException
 
- 
fieldsProducerReturns aDocValuesProducerto read docvalues from the index.NOTE: by the time this call returns, it must hold open any files it will need to use; else, those files may be deleted. Additionally, required files may be deleted during the execution of this call before there is a chance to open them. Under these circumstances an IOException should be thrown by the implementation. IOExceptions are expected and will automatically cause a retry of the segment opening logic with the newly revised segments. - Throws:
- IOException
 
- 
getName- Specified by:
- getNamein interface- NamedSPILoader.NamedSPI
 
- 
toString
- 
forNamelooks up a format by name
- 
availableDocValuesFormatsreturns a list of all available format names
- 
reloadDocValuesFormatsReloads the DocValues format list from the givenClassLoader. Changes to the docvalues formats are visible after the method ends, all iterators (availableDocValuesFormats(),...) stay consistent.NOTE: Only new docvalues formats are added, existing ones are never removed or replaced. This method is expensive and should only be called for discovery of new docvalues formats on the given classpath/classloader! 
 
-