Class AbstractOrigin<T, B extends AbstractOrigin<T,B>>
java.lang.Object
org.apache.commons.io.build.AbstractSupplier<T,B>
org.apache.commons.io.build.AbstractOrigin<T,B>
- Type Parameters:
T- the type produced by the builder.B- the concrete builder subclass type.
- All Implemented Interfaces:
IOSupplier<T>
- Direct Known Subclasses:
AbstractOrigin.AbstractRandomAccessFileOrigin, AbstractOrigin.ByteArrayOrigin, AbstractOrigin.ChannelOrigin, AbstractOrigin.CharSequenceOrigin, AbstractOrigin.FileOrigin, AbstractOrigin.InputStreamOrigin, AbstractOrigin.OutputStreamOrigin, AbstractOrigin.PathOrigin, AbstractOrigin.ReaderOrigin, AbstractOrigin.URIOrigin, AbstractOrigin.WriterOrigin
public abstract class AbstractOrigin<T, B extends AbstractOrigin<T,B>>
extends AbstractSupplier<T,B>
Abstracts and wraps an origin for builders, where an origin is a
byte[], Channel, CharSequence, File,
InputStream, IORandomAccessFile, OutputStream, Path, RandomAccessFile, Reader, URI,
or Writer.
An origin represents where bytes/characters come from or go to. Concrete subclasses
expose only the operations that make sense for the underlying source or sink; invoking an unsupported operation
results in UnsupportedOperationException (see, for example, getFile() and getPath()).
An instance doesn't own its origin, it holds on to it to allow conversions. There are two use cases related to resource management for a Builder:
-
A client allocates a Closeable (or AutoCloseable) resource, creates a Builder, and gives the Builder that resource by calling a
setter method. No matter what happens next, the client is responsible for releasing the resource (
Closeable.close()). In this case, the origin wraps but doesn't own the closeable resource. There is no transfer of ownership. - A client creates a Builder and gives it a non-Closeable object, like a File or a Path. The client then calls the Builder's factory method (like get()), and that call returns a Closeable or a resource that requires releasing in some other way. No matter what happens next, the client is responsible for releasing that resource. In this case, the origin doesn't wrap a closeable resource.
In both cases, the client causes the allocation and is responsible for releasing the resource.
The table below summarizes which views and conversions are supported for each origin type. Column headers show the target view; cells indicate whether that view is available from the origin in that row.
| Origin Type | byte[] | CS | File | Path | RAF | IS | Reader | RBC | OS | Writer | WBC | Channel type2 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| byte[] | ✔ | ✔ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | ✖ | ✖ | ✖ | SBC |
CharSequence (CS) |
✔ | ✔ | ✖ | ✖ | ✖ | ✔1 | ✔ | ✔1 | ✖ | ✖ | ✖ | SBC |
File |
✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | FC |
Path |
✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | FC |
IORandomAccessFile |
✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | FC |
RandomAccessFile (RAF) |
✔ | ✔ | ✖ | ✖ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | FC |
InputStream (IS) |
✔ | ✔ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | ✖ | ✖ | ✖ | RBC |
Reader |
✔ | ✔ | ✖ | ✖ | ✖ | ✔1 | ✔ | ✔1 | ✖ | ✖ | ✖ | RBC |
ReadableByteChannel (RBC) |
✔ | ✔ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | ✖ | ✖ | ✖ | RBC |
OutputStream (OS) |
✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | WBC |
Writer |
✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✔1 | ✔ | ✔1 | WBC |
WritableByteChannel (WBC) |
✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | WBC |
URI (FileSystem) |
✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | FC |
URI (http/https) |
✔ | ✔ | ✖ | ✖ | ✖ | ✔ | ✔ | ✔ | ✖ | ✖ | ✖ | RBC |
Legend
- ✔ = Supported
- ✖ = Not supported (throws
UnsupportedOperationException) - 1 = Characters are converted to bytes using the default
Charset. - 2 Minimum channel type provided by the origin:
- RBC = ReadableByteChannel
- WBC = WritableByteChannel
- SBC = SeekableByteChannel
- FC = FileChannel
- Since:
- 2.12.0
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAbstractOrigin.AbstractRandomAccessFileOrigin<T extends RandomAccessFile, B extends AbstractOrigin.AbstractRandomAccessFileOrigin<T,B>> ARandomAccessFileorigin.static classAbyte[]origin.static classAChannelorigin.static classACharSequenceorigin.static classAFileorigin.static classAnInputStreamorigin.static classAnIORandomAccessFileorigin.static classAnOutputStreamorigin.static classAPathorigin.static classARandomAccessFileorigin.static classAReaderorigin.static classAURIorigin.static classAWriterorigin. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedAbstractOrigin(T origin) Constructs a new instance for subclasses. -
Method Summary
Modifier and TypeMethodDescriptionget()Gets the origin, never null.byte[]Gets this origin as a byte array, if possible.byte[]getByteArray(long position, int length) Gets a portion of this origin as a byte array, if possible.final <C extends Channel>
CgetChannel(Class<C> channelType, OpenOption... options) Gets this origin as a Channel of the given type, if possible.protected ChannelgetChannel(OpenOption... options) Gets this origin as a Channel, if possible.getCharSequence(Charset charset) Gets this origin as a byte array, if possible.getFile()Gets this origin as a File, if possible.getInputStream(OpenOption... options) Gets this origin as an InputStream, if possible.getOutputStream(OpenOption... options) Gets this origin as an OutputStream, if possible.getPath()Gets this origin as a Path, if possible.getRandomAccessFile(OpenOption... openOption) Gets this origin as a RandomAccessFile, if possible.Gets a new Reader on the origin, buffered by default.getWriter(Charset charset, OpenOption... options) Gets a new Writer on the origin, buffered by default.longsize()Gets the size of the origin, if possible.toString()Methods inherited from class AbstractSupplier
asThisMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface IOSupplier
asSupplier, getUnchecked
-
Constructor Details
-
AbstractOrigin
Constructs a new instance for subclasses.- Parameters:
origin- The origin, not null.- Throws:
NullPointerException- iforiginisnull.
-
-
Method Details
-
get
-
getByteArray
Gets this origin as a byte array, if possible.- Returns:
- this origin as a byte array, if possible.
- Throws:
IOException- if an I/O error occurs.UnsupportedOperationException- if the origin cannot be converted to a Path.
-
getByteArray
Gets a portion of this origin as a byte array, if possible.- Parameters:
position- the initial index of the range to be copied, inclusive.length- How many bytes to copy.- Returns:
- this origin as a byte array, if possible.
- Throws:
UnsupportedOperationException- if the origin cannot be converted to a Path.ArithmeticException- if thepositionoverflows an intIOException- if an I/O error occurs.- Since:
- 2.13.0
-
getChannel
public final <C extends Channel> C getChannel(Class<C> channelType, OpenOption... options) throws IOException Gets this origin as a Channel of the given type, if possible.- Type Parameters:
C- The type of channel to return.- Parameters:
channelType- The type of channel to return.options- Options specifying how a file-based origin is opened, ignored otherwise.- Returns:
- A new Channel on the origin of the given type.
- Throws:
IOException- If an I/O error occurs.UnsupportedOperationException- If this origin cannot be converted to a channel of the given type.- Since:
- 2.21.0
- See Also:
-
getChannel
Gets this origin as a Channel, if possible.- Parameters:
options- Options specifying how a file-based origin is opened, ignored otherwise.- Returns:
- A new Channel on the origin.
- Throws:
IOException- If an I/O error occurs.UnsupportedOperationException- If this origin cannot be converted to a channel.- Since:
- 2.21.0
- See Also:
-
getCharSequence
Gets this origin as a byte array, if possible.- Parameters:
charset- The charset to use if conversion from bytes is needed.- Returns:
- this origin as a byte array, if possible.
- Throws:
IOException- if an I/O error occurs.UnsupportedOperationException- if the origin cannot be converted to a Path.
-
getFile
Gets this origin as a File, if possible.- Returns:
- this origin as a File, if possible.
- Throws:
UnsupportedOperationException- if this method is not implemented in a concrete subclass.
-
getInputStream
Gets this origin as an InputStream, if possible.- Parameters:
options- options specifying how the file is opened- Returns:
- this origin as an InputStream, if possible.
- Throws:
IOException- if an I/O error occurs.UnsupportedOperationException- if the origin cannot be converted to a Path.
-
getOutputStream
Gets this origin as an OutputStream, if possible.- Parameters:
options- options specifying how the file is opened- Returns:
- this origin as an OutputStream, if possible.
- Throws:
IOException- if an I/O error occurs.UnsupportedOperationException- if the origin cannot be converted to a Path.
-
getPath
Gets this origin as a Path, if possible.- Returns:
- this origin as a Path, if possible.
- Throws:
UnsupportedOperationException- if this method is not implemented in a concrete subclass.
-
getRandomAccessFile
Gets this origin as a RandomAccessFile, if possible.- Parameters:
openOption- options likeStandardOpenOption.- Returns:
- this origin as a RandomAccessFile, if possible.
- Throws:
FileNotFoundException- SeeRandomAccessFile(File, String).UnsupportedOperationException- if this method is not implemented in a concrete subclass.- Since:
- 2.18.0
-
getReader
Gets a new Reader on the origin, buffered by default.- Parameters:
charset- the charset to use for decoding, null maps to the default Charset.- Returns:
- a new Reader on the origin.
- Throws:
IOException- if an I/O error occurs opening the file.
-
getWriter
Gets a new Writer on the origin, buffered by default.- Parameters:
charset- the charset to use for encodingoptions- options specifying how the file is opened- Returns:
- a new Writer on the origin.
- Throws:
IOException- if an I/O error occurs opening or creating the file.UnsupportedOperationException- if the origin cannot be converted to a Path.
-
size
Gets the size of the origin, if possible.- Returns:
- the size of the origin in bytes or characters.
- Throws:
IOException- if an I/O error occurs.- Since:
- 2.13.0
-
toString
-