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

ratpack.func.Function Maven / Gradle / Ivy

There is a newer version: 2.0.0-rc-1
Show newest version
/*
 * Copyright 2013 the original author or authors.
 *
 * 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 ratpack.func;

import ratpack.util.ExceptionUtils;

import java.util.Objects;

/**
 * A single argument function.
 * 

* This type serves the same purpose as the JDK's {@link java.util.function.Function}, but allows throwing checked exceptions. * It contains methods for bridging to and from the JDK type. * * @param the type of the input * @param the type of the output */ @FunctionalInterface public interface Function { /** * The function implementation. * * @param i the input to the function * @return the output of the function * @throws Exception any */ O apply(I i) throws Exception; /** * Joins {@code this} function with the given function. * *

{@code
   * import ratpack.func.Function;
   *
   * public class Example {
   *   public static void main(String[] args) throws Exception {
   *     Function function = in -> in + "-bar";
   *     assert function.andThen(String::toUpperCase).apply("foo").equals("FOO-BAR");
   *   }
   * }
   * }
*

* Analogous to {@link java.util.function.Function#andThen(java.util.function.Function)}. * * @param after the function to apply to the result of {@code this} function * @param the type of the final output * @return the result of applying the given function to {@code this} function * @throws Exception any thrown by {@code this} or {@code after} */ default Function andThen(Function after) throws Exception { Objects.requireNonNull(after); return (I i) -> { O apply = apply(i); return after.apply(apply); }; } /** * Joins the given function with {@code this} function. * *

{@code
   * import ratpack.func.Function;
   *
   * public class Example {
   *   public static void main(String... args) throws Exception {
   *     Function function = String::toUpperCase;
   *     assert function.compose(in -> in + "-BAR").apply("foo").equals("FOO-BAR");
   *   }
   * }
   * }
*

* Analogous to {@link java.util.function.Function#compose(java.util.function.Function)}. * * @param before the function to apply {@code this} function to the result of * @param the type of the new input * @return the result of applying {@code this} function to the result of the given function * @throws Exception any thrown by {@code this} or {@code before} */ default Function compose(Function before) throws Exception { Objects.requireNonNull(before); return (T t) -> apply(before.apply(t)); } /** * Converts {@code this} function into the equivalent JDK type. *

* Any exceptions thrown by {@code this} function will be unchecked via {@link ExceptionUtils#uncheck(Throwable)} and rethrown. * * @return this function as a JDK style function. */ default java.util.function.Function toFunction() { return (t) -> { try { return apply(t); } catch (Exception e) { throw ExceptionUtils.uncheck(e); } }; } /** * Creates a function of this type from a JDK style function. * * @param function a JDK style function * @param the input type * @param the output type * @return a Ratpack style function wrapping the given JDK function */ static Function from(java.util.function.Function function) { Objects.requireNonNull(function); return function::apply; } }