/*
* $Id$
*
* Copyright (c) 2010 by Joel Uckelman
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License (LGPL) as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, copies are available
* at http://www.opensource.org.
*/
package VASSAL.tools.concurrent;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
/**
* A {@link Future} which provides methods for setting its result.
*
* @since author Joel Uckelman
* @since 3.2.0
*/
public interface SettableFuture<V> extends Future<V> {
/**
* Sets the exception to be wrapped in an {@link ExecutionException} and
* thrown by {@link #get}.
*
* <b>May be called only from the thread executing the computation.</b>
*
* @param t the exception
*/
public void setException(Throwable t);
/**
* Sets the result to be returned by {@link #get}.
*
* <b>May be called only from the thread executing the computation.</b>
*
* @param r the result
*/
public void set(V r);
}