All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy