ExactMath.java

  1. /*
  2.  * Licensed to the Apache Software Foundation (ASF) under one
  3.  * or more contributor license agreements.  See the NOTICE file
  4.  * distributed with this work for additional information
  5.  * regarding copyright ownership.  The ASF licenses this file
  6.  * to you under the Apache License, Version 2.0 (the
  7.  * "License"); you may not use this file except in compliance
  8.  * with the License.  You may obtain a copy of the License at
  9.  *
  10.  * http://www.apache.org/licenses/LICENSE-2.0
  11.  *
  12.  * Unless required by applicable law or agreed to in writing,
  13.  * software distributed under the License is distributed on an
  14.  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  15.  * KIND, either express or implied.  See the License for the
  16.  * specific language governing permissions and limitations
  17.  * under the License.
  18.  */

  19. package org.apache.commons.compress.utils;

  20. /**
  21.  * PRIVATE.
  22.  *
  23.  * Performs exact math through {@link Math} "exact" APIs.
  24.  */
  25. public class ExactMath {

  26.     /**
  27.      * Returns the int result of adding an int and a long, and throws an exception if the result overflows an int.
  28.      *
  29.      * @param x the first value, an int.
  30.      * @param y the second value, a long,
  31.      * @return the addition of both values.
  32.      * @throws IllegalArgumentException when y or the result overflows an int
  33.      */
  34.     public static int add(final int x, final long y) {
  35.         try {
  36.             return Math.addExact(x, Math.toIntExact(y));
  37.         } catch (final ArithmeticException exp) {
  38.             throw new IllegalArgumentException("Argument too large or result overflows", exp);
  39.         }
  40.     }

  41.     private ExactMath() {
  42.         // no instances
  43.     }

  44. }