Class FlowableMapOptional.MapOptionalConditionalSubscriber<T,R>
java.lang.Object
io.reactivex.rxjava3.internal.subscribers.BasicFuseableConditionalSubscriber<T,R>
io.reactivex.rxjava3.internal.jdk8.FlowableMapOptional.MapOptionalConditionalSubscriber<T,R>
- All Implemented Interfaces:
FlowableSubscriber<T>
,ConditionalSubscriber<T>
,QueueFuseable<R>
,QueueSubscription<R>
,SimpleQueue<R>
,org.reactivestreams.Subscriber<T>
,org.reactivestreams.Subscription
- Enclosing class:
FlowableMapOptional<T,
R>
static final class FlowableMapOptional.MapOptionalConditionalSubscriber<T,R>
extends BasicFuseableConditionalSubscriber<T,R>
-
Field Summary
FieldsModifier and TypeFieldDescriptionFields inherited from class io.reactivex.rxjava3.internal.subscribers.BasicFuseableConditionalSubscriber
done, downstream, qs, sourceMode, upstream
-
Constructor Summary
ConstructorsConstructorDescriptionMapOptionalConditionalSubscriber
(ConditionalSubscriber<? super R> downstream, Function<? super T, Optional<? extends R>> mapper) -
Method Summary
Methods inherited from class io.reactivex.rxjava3.internal.subscribers.BasicFuseableConditionalSubscriber
afterDownstream, beforeDownstream, cancel, clear, fail, isEmpty, offer, offer, onComplete, onError, onSubscribe, request, transitiveBoundaryFusion
-
Field Details
-
mapper
-
-
Constructor Details
-
MapOptionalConditionalSubscriber
-
-
Method Details
-
onNext
-
tryOnNext
Description copied from interface:ConditionalSubscriber
Conditionally takes the value.- Parameters:
t
- the value to deliver- Returns:
- true if the value has been accepted, false if the value has been rejected and the next value can be sent immediately
-
requestFusion
public int requestFusion(int mode) Description copied from interface:QueueFuseable
Request a fusion mode from the upstream.This should be called before
onSubscribe
returns.Calling this method multiple times or after
onSubscribe
finished is not allowed and may result in undefined behavior.- Parameters:
mode
- the requested fusion mode, allowed values areQueueFuseable.SYNC
,QueueFuseable.ASYNC
,QueueFuseable.ANY
combined withQueueFuseable.BOUNDARY
(e.g.,requestFusion(SYNC | BOUNDARY)
).- Returns:
- the established fusion mode:
QueueFuseable.NONE
,QueueFuseable.SYNC
,QueueFuseable.ASYNC
.
-
poll
Description copied from interface:SimpleQueue
Tries to dequeue a value (non-null) or returns null if the queue is empty.If the producer uses
SimpleQueue.offer(Object, Object)
and when polling in pairs, if the first poll() returns a non-null item, the second poll() is guaranteed to return a non-null item as well.- Returns:
- the item or null to indicate an empty queue
- Throws:
Throwable
- if some pre-processing of the dequeued item (usually through fused functions) throws.
-