001/*
002 * Copyright (c) 2012-2021 Institut National des Sciences Appliquées de Lyon (INSA Lyon) and others
003 *
004 * This program and the accompanying materials are made available under the
005 * terms of the Eclipse Public License 2.0 which is available at
006 * http://www.eclipse.org/legal/epl-2.0.
007 *
008 * SPDX-License-Identifier: EPL-2.0
009 */
010
011package gololang.concurrent.async;
012
013/**
014 * A future is an abstraction over the eventual result of a possibly asynchronous computation.
015 *
016 * This interface is intended to be used in conjunction with {@code Promise}. A future is a read-only view over a
017 * promise.
018 *
019 * {@code Future} objects are made composable in Golo through a set of augmentations: {@code filter}, {@code map}, etc.
020 * You should consult the "golodoc" of the {@code gololang.Async} module.
021 */
022public interface Future {
023
024  /**
025   * Non-blocking get.
026   *
027   * @return the future value, which may be {@code null} if it has not been resolved yet.
028   */
029  Object get();
030
031  /**
032   * Blocking get, waiting until the future has been resolved.
033   *
034   * @return the future value.
035   * @throws InterruptedException when the current thread is being interrupted.
036   */
037  Object blockingGet() throws InterruptedException;
038
039  /**
040   * Test whether the future has been resolved, that is, the future is either set or failed.
041   *
042   * @return {@code true} if the future is resolved, {@code false} otherwise.
043   */
044  boolean isResolved();
045
046  /**
047   * Test whether the future has failed.
048   *
049   * @return {@code true} if the future is resolved and failed, {@code false} otherwise.
050   */
051  boolean isFailed();
052
053  /**
054   * Registers a callback for when the future is set. If the future has already been set, then it is executed
055   * immediately from the caller thread.
056   *
057   * @param observer the callback.
058   * @return this future object.
059   */
060  Future onSet(Observer observer);
061
062  /**
063   * Registers a callback for when the future fails. If the future has already been failed, then it is executed
064   * immediately from the caller thread.
065   *
066   * @param observer the callback.
067   * @return this future object.
068   */
069  Future onFail(Observer observer);
070
071  /**
072   * Simple interface for a future observer / callback.
073   */
074  @FunctionalInterface
075  interface Observer {
076
077    /**
078     * Callback method.
079     *
080     * @param value the future value.
081     */
082    void apply(Object value);
083  }
084}