io.vertx.core.Promise Maven / Gradle / Ivy
/*
* Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
* which is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
*/
package io.vertx.core;
import io.vertx.codegen.annotations.CacheReturn;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.impl.NoStackTraceThrowable;
import io.vertx.core.impl.future.PromiseImpl;
import java.util.function.BiConsumer;
/**
* Represents the writable side of an action that may, or may not, have occurred yet.
*
* The {@link #future()} method returns the {@link Future} associated with a promise, the future
* can be used for getting notified of the promise completion and retrieve its value.
*
* A promise extends {@code Handler>} so it can be used as a callback.
*
* @author Julien Viet
*/
@VertxGen
public interface Promise extends Completable {
/**
* Create a promise that hasn't completed yet
*
* @param the result type
* @return the promise
*/
static Promise promise() {
return new PromiseImpl<>();
}
/**
* Succeed or fail this promise with the {@link AsyncResult} event.
*
* @param asyncResult the async result to handle
*/
@GenIgnore(GenIgnore.PERMITTED_TYPE)
default void handle(AsyncResult asyncResult) {
if (asyncResult.succeeded()) {
complete(asyncResult.result());
} else {
fail(asyncResult.cause());
}
}
@Override
default void complete(T result, Throwable failure) {
if (failure != null) {
handle(Future.failedFuture(failure));
} else {
handle(Future.succeededFuture(result));
}
}
/**
* Set the result. Any handler will be called, if there is one, and the promise will be marked as completed.
*
* Any handler set on the associated promise will be called.
*
* @param result the result
* @throws IllegalStateException when the promise is already completed
*/
default void complete(T result) {
if (!tryComplete(result)) {
throw new IllegalStateException("Result is already complete");
}
}
/**
* Calls {@code complete(null)}
*
* @throws IllegalStateException when the promise is already completed
*/
default void complete() {
if (!tryComplete()) {
throw new IllegalStateException("Promise already completed");
}
}
default void succeed(T result) {
if (!tryComplete(result)) {
throw new IllegalStateException("Promise already completed");
}
}
default void succeed() {
complete(null, null);
}
default void fail(Throwable failure) {
if (!tryFail(failure)) {
throw new IllegalStateException("Promise already completed");
}
}
default void fail(String message) {
if (!tryFail(message)) {
throw new IllegalStateException("Promise already completed");
}
}
/**
* Like {@link #complete(Object)} but returns {@code false} when the promise is already completed instead of throwing
* an {@link IllegalStateException}, it returns {@code true} otherwise.
*
* @param result the result
* @return {@code false} when the future is already completed
*/
boolean tryComplete(T result);
/**
* Calls {@code tryComplete(null)}.
*
* @return {@code false} when the future is already completed
*/
default boolean tryComplete() {
return tryComplete(null);
}
/**
* Like {@link #fail(Throwable)} but returns {@code false} when the promise is already completed instead of throwing
* an {@link IllegalStateException}, it returns {@code true} otherwise.
*
* @param cause the failure cause
* @return {@code false} when the future is already completed
*/
boolean tryFail(Throwable cause);
/**
* Calls {@link #fail(Throwable)} with the {@code message}.
*
* @param message the failure message
* @return false when the future is already completed
*/
default boolean tryFail(String message) {
return tryFail(new NoStackTraceThrowable(message));
}
/**
* @return the {@link Future} associated with this promise, it can be used to be aware of the promise completion
*/
@CacheReturn
Future future();
}