Emmanuel BENOîT
ec2c870f7b
Contains POM (probably incomplete) as well as all Throwing versions of java.util.function interfaces + the Runnable interface.
57 lines
1.2 KiB
Java
57 lines
1.2 KiB
Java
package info.ebenoit.ebul.func;
|
|
|
|
|
|
import java.util.function.IntBinaryOperator;
|
|
|
|
|
|
|
|
/**
|
|
* This interface supports a {@link IntBinaryOperator} that can throw checked exceptions. Checked exceptions are
|
|
* transmitted using a {@link FunctionException} runtime exception.
|
|
*
|
|
* @author <a href="mailto:ebenoit@ebenoit.info">E. Benoît</a>
|
|
*/
|
|
@FunctionalInterface
|
|
public interface ThrowingIntBinaryOperator
|
|
extends IntBinaryOperator
|
|
{
|
|
|
|
/**
|
|
* Applies this function to the given arguments.
|
|
*
|
|
* @param t
|
|
* the first argument
|
|
* @param u
|
|
* the second argument
|
|
* @return the result
|
|
* @throws FunctionException
|
|
* if a checked exception occurs
|
|
*/
|
|
@Override
|
|
default int applyAsInt( final int t , final int u )
|
|
{
|
|
try {
|
|
return this.throwingApplyAsInt( t , u );
|
|
} catch ( final RuntimeException e ) {
|
|
throw e;
|
|
} catch ( final Throwable e ) {
|
|
throw new FunctionException( e );
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Applies this function to the given arguments.
|
|
*
|
|
* @param t
|
|
* the first argument
|
|
* @param u
|
|
* the second argument
|
|
* @return the result
|
|
* @throws Throwable
|
|
* any exception
|
|
*/
|
|
public int throwingApplyAsInt( int t , int u )
|
|
throws Throwable;
|
|
|
|
}
|