public class H4iosp extends AbstractIOServiceProvider
IOServiceProvider.SortGroup
location, ncfile, raf, rafOrder
Constructor and Description |
---|
H4iosp() |
Modifier and Type | Method and Description |
---|---|
void |
build(RandomAccessFile raf,
Group.Builder rootGroup,
CancelTask cancelTask)
Open existing file, and populate it.
|
java.lang.String |
getFileTypeDescription()
Get a human-readable description for this file type.
|
java.lang.String |
getFileTypeId()
Get a unique id for this file type.
|
java.lang.String |
getFileTypeVersion()
Get the version of this file type.
|
protected java.util.Optional<java.nio.charset.Charset> |
getValueCharset()
Return
value charset if it was defined. |
boolean |
isBuilder()
If this iosp implements build().
|
boolean |
isValidFile(RandomAccessFile raf)
Check if this is a valid file for this IOServiceProvider.
|
void |
open(RandomAccessFile raf,
NetcdfFile ncfile,
CancelTask cancelTask)
Open existing file, and populate ncfile with it.
|
void |
reacquire()
Reacquire any resources like file handles
Used when reactivating in cache.
|
Array |
readData(Variable v,
Section section)
Read data from a top level Variable and return a memory resident Array.
|
java.lang.Object |
sendIospMessage(java.lang.Object message)
A way to communicate arbitrary information to and from an iosp.
|
protected void |
setValueCharset(java.nio.charset.Charset charset)
Define
value charset . |
java.lang.String |
toStringDebug(java.lang.Object o)
Debug info for this object.
|
buildFinish, close, getDetailInfo, getLastModified, getStructureIterator, readSection, readToByteChannel, readToOutputStream, release, setNetcdfFile, streamToByteChannel, syncExtend
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
compareTo, getSortGroup
public boolean isValidFile(RandomAccessFile raf) throws java.io.IOException
IOServiceProvider
raf
- RandomAccessFilejava.io.IOException
- if read errorpublic java.lang.String getFileTypeId()
IOServiceProvider
public java.lang.String getFileTypeDescription()
IOServiceProvider
public java.lang.String getFileTypeVersion()
IOServiceProvider
getFileTypeVersion
in interface IOServiceProvider
getFileTypeVersion
in class AbstractIOServiceProvider
public void open(RandomAccessFile raf, NetcdfFile ncfile, CancelTask cancelTask) throws java.io.IOException
IOServiceProvider
open
in interface IOServiceProvider
open
in class AbstractIOServiceProvider
raf
- the file to work on, it has already passed the isValidFile() test.ncfile
- add objects to this empty NetcdfFilecancelTask
- used to monitor user cancellation; may be null.java.io.IOException
- if read errorpublic boolean isBuilder()
IOServiceProvider
isBuilder
in interface IOServiceProvider
isBuilder
in class AbstractIOServiceProvider
public void build(RandomAccessFile raf, Group.Builder rootGroup, CancelTask cancelTask) throws java.io.IOException
IOServiceProvider
build
in interface IOServiceProvider
build
in class AbstractIOServiceProvider
raf
- the file to work on, it has already passed the isValidFile() test.rootGroup
- add objects to the root group.cancelTask
- used to monitor user cancellation; may be null.java.io.IOException
- if read errorpublic Array readData(Variable v, Section section) throws java.io.IOException, InvalidRangeException
IOServiceProvider
v
- a top-level Variablesection
- the section of data to read. There must be a Range for each Dimension in the variable, in order.
Note: no nulls allowed.
IOSP may not modify.java.io.IOException
- if read errorInvalidRangeException
- if invalid sectionRange
public java.lang.String toStringDebug(java.lang.Object o)
IOServiceProvider
toStringDebug
in interface IOServiceProvider
toStringDebug
in class AbstractIOServiceProvider
o
- which objectpublic void reacquire() throws java.io.IOException
IOServiceProvider
reacquire
in interface IOServiceProvider
reacquire
in class AbstractIOServiceProvider
java.io.IOException
public java.lang.Object sendIospMessage(java.lang.Object message)
IOServiceProvider
sendIospMessage
in interface IOServiceProvider
sendIospMessage
in class AbstractIOServiceProvider
message
- opaque message sent to the IOSP object when its opened (not when isValidFile() is called)protected java.util.Optional<java.nio.charset.Charset> getValueCharset()
value charset
if it was defined. Definition of charset
occurs by sending a charset as a message using the sendIospMessage(java.lang.Object)
method.value charset
if it was defined.protected void setValueCharset(@Nullable java.nio.charset.Charset charset)
value charset
.charset
- may be null.