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

io.jsync.impl.DefaultFutureResult Maven / Gradle / Ivy

There is a newer version: 1.10.13
Show newest version
/*
 * Copyright (c) 2011-2013 The original author or authors
 * ------------------------------------------------------
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Apache License v2.0 which accompanies this distribution.
 *
 *     The Eclipse Public License is available at
 *     http://www.eclipse.org/legal/epl-v10.html
 *
 *     The Apache License v2.0 is available at
 *     http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */

package io.jsync.impl;

import io.jsync.AsyncResult;
import io.jsync.Future;
import io.jsync.Handler;

public class DefaultFutureResult implements Future {
    private boolean failed;
    private boolean succeeded;
    private Handler> handler;
    private T result;
    private Throwable throwable;

    /**
     * Create a FutureResult that hasn't completed yet
     */
    public DefaultFutureResult() {
    }

    /**
     * Create a VoidResult that has already completed
     *
     * @param t The Throwable or null if succeeded
     */
    public DefaultFutureResult(Throwable t) {
        if (t == null) {
            setResult(null);
        } else {
            setFailure(t);
        }
    }

    /**
     * Create a FutureResult that has already succeeded
     *
     * @param result The result
     */
    public DefaultFutureResult(T result) {
        setResult(result);
    }

    /**
     * The result of the operation. This will be null if the operation failed.
     */
    public T result() {
        return result;
    }

    /**
     * An exception describing failure. This will be null if the operation succeeded.
     */
    public Throwable cause() {
        return throwable;
    }

    /**
     * Did it succeeed?
     */
    public boolean succeeded() {
        return succeeded;
    }

    /**
     * Did it fail?
     */
    public boolean failed() {
        return failed;
    }

    /**
     * Has it completed?
     */
    public boolean complete() {
        return failed || succeeded;
    }

    /**
     * Set a handler for the result. It will get called when it's complete
     */
    public DefaultFutureResult setHandler(Handler> handler) {
        this.handler = handler;
        checkCallHandler();
        return this;
    }

    /**
     * Set the result. Any handler will be called, if there is one
     */
    public DefaultFutureResult setResult(T result) {
        this.result = result;
        succeeded = true;
        checkCallHandler();
        return this;
    }

    /**
     * Set the failure. Any handler will be called, if there is one
     */
    public DefaultFutureResult setFailure(Throwable throwable) {
        this.throwable = throwable;
        failed = true;
        checkCallHandler();
        return this;
    }

    private void checkCallHandler() {
        if (handler != null && complete()) {
            handler.handle(this);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy