Class AbstractClassicEntityProducer
java.lang.Object
org.apache.hc.core5.http.nio.support.classic.AbstractClassicEntityProducer
- All Implemented Interfaces:
EntityDetails,AsyncDataProducer,AsyncEntityProducer,ResourceHolder
AsyncEntityProducer implementation that acts as a compatibility
layer for classic OutputStream based interfaces. Blocking output
processing is executed through an Executor.- Since:
- 5.0
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final SharedOutputBufferprivate final ContentTypeprivate final AtomicReference<Exception> private final Executorprivate final AtomicReference<AbstractClassicEntityProducer.State> -
Constructor Summary
ConstructorsConstructorDescriptionAbstractClassicEntityProducer(int initialBufferSize, ContentType contentType, Executor executor) -
Method Summary
Modifier and TypeMethodDescriptionfinal intReturns the number of bytes immediately available for output.final voidTriggered to signal a failure in data generation.Returns content encoding of the entity, if known.final longReturns length of the entity, if known.final StringReturns content type of the entity, if known.final ExceptionPreliminary declaration of trailing headers.final booleanReturns chunked transfer hint for this entity.final booleanDetermines whether the producer can consistently produce the same content after invocation ofResourceHolder.releaseResources().final voidproduce(DataStreamChannel channel) Triggered to signal the ability of the underlying data channel to accept more data.protected abstract voidproduceData(ContentType contentType, OutputStream outputStream) Writes out entity data into the given stream.void
-
Field Details
-
buffer
-
contentType
-
executor
-
state
-
exception
-
-
Constructor Details
-
AbstractClassicEntityProducer
public AbstractClassicEntityProducer(int initialBufferSize, ContentType contentType, Executor executor)
-
-
Method Details
-
produceData
protected abstract void produceData(ContentType contentType, OutputStream outputStream) throws IOException Writes out entity data into the given stream.- Parameters:
contentType- the entity content typeoutputStream- the output stream- Throws:
IOException
-
isRepeatable
public final boolean isRepeatable()Description copied from interface:AsyncEntityProducerDetermines whether the producer can consistently produce the same content after invocation ofResourceHolder.releaseResources().- Specified by:
isRepeatablein interfaceAsyncEntityProducer
-
available
public final int available()Description copied from interface:AsyncDataProducerReturns the number of bytes immediately available for output. This method can be used as a hint to control output events of the underlying I/O session.- Specified by:
availablein interfaceAsyncDataProducer- Returns:
- the number of bytes immediately available for output
-
produce
Description copied from interface:AsyncDataProducerTriggered to signal the ability of the underlying data channel to accept more data. The data producer can choose to write data immediately inside the call or asynchronously at some later point.- Specified by:
producein interfaceAsyncDataProducer- Parameters:
channel- the data channel capable to accepting more data.- Throws:
IOException
-
getContentLength
public final long getContentLength()Description copied from interface:EntityDetailsReturns length of the entity, if known.- Specified by:
getContentLengthin interfaceEntityDetails
-
getContentType
Description copied from interface:EntityDetailsReturns content type of the entity, if known.- Specified by:
getContentTypein interfaceEntityDetails
-
getContentEncoding
Description copied from interface:EntityDetailsReturns content encoding of the entity, if known.- Specified by:
getContentEncodingin interfaceEntityDetails
-
isChunked
public final boolean isChunked()Description copied from interface:EntityDetailsReturns chunked transfer hint for this entity.The behavior of wrapping entities is implementation dependent, but should respect the primary purpose.
- Specified by:
isChunkedin interfaceEntityDetails
-
getTrailerNames
Description copied from interface:EntityDetailsPreliminary declaration of trailing headers.- Specified by:
getTrailerNamesin interfaceEntityDetails
-
failed
Description copied from interface:AsyncEntityProducerTriggered to signal a failure in data generation.- Specified by:
failedin interfaceAsyncEntityProducer- Parameters:
cause- the cause of the failure.
-
getException
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-