Class IonReaderBuilder
- Direct Known Subclasses:
_Private_IonReaderBuilder
IonReader from the given IonCatalog and data
source. A data source is required, while an IonCatalog is optional. If no
IonCatalog is provided, an empty SimpleCatalog will be used.
IonReaders parse incrementally, so syntax errors in the input data
will not be detected as side effects of any of the build methods
in this class.
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedprotected -
Method Summary
Modifier and TypeMethodDescriptionbuild(byte[] ionData) Based on the builder's configuration properties, creates a new IonReader instance over the given block of Ion data, detecting whether it's text or binary data.abstract IonReaderbuild(byte[] ionData, int offset, int length) Based on the builder's configuration properties, creates a new IonReader instance over the given block of Ion data, detecting whether it's text or binary data.abstract IonReaderabstract IonReaderbuild(InputStream ionData) Based on the builder's configuration properties, creates a new IonReader instance over the given stream of Ion data, detecting whether it's text or binary data.abstract IonReaderBased on the builder's configuration properties, creates a newIonReaderinstance over Ion text data.abstract IonTextReaderBased on the builder's configuration properties, creates an newIonReaderinstance over Ion text data.copy()Creates a mutable copy of this builder.Gets the catalog to use when building anIonReader, or null if none has been manually set.Returns an immutable builder configured exactly like this one.booleanmutable()Returns a mutable builder configured exactly like this one.protected voidNOT FOR APPLICATION USE!voidsetBufferConfiguration(IonBufferConfiguration configuration) voidsetCatalog(IonCatalog catalog) Sets the catalog to use when building anIonReader.voidvoidstatic IonReaderBuilderstandard()The standard builder ofIonReaders, with all configuration properties having their default values.protected IonCatalogwithBufferConfiguration(IonBufferConfiguration configuration) Sets the buffer configuration.withCatalog(IonCatalog catalog) Declares the catalog to use when building anIonReader, returning a new mutable builder the current one is immutable.withIncrementalReadingEnabled(boolean isEnabled) Determines whether the IonReader will allow incremental reading of binary Ion data.
-
Constructor Details
-
IonReaderBuilder
protected IonReaderBuilder() -
IonReaderBuilder
-
-
Method Details
-
standard
The standard builder ofIonReaders, with all configuration properties having their default values.- Returns:
- a new, mutable builder instance.
-
copy
Creates a mutable copy of this builder.- Returns:
- a new builder with the same configuration as
this.
-
immutable
Returns an immutable builder configured exactly like this one.- Returns:
- this builder instance, if immutable; otherwise an immutable copy of this builder.
-
mutable
Returns a mutable builder configured exactly like this one.- Returns:
- this instance, if mutable; otherwise a mutable copy of this instance.
-
mutationCheck
protected void mutationCheck()NOT FOR APPLICATION USE! -
withCatalog
Declares the catalog to use when building anIonReader, returning a new mutable builder the current one is immutable.- Parameters:
catalog- the catalog to use in built readers. If null, a newSimpleCatalogwill be used.- Returns:
- this builder instance, if mutable; otherwise a mutable copy of this builder.
- See Also:
-
setCatalog
Sets the catalog to use when building anIonReader.- Parameters:
catalog- the catalog to use in built readers. If null, a newSimpleCatalogwill be used.- Throws:
UnsupportedOperationException- if this builder is immutable.- See Also:
-
getCatalog
Gets the catalog to use when building anIonReader, or null if none has been manually set. The catalog is needed to resolve shared symbol table imports.- See Also:
-
validateCatalog
-
withIncrementalReadingEnabled
Determines whether the IonReader will allow incremental reading of binary Ion data. When enabled, if
IonReader.next()returnsnullat the top-level, it indicates that there is not enough data in the stream to complete a top-level value. The user may wait for more data to become available in the stream and callIonReader.next()again to continue reading. Unlike the non-incremental reader, the incremental reader will never throw an exception due to unexpected EOF duringnext(). If, however,Closeable.close()is called when an incomplete value is buffered, anIonExceptionwill be raised.There is currently no incremental text IonReader, so for text data a non-incremental IonReader will be returned regardless of the value of this option. If incremental text reading is supported in the future, it may be enabled via this option.
There is one caveat to note when using this option: the incremental implementation must be able to buffer an entire top-level value in memory. This will not be a problem for the vast majority of Ion streams, as it is rare for a single top-level value or symbol table to exceed a few megabytes in size. However, if the size of the stream's values risks exceeding the available memory, then this option must not be enabled.
- Parameters:
isEnabled- true if the option is enabled; otherwise, false.- Returns:
- this builder instance, if mutable; otherwise a mutable copy of this builder.
- See Also:
-
setIncrementalReadingEnabled
public void setIncrementalReadingEnabled()- See Also:
-
setIncrementalReadingDisabled
public void setIncrementalReadingDisabled()- See Also:
-
isIncrementalReadingEnabled
public boolean isIncrementalReadingEnabled()- Returns:
- true if incremental reading is enabled; otherwise, false.
- See Also:
-
withBufferConfiguration
Sets the buffer configuration. This can be used, for example, to set a maximum buffer size and receive notifications when values would exceed this size. Currently, this is ignored unless incremental reading has been enabled viawithIncrementalReadingEnabled(boolean)) orsetIncrementalReadingEnabled(). This configuration is optional. If not provided, the buffer size will be limited only by the available memory.- Parameters:
configuration- the configuration.- Returns:
- this builder instance, if mutable; otherwise a mutable copy of this builder.
- See Also:
-
setBufferConfiguration
- See Also:
-
getBufferConfiguration
- Returns:
- the current configuration.
- See Also:
-
build
Based on the builder's configuration properties, creates a new IonReader instance over the given block of Ion data, detecting whether it's text or binary data.This method will auto-detect and uncompress GZIPped Ion data.
- Parameters:
ionData- the source of the Ion data, which may be either Ion binary data or UTF-8 Ion text. The reader retains a reference to the array, so its data must not be modified while the reader is active. Must not be null.- Returns:
- a new
IonReaderinstance; notnull. - See Also:
-
build
Based on the builder's configuration properties, creates a new IonReader instance over the given block of Ion data, detecting whether it's text or binary data.This method will auto-detect and uncompress GZIPped Ion data.
- Parameters:
ionData- the source of the Ion data, which is used only within the range of bytes starting atoffsetforlenbytes. The data in that range may be either Ion binary data or UTF-8 Ion text. The reader retains a reference to the array, so its data must not be modified while the reader is active. Must not be null.offset- must be non-negative and less thanionData.length.length- must be non-negative andoffset+lengthmust not exceedionData.length.- See Also:
-
build
Based on the builder's configuration properties, creates a new IonReader instance over the given stream of Ion data, detecting whether it's text or binary data.This method will auto-detect and uncompress GZIPped Ion data.
Because this library performs its own buffering, it's recommended that users avoid adding additional buffering to the given stream.
- Parameters:
ionData- the source of the Ion data, which may be either Ion binary data or UTF-8 Ion text. Must not be null.- Returns:
- a new reader instance.
Callers must call
Closeable.close()when finished with it. - Throws:
IonException- if the source throwsIOException.- See Also:
-
build
Based on the builder's configuration properties, creates a newIonReaderinstance over Ion text data.Applications should generally use
build(InputStream)whenever possible, since this library has much faster Unicode decoding than the Java IO framework.Because this library performs its own buffering, it's recommended that you avoid adding additional buffering to the given stream.
- Parameters:
ionText- the source of the Ion text data. Must not be null.- Throws:
IonException- if the source throwsIOException.- See Also:
-
build
Based on the builder's configuration properties, creates a newIonReaderinstance over anIonValuedata model. Typically this is used to iterate over a collection, such as anIonStruct. The given value and its children, if any, must not be modified until after the IonReader constructed by this method is closed. Violating this constraint results in undefined behavior.- Parameters:
value- must not be null.- See Also:
-
build
Based on the builder's configuration properties, creates an newIonReaderinstance over Ion text data.- Parameters:
ionText- the source of the Ion text data. Must not be null.- See Also:
-