Package org.apache.hc.core5.reactive
Class ReactiveDataConsumer
java.lang.Object
org.apache.hc.core5.reactive.ReactiveDataConsumer
- All Implemented Interfaces:
AsyncDataConsumer,ResourceHolder,org.reactivestreams.Publisher<ByteBuffer>
@Contract(threading=SAFE)
final class ReactiveDataConsumer
extends Object
implements AsyncDataConsumer, org.reactivestreams.Publisher<ByteBuffer>
An asynchronous data consumer that supports Reactive Streams.
- Since:
- 5.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final BlockingQueue<ByteBuffer> private booleanprivate CapacityChannelprivate booleanprivate Exceptionprivate final AtomicBooleanprivate final Objectprivate final AtomicLongprivate org.reactivestreams.Subscriber<? super ByteBuffer> private final AtomicInteger -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidconsume(ByteBuffer byteBuffer) Triggered to pass incoming data to the data consumer.voidprivate voidvoidprivate voidsignalCapacity(CapacityChannel channel) voidTriggered to signal termination of the data stream.voidsubscribe(org.reactivestreams.Subscriber<? super ByteBuffer> subscriber) private voidvoidupdateCapacity(CapacityChannel capacityChannel) Triggered to signal ability of the underlying data stream to receive data capacity update.
-
Field Details
-
requests
-
buffers
-
flushInProgress
-
flushLock
-
windowScalingIncrement
-
cancelled
private volatile boolean cancelled -
completed
private volatile boolean completed -
exception
-
capacityChannel
-
subscriber
-
-
Constructor Details
-
ReactiveDataConsumer
ReactiveDataConsumer()
-
-
Method Details
-
failed
-
updateCapacity
Description copied from interface:AsyncDataConsumerTriggered to signal ability of the underlying data stream to receive data capacity update. The data consumer can choose to write data immediately inside the call or asynchronously at some later point.- Specified by:
updateCapacityin interfaceAsyncDataConsumer- Parameters:
capacityChannel- the channel for capacity updates.- Throws:
IOException
-
signalCapacity
- Throws:
IOException
-
throwIfCancelled
- Throws:
IOException
-
consume
Description copied from interface:AsyncDataConsumerTriggered to pass incoming data to the data consumer. The consumer must consume the entire content of the data buffer. The consumer must stop incrementing its capacity on the capacity channel if it is unable to accept more data. Once the data consumer has handled accumulated data or allocated more intermediate storage it can update its capacity information on the capacity channel.- Specified by:
consumein interfaceAsyncDataConsumer- Parameters:
byteBuffer- data source.- Throws:
IOException
-
streamEnd
Description copied from interface:AsyncDataConsumerTriggered to signal termination of the data stream.- Specified by:
streamEndin interfaceAsyncDataConsumer- Parameters:
trailers- data stream trailers.
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-
flushToSubscriber
private void flushToSubscriber() -
subscribe
- Specified by:
subscribein interfaceorg.reactivestreams.Publisher<ByteBuffer>
-