public final class RandomAccessSourceFactory extends Object implements Serializable
IRandomAccessSource
objects based on various types of sources
Constructor and Description |
---|
RandomAccessSourceFactory()
Creates a factory that will give preference to accessing the underling data source using memory mapped files
|
public RandomAccessSourceFactory()
public RandomAccessSourceFactory setForceRead(boolean forceRead)
forceRead
- true if the full content will be read, false otherwise
public RandomAccessSourceFactory setUsePlainRandomAccess(boolean usePlainRandomAccess)
RandomAccessFile
should be used as the primary data access mechanism
usePlainRandomAccess
- whether RandomAccessFile
should be used as the primary data access mechanism
public RandomAccessSourceFactory setExclusivelyLockFile(boolean exclusivelyLockFile)
public IRandomAccessSource createSource(byte[] data)
IRandomAccessSource
based on a byte array
data
- the byte array
IRandomAccessSource
public IRandomAccessSource createSource(RandomAccessFile raf) throws IOException
IOException
public IRandomAccessSource createSource(URL url) throws IOException
IRandomAccessSource
based on a URL. The data available at the URL is read into memory and used as the source for the IRandomAccessSource
url
- the url to read from
IRandomAccessSource
IOException
- in case of any I/O error.
public IRandomAccessSource createSource(InputStream inputStream) throws IOException
IRandomAccessSource
based on an InputStream
. The full content of the InputStream is read into memory and used as the source for the IRandomAccessSource
inputStream
- the stream to read from
IRandomAccessSource
IOException
- in case of any I/O error.
public IRandomAccessSource createBestSource(String filename) throws IOException
IRandomAccessSource
based on a filename string. If the filename describes a URL, a URL based source is created If the filename describes a file on disk, the contents may be read into memory (if forceRead
is true), opened using memory mapped file channel (if usePlainRandomAccess is false), or opened using RandomAccessFile
access (if usePlainRandomAccess is true) This call will automatically fail over to using RandomAccessFile
if the memory map operation fails
filename
- the name of the file or resource to create the IRandomAccessSource
for
IRandomAccessSource
IOException
- in case of any I/O error
public IRandomAccessSource createBestSource(FileChannel channel) throws IOException
IRandomAccessSource
based on memory mapping a file channel. Unless you are explicitly working with a FileChannel
already, it is better to use createBestSource(String)
. If the file is large, it will be opened using a paging strategy.
channel
- the name of the file or resource to create the IRandomAccessSource
for
IRandomAccessSource
IOException
- in case of any I/O error
public IRandomAccessSource createRanged(IRandomAccessSource source, long[] ranges) throws IOException
IOException
Copyright © 1998–2023 iText Group NV. All rights reserved.