Skip to content

Commit

Permalink
Revisit nullability annotations
Browse files Browse the repository at this point in the history
This commit introduces following changes:
 - It adds @nonnull and @nullable annotations which allows to apply
null-safety semantics on a specific type like JSR 305 but allows to
target generic type arguments.
 - @NonNullApi does not apply to ElementType.TYPE anymore
 - Nullability annotations are now also applied to generic type arguments,
varargs and array elements.
 - Package is now reactor.util.annotation
 - Add null-safety reference documentation
  • Loading branch information
sdeleuze committed Sep 19, 2017
1 parent 7d20151 commit ce679f7
Show file tree
Hide file tree
Showing 250 changed files with 1,471 additions and 1,240 deletions.
2 changes: 1 addition & 1 deletion build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -224,7 +224,7 @@ project('reactor-core') {
testCompile "org.reactivestreams:reactive-streams-tck:1.0.1"

// JSR-305 annotations
optional "com.google.code.findbugs:jsr305:3.0.0"
optional "com.google.code.findbugs:jsr305:3.0.2"

//Optional Logging Operator
optional "org.slf4j:slf4j-api:$slf4jVersion"
Expand Down
17 changes: 9 additions & 8 deletions reactor-core/src/main/java/reactor/adapter/JdkFlowAdapter.java
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import org.reactivestreams.Subscription;
import reactor.core.CoreSubscriber;
import reactor.core.publisher.Flux;
import reactor.util.annotation.NonNull;

/**
* Convert a Java 9+ {@literal Flow.Publisher} to/from a Reactive Streams {@link Publisher}.
Expand All @@ -39,7 +40,7 @@ public abstract class JdkFlowAdapter {
* @param <T> the type of the publisher
* @return a java {@code Flow.Publisher} from the given {@link Publisher}
*/
public static <T> Flow.Publisher<T> publisherToFlowPublisher(final Publisher<T>
public static <T> Flow.Publisher<@NonNull T> publisherToFlowPublisher(final Publisher<@NonNull T>
publisher) {
return new PublisherAsFlowPublisher<>(publisher);
}
Expand All @@ -51,32 +52,32 @@ public static <T> Flow.Publisher<T> publisherToFlowPublisher(final Publisher<T>
* @param <T> the type of the publisher
* @return a {@link Flux} from a java {@code Flow.Publisher}
*/
public static <T> Flux<T> flowPublisherToFlux(Flow.Publisher<T> publisher) {
public static <T> Flux<@NonNull T> flowPublisherToFlux(Flow.Publisher<@NonNull T> publisher) {
return new FlowPublisherAsFlux<>(publisher);
}

private static class FlowPublisherAsFlux<T> extends Flux<T> {
private final java.util.concurrent.Flow.Publisher<T> pub;

private FlowPublisherAsFlux(java.util.concurrent.Flow.Publisher<T> pub) {
private FlowPublisherAsFlux(java.util.concurrent.Flow.Publisher<@NonNull T> pub) {
this.pub = pub;
}

@Override
public void subscribe(final CoreSubscriber<? super T> actual) {
public void subscribe(final CoreSubscriber<? super @NonNull T> actual) {
pub.subscribe(new SubscriberToRS<>(actual));
}
}

private static class PublisherAsFlowPublisher<T> implements Flow.Publisher<T> {
private final Publisher<T> pub;

private PublisherAsFlowPublisher(Publisher<T> pub) {
private PublisherAsFlowPublisher(Publisher<@NonNull T> pub) {
this.pub = pub;
}

@Override
public void subscribe(Flow.Subscriber<? super T> subscriber) {
public void subscribe(Flow.Subscriber<? super @NonNull T> subscriber) {
pub.subscribe(new FlowSubscriber<>(subscriber));
}
}
Expand All @@ -87,7 +88,7 @@ private static class FlowSubscriber<T> implements CoreSubscriber<T>, Flow.Subscr

Subscription subscription;

public FlowSubscriber(Flow.Subscriber<? super T> subscriber) {
public FlowSubscriber(Flow.Subscriber<? super @NonNull T> subscriber) {
this.subscriber = subscriber;
}

Expand Down Expand Up @@ -129,7 +130,7 @@ private static class SubscriberToRS<T> implements Flow.Subscriber<T>, Subscripti

Flow.Subscription subscription;

public SubscriberToRS(Subscriber<? super T> s) {
public SubscriberToRS(Subscriber<? super @NonNull T> s) {
this.s = s;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,4 @@
@NonNullApi
package reactor.adapter;

import reactor.util.lang.NonNullApi;
import reactor.util.annotation.NonNullApi;
3 changes: 2 additions & 1 deletion reactor-core/src/main/java/reactor/core/Disposable.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@

import java.util.Collection;
import java.util.function.Supplier;
import javax.annotation.Nullable;

import reactor.util.annotation.Nullable;

/**
* Indicates that a task or resource can be cancelled/disposed.
Expand Down
21 changes: 11 additions & 10 deletions reactor-core/src/main/java/reactor/core/Disposables.java
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,10 @@
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
import java.util.stream.Stream;
import javax.annotation.Nullable;

import reactor.util.concurrent.Queues;
import reactor.util.annotation.NonNull;
import reactor.util.annotation.Nullable;

/**
* A support class that offers factory methods for implementations of the specialized
Expand Down Expand Up @@ -55,7 +56,7 @@ public static Disposable.Composite composite() {
*
* @return a pre-filled atomic {@link Disposable.Composite}
*/
public static Disposable.Composite composite(Disposable... disposables) {
public static Disposable.Composite composite(Disposable @NonNull ... disposables) {
return new CompositeDisposable(disposables);
}

Expand All @@ -66,7 +67,7 @@ public static Disposable.Composite composite(Disposable... disposables) {
* @return a pre-filled atomic {@link Disposable.Composite}
*/
public static Disposable.Composite composite(
Iterable<? extends Disposable> disposables) {
Iterable<? extends @NonNull Disposable> disposables) {
return new CompositeDisposable(disposables);
}

Expand Down Expand Up @@ -146,7 +147,7 @@ static final class CompositeDisposable implements Disposable.Composite, Scannabl
* Creates a {@link CompositeDisposable} with the given array of initial elements.
* @param disposables the array of {@link Disposable} to start with
*/
CompositeDisposable(Disposable... disposables) {
CompositeDisposable(Disposable @NonNull ... disposables) {
Objects.requireNonNull(disposables, "disposables is null");

int capacity = disposables.length + 1;
Expand All @@ -167,7 +168,7 @@ static final class CompositeDisposable implements Disposable.Composite, Scannabl
* initial elements.
* @param disposables the Iterable sequence of {@link Disposable} to start with
*/
CompositeDisposable(Iterable<? extends Disposable> disposables) {
CompositeDisposable(Iterable<? extends @NonNull Disposable> disposables) {
Objects.requireNonNull(disposables, "disposables is null");
this.loadFactor = DEFAULT_LOAD_FACTOR;
int c = DEFAULT_CAPACITY;
Expand Down Expand Up @@ -239,7 +240,7 @@ public boolean add(Disposable d) {
}

@Override
public boolean addAll(Collection<? extends Disposable> ds) {
public boolean addAll(Collection<? extends @NonNull Disposable> ds) {
Objects.requireNonNull(ds, "ds is null");
if (!disposed) {
synchronized (this) {
Expand Down Expand Up @@ -357,7 +358,7 @@ boolean removeEntry(Disposable value) {
}
}

boolean removeEntry(int pos, Disposable[] a, int m) {
boolean removeEntry(int pos, Disposable @Nullable [] a, int m) {
size--;

int last;
Expand Down Expand Up @@ -528,7 +529,7 @@ public boolean isDisposed() {
* @param newValue the new Disposable to push
* @return true if successful, false if the field contains the {@link #DISPOSED} instance.
*/
static <T> boolean set(AtomicReferenceFieldUpdater<T, Disposable> updater, T holder, @Nullable Disposable newValue) {
static <T> boolean set(AtomicReferenceFieldUpdater<@NonNull T, @NonNull Disposable> updater, T holder, @Nullable Disposable newValue) {
for (;;) {
Disposable current = updater.get(holder);
if (current == DISPOSED) {
Expand Down Expand Up @@ -556,7 +557,7 @@ static <T> boolean set(AtomicReferenceFieldUpdater<T, Disposable> updater, T hol
* @return true if the operation succeeded, false if the target field contained
* the common {@link #DISPOSED} instance and the given disposable is not null but is disposed.
*/
static <T> boolean replace(AtomicReferenceFieldUpdater<T, Disposable> updater, T holder, @Nullable Disposable newValue) {
static <T> boolean replace(AtomicReferenceFieldUpdater<@NonNull T, @NonNull Disposable> updater, T holder, @Nullable Disposable newValue) {
for (;;) {
Disposable current = updater.get(holder);
if (current == DISPOSED) {
Expand All @@ -578,7 +579,7 @@ static <T> boolean replace(AtomicReferenceFieldUpdater<T, Disposable> updater, T
* @param holder the target instance holding the field
* @return true if the {@link Disposable} held by the field was properly disposed
*/
static <T> boolean dispose(AtomicReferenceFieldUpdater<T, Disposable> updater, T holder) {
static <T> boolean dispose(AtomicReferenceFieldUpdater<@NonNull T, @NonNull Disposable> updater, T holder) {
Disposable current = updater.get(holder);
Disposable d = DISPOSED;
if (current != d) {
Expand Down
12 changes: 7 additions & 5 deletions reactor-core/src/main/java/reactor/core/Exceptions.java
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,9 @@
import java.util.Objects;
import java.util.concurrent.RejectedExecutionException;
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
import javax.annotation.Nullable;

import reactor.util.annotation.NonNull;
import reactor.util.annotation.Nullable;

/**
* Global Reactor Core Exception handling and utils to operate on.
Expand Down Expand Up @@ -60,7 +62,7 @@ public abstract class Exceptions {
* instance.
* @see #unwrapMultiple(Throwable)
*/
public static <T> boolean addThrowable(AtomicReferenceFieldUpdater<T, Throwable> field,
public static <T> boolean addThrowable(AtomicReferenceFieldUpdater<@NonNull T, @NonNull Throwable> field,
T instance,
Throwable exception) {
for (; ; ) {
Expand Down Expand Up @@ -102,7 +104,7 @@ public static <T> boolean addThrowable(AtomicReferenceFieldUpdater<T, Throwable>
* suppressed exceptions
* @see #addThrowable(AtomicReferenceFieldUpdater, Object, Throwable)
*/
public static RuntimeException multiple(Throwable... throwables) {
public static RuntimeException multiple(Throwable @NonNull ... throwables) {
CompositeException multiple = new CompositeException();
//noinspection ConstantConditions
if (throwables != null) {
Expand All @@ -127,7 +129,7 @@ public static RuntimeException multiple(Throwable... throwables) {
* suppressed exceptions
* @see #addThrowable(AtomicReferenceFieldUpdater, Object, Throwable)
*/
public static RuntimeException multiple(Iterable<Throwable> throwables) {
public static RuntimeException multiple(Iterable<@NonNull Throwable> throwables) {
RuntimeException multiple = new RuntimeException("Multiple exceptions");
//noinspection ConstantConditions
if (throwables != null) {
Expand Down Expand Up @@ -336,7 +338,7 @@ public static RuntimeException propagate(Throwable t) {
* @return the previously masked throwable
*/
@Nullable
public static <T> Throwable terminate(AtomicReferenceFieldUpdater<T, Throwable> field,
public static <T> Throwable terminate(AtomicReferenceFieldUpdater<@NonNull T, @NonNull Throwable> field,
T instance) {
Throwable current = field.get(instance);
if (current != TERMINATED) {
Expand Down
16 changes: 8 additions & 8 deletions reactor-core/src/main/java/reactor/core/Scannable.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,13 @@

import java.util.Iterator;
import java.util.Objects;
import java.util.Set;
import java.util.Spliterators;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import javax.annotation.Nullable;

import reactor.util.function.Tuple2;
import reactor.util.annotation.NonNull;
import reactor.util.annotation.Nullable;

/**
* A Scannable component exposes state in a non strictly memory consistent way and
Expand Down Expand Up @@ -265,7 +265,7 @@ static Scannable from(@Nullable Object o) {
* @return a {@link Stream} navigating the {@link org.reactivestreams.Subscriber}
* chain (downward)
*/
default Stream<? extends Scannable> actuals() {
default Stream<? extends @NonNull Scannable> actuals() {
return Attr.recurse(this, Attr.ACTUAL);
}

Expand All @@ -274,7 +274,7 @@ default Stream<? extends Scannable> actuals() {
*
* @return a {@link Stream} of referenced inners (flatmap, multicast etc)
*/
default Stream<? extends Scannable> inners() {
default Stream<? extends @NonNull Scannable> inners() {
return Stream.empty();
}

Expand Down Expand Up @@ -330,7 +330,7 @@ default String operatorName() {
* @return a {@link Stream} navigating the {@link org.reactivestreams.Subscription}
* chain (upward)
*/
default Stream<? extends Scannable> parents() {
default Stream<? extends @NonNull Scannable> parents() {
return Attr.recurse(this, Attr.PARENT);
}

Expand Down Expand Up @@ -361,7 +361,7 @@ default Stream<? extends Scannable> parents() {
*
*/
@Nullable
default <T> T scan(Attr<T> key) {
default <T> T scan(Attr<@NonNull T> key) {
@SuppressWarnings("unchecked")
T value = (T) scanUnsafe(key);
if (value == null)
Expand All @@ -379,7 +379,7 @@ default <T> T scan(Attr<T> key) {
*
* @return a value associated to the key or the provided default if unmatched or unresolved
*/
default <T> T scanOrDefault(Attr<T> key, T defaultValue) {
default <T> T scanOrDefault(Attr<@NonNull T> key, T defaultValue) {
@SuppressWarnings("unchecked")
T v = (T) scanUnsafe(key);
if (v == null) {
Expand All @@ -394,7 +394,7 @@ default <T> T scanOrDefault(Attr<T> key, T defaultValue) {
*
* @return the stream of tags for this {@link Scannable} and its parents
*/
default Stream<Tuple2<String, String>> tags() {
default Stream<@NonNull Tuple2<@NonNull String, @NonNull String>> tags() {
Stream<Tuple2<String, String>> parentTags =
parents().flatMap(s -> s.scan(Attr.TAGS));

Expand Down
2 changes: 1 addition & 1 deletion reactor-core/src/main/java/reactor/core/package-info.java
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,4 @@
@NonNullApi
package reactor.core;

import reactor.util.lang.NonNullApi;
import reactor.util.annotation.NonNullApi;
Original file line number Diff line number Diff line change
Expand Up @@ -29,13 +29,13 @@
import java.util.function.Supplier;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import javax.annotation.Nullable;

import org.reactivestreams.Publisher;
import org.reactivestreams.Subscription;
import reactor.core.Exceptions;
import reactor.core.Scannable;
import reactor.util.context.Context;
import reactor.util.annotation.NonNull;
import reactor.util.annotation.Nullable;

/**
* An iterable that consumes a Publisher in a blocking fashion.
Expand Down Expand Up @@ -74,7 +74,7 @@ public Object scanUnsafe(Attr key) {
}

@Override
public Iterator<T> iterator() {
public Iterator<@NonNull T> iterator() {
SubscriberIterator<T> it = createIterator();

source.subscribe(it);
Expand All @@ -83,15 +83,15 @@ public Iterator<T> iterator() {
}

@Override
public Spliterator<T> spliterator() {
public Spliterator<@NonNull T> spliterator() {
return stream().spliterator(); // cancellation should be composed through this way
}

/**
* @return a {@link Stream} of unknown size with onClose attached to {@link
* Subscription#cancel()}
*/
public Stream<T> stream() {
public Stream<@NonNull T> stream() {
SubscriberIterator<T> it = createIterator();
source.subscribe(it);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
import org.reactivestreams.Subscription;
import reactor.core.Disposable;
import reactor.core.Exceptions;
import javax.annotation.Nullable;
import reactor.util.annotation.Nullable;

/**
* @see <a href="https://github.com/reactor/reactive-streams-commons">https://github.com/reactor/reactive-streams-commons</a>
Expand Down
Loading

0 comments on commit ce679f7

Please sign in to comment.