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

com.lambdista.util.TryBinaryOperator Maven / Gradle / Ivy

/**
 * Copyright 2015 Bernhard Frauendienst
 *
 * 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 com.lambdista.util;

import java.util.Comparator;
import java.util.Objects;
import java.util.function.BinaryOperator;

import com.lambdista.util.Try.Failure;
import com.lambdista.util.Try.Success;

/**
 * A {@link BinaryOperator} which simplifies working with {@link Try} values, by
 * returning a {@link Failure} if one of the values is a failure, and passing
 * the wrapped values to another {@link BinaryOperator} otherwise.
 * 
 */
@FunctionalInterface
public interface TryBinaryOperator extends BinaryOperator> {

  /**
   * Returns a {@link TryBinaryOperator} which returns either a {@link Failure},
   * if either of the both arguments is non-successful, or passes the wrapped
   * values to the specified {@link BinaryOperator}
   * 
   * @param  the type of the input arguments of the binaryOperator
   * @param binaryOperator a {@link BinaryOperator} for operating on the wrapped
   *          values if both represent a {@link Success}
   * @return a {@link TryBinaryOperator} which returns a {@link Failure} if
   *         either of its arguments is a failure, or the result of the binary
   *         operation done by the passed {@link BinaryOperator}
   * @throws NullPointerException if the argument is null
   */
  public static  TryBinaryOperator of(BinaryOperator binaryOperator) {
    Objects.requireNonNull(binaryOperator);
    return (a, b) -> a.flatMap(x -> b.map(y -> binaryOperator.apply(x, y)));
  }

  /**
   * Returns a {@link TryBinaryOperator} which returns the lesser of two
   * elements according to the specified {@code Comparator}, if both values are
   * a {@link Success}.
   *
   * @param  the type of the input arguments of the comparator
   * @param comparator a {@code Comparator} for comparing the two values
   * @return a {@code TryBinaryOperator} which returns the lesser of its
   *         operands, according to the supplied {@code Comparator}, or the
   *         first {@link Failure} if one is encountered.
   * @throws NullPointerException if the argument is null
   */
  public static  TryBinaryOperator minBy(Comparator comparator) {
    return TryBinaryOperator.of(BinaryOperator.minBy(comparator));
  }

  /**
   * Returns a {@link BinaryOperator} which returns the greater of two elements
   * according to the specified {@code Comparator}, if both values are a
   * {@link Success}
   *
   * @param  the type of the input arguments of the comparator
   * @param comparator a {@code Comparator} for comparing the two values
   * @return a {@code TryBinaryOperator} which returns the greater of its
   *         operands, according to the supplied {@code Comparator}, or the
   *         first {@link Failure} if one is encountered
   * @throws NullPointerException if the argument is null
   */
  public static  TryBinaryOperator maxBy(Comparator comparator) {
    return TryBinaryOperator.of(BinaryOperator.maxBy(comparator));
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy