/*
* Copyright 2016 JBoss Inc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.apiman.gateway.engine.async;
/**
* A simple future interface that allows the indication of an event's completion or failure.
*
* @author Marc Savy {@literal <msavy@redhat.com>}
* @param <T> Type future contained type.
*/
public interface IAsyncFuture<T> extends IAsyncResult<T> {
/**
* Indicate completion
*/
void completed();
/**
* Indicate completion and set result
*
* @param result the result to set
*/
void completed(T result);
/**
* Indicate failure and set error
*
* @param t the throwable to set
*/
void fail(Throwable t);
/**
* Set the action handler to invoke when the future indicates completion or failure.
*
* @param handler the handler invoked on completion or failure
* @return this future
*/
IAsyncFuture<T> setActionHandler(IAsyncResultHandler<T> handler);
/**
* Create an empty future.
*
* @return the new future
*/
static <T> IAsyncFuture<T> create() {
return new AsyncFutureImpl<>();
}
}