Package com.bea.wli.sb.sources
Class StreamSource
java.lang.Object
com.bea.wli.sb.sources.StreamSource
- All Implemented Interfaces:
com.bea.wli.sb.sources.ContentTypeAwareSource
,SingleUseSource
,Source
public class StreamSource
extends Object
implements SingleUseSource, com.bea.wli.sb.sources.ContentTypeAwareSource
A byte-stream Source whose content comes from an InputStream.
As a byte-stream source, the serialization methods do not heed any
transformation options.
NOTE: since this stream is backed by an InputStream, that means that
this source is a single-use source. Both serialization methods pull
from the same underlying InputStream, and once that content is consumed,
it is gone. The push-based
writeTo()
method will result
in all data being consumed immediately, assuming no error occurs. The
pull-based getInputStream()
actually gives the underlying
InputStream directly to the caller.-
Field Summary
Fields inherited from interface com.bea.wli.sb.sources.Source
DEFAULT_CHARACTER_SET_ENCODING
-
Constructor Summary
ConstructorsConstructorDescriptionStreamSource
(InputStream inputStream) StreamSource
(InputStream inputStream, String contentType) -
Method Summary
Modifier and TypeMethodDescriptiongetInputStream
(TransformOptions options) Returns streaming byte-baseed representation of the Source's content.boolean
Indicates if the Source has already been consumedint
peek
(byte[] b, int off, int len) Peek bytes from the input stream without consuming the input stream.void
writeTo
(OutputStream out, TransformOptions options) Serializes the Source's content to a byte-based stream.
-
Constructor Details
-
StreamSource
- Parameters:
inputStream
- A valid InputStream reference to an XML stream.
-
StreamSource
- Parameters:
inputStream
- A valid InputStream reference to an XML stream.
-
-
Method Details
-
getContentType
- Specified by:
getContentType
in interfacecom.bea.wli.sb.sources.ContentTypeAwareSource
-
getInputStream
Description copied from interface:Source
Returns streaming byte-baseed representation of the Source's content. The representation of that serialization is entirely up to the Source. Note that this method may involve an internal transformation, although it should not in any way change the underlying content.- Specified by:
getInputStream
in interfaceSource
- Parameters:
options
- Options used to affect the serialization- Returns:
- an InputStream for retrieving the serialized content
-
writeTo
Description copied from interface:Source
Serializes the Source's content to a byte-based stream. The representation of that serialization is entirely up to the Source. The Source is forbidden from closing the provided OutputStream, although it is allowed to flush it. However, flushing the stream should be left to the caller, if possible.Note that this method may involve an internal transformation, although it should not in any way change the underlying content.
- Specified by:
writeTo
in interfaceSource
- Parameters:
out
- the OutputStream to which serialized content will be writtenoptions
- TransformOptions used to affect the serialization- Throws:
IOException
-
isConsumed
public boolean isConsumed()Description copied from interface:SingleUseSource
Indicates if the Source has already been consumed- Specified by:
isConsumed
in interfaceSingleUseSource
- Returns:
-
peek
Peek bytes from the input stream without consuming the input stream. This does not affect subsequent calls toread
- Parameters:
b
- bytes array to copy bytes tooff
- start offset for bytes to copylen
- length of bytes to copy- Returns:
- number of copied bytes, -1 if no bytes are available or the stream is consumed.
- Throws:
IOException
- an I/O Exception occurred
-