T
- the converted type.public interface ReactiveTypeConverter<T>
CompletionStage
and Publisher
.
In addition to conversion operations, this class provides characteristics on the converted type:
<T>
may emit at most one item<T>
may emit multiple items<T>
may emit null
values
Implementations must be tested against the TCK by extending the test case from the
io.smallrye.reactive.converters.tck
packages.
Modifier and Type | Method and Description |
---|---|
boolean |
emitAtMostOneItem() |
boolean |
emitItems() |
<X> T |
fromCompletionStage(CompletionStage<X> cs)
Transforms an instance of
CompletionStage to an instance of T . |
<X> T |
fromPublisher(org.reactivestreams.Publisher<X> publisher)
Transforms an instance of
T to a Publisher . |
default boolean |
requireAtLeastOneItem() |
boolean |
supportNullValue() |
<X> CompletionStage<X> |
toCompletionStage(T instance)
Transforms an instance of
T to a CompletionStage completed with a potential value. |
<X> org.reactivestreams.Publisher<X> |
toRSPublisher(T instance)
Transforms an instance of
T to a Publisher . |
Class<T> |
type() |
<X> CompletionStage<X> toCompletionStage(T instance)
T
to a CompletionStage
completed with a potential value.
Each converter instances can use specific rules, however the following set of rules are mandatory:
CompletionStage
must never be null
.CompletionStage
completes with the first emitted value. This value may be null
for empty stream or instance of T
emitting null
as first value.instance
emits several values, only the first one is considered, others are
discarded.instance
fails before emitting a value, the returned CompletionStage
completes with this failure.instance
does not emit any value and does not fail or complete, the returned
CompletionStage
does not complete.instance
completes beforeCompletionStage
is completed with a null
value.instance
emits null
as first value (if supported), the
CompletionStage
is completed with null
. As a consequence, there are no
differences between an instance
emitting null
as first value or completing without emitting
a value. If the instance
does not support emitting null
values, the returned
CompletionStage
must be completed with a failure.X
- the type used to complete the returned CompletionStage
.
It is generally the type of data emitted by the passed instance
.instance
- the instance to convert to a CompletionStage
. Must not be null
.non-null
CompletionStage
.<X> org.reactivestreams.Publisher<X> toRSPublisher(T instance)
T
to a Publisher
.
Each converter instances can use specific rules, however the following set of rules are mandatory:
Publisher
must never be null
.instance
are emitted by the returned Publisher
.instance
emits a failure, Publisher
propagates the same failure and
terminates.instance
completes, Publisher
also completes.instance
does not emit any value and does not fail or complete, the returned
Publisher
does not send any signals or values.instance
completes beforePublisher
also completes empty.instance
emits null
, the Publisher
must send a failure
(NullPointerException
.instance
support back-pressure, the resulting Publisher
must enforce
back-pressure. When the instance
does not support back-pressure, the Publisher
consumes
the data without back-pressure using an unbounded-buffer. In other words, this operation is a pass-through
for back-pressure and its behavior is determined by the back-pressure behavior of the passed
instance
.X
- the type emitted by the returned Publisher
. It
is generally the type of data emitted by the passed instance
.instance
- the instance to convert to a Publisher
. Must not be null
.non-null
Publisher
.<X> T fromCompletionStage(CompletionStage<X> cs)
CompletionStage
to an instance of T
. The value emitted by T
depends on the completion of the passed CompletionStage
. Each converter instances can use specific rules,
however the following set of rules are mandatory:
T
must never be null
.CompletionStage
never completes, no values are emitted by the returned
T
.CompletionStage
redeems a null
value, and if T
support null
values, null
is emitted by the returned instance of T
.CompletionStage
redeems a null
value, and if T
does not support
null
values, a failure is emitted by the returned instance of T
.CompletionStage
redeems a non-null
value, the value is emitted by the
returned instance of T
.CompletionStage
is completed with a failure, the same failure is emitted by
the returned instance of T
.CompletionStage
is cancelled before having completed, the
CancellationException
must be emitted by the returned instance.
Implementations must not expect the CompletionStage
to be instances of
CompletableFuture
.
Implementations may decide to adapt the emitted result when receiving container object such as Optional
.
X
- the type of result provided by the CompletionStage
cs
- the instance of CompletionStage
, must not be null
X
.<X> T fromPublisher(org.reactivestreams.Publisher<X> publisher)
T
to a Publisher
.
Each converter instances can use specific rules, however the following set of rules are mandatory:
Publisher
must never be null
.T
emits a single value, the returned Publisher
emits the same value
and completes.T
does not emits value, sends the completion signal, the returned
Publisher
completes.T
emits a failure, the returned Publisher
emits a failure.T
emits a null
value, the returned Publisher
emits an
NullPointerException
as null
is not a valid value.T
does neither emits a value nor a signal, the returned Publisher
does not emits values or signals.X
- the type of data emitted by the passed Publisher
.publisher
- the Publisher
to convert. Must not be null
.non-null
instance of T
.Class<T> type()
null
. Notice that sub-classes of the returned class are also
managed by the same converter.boolean emitItems()
true
if the type T
may emit items, false
otherwise.boolean emitAtMostOneItem()
true
if the type T
may emit items at most one item, false
otherwise. Returning
false
to this method means that the converted type only signals about completion or error. Returning
true
means that emitItems()
must also return true
.boolean supportNullValue()
true
if the type T
can emit or receive null
as item.default boolean requireAtLeastOneItem()
true
if the type T
require at least one item. Converting from a type not emitting a
value item would fail.Copyright © 2018–2019 SmallRye. All rights reserved.