MemoryLimitException.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;

  20. import java.io.IOException;

  21. /**
  22.  * If a stream checks for estimated memory allocation, and the estimate goes above the memory limit, this is thrown. This can also be thrown if a stream tries
  23.  * to allocate a byte array that is larger than the allowable limit.
  24.  *
  25.  * @since 1.14
  26.  */
  27. public class MemoryLimitException extends IOException {

  28.     private static final long serialVersionUID = 1L;

  29.     private static String buildMessage(final long memoryNeededInKb, final int memoryLimitInKb) {
  30.         return memoryNeededInKb + " kb of memory would be needed; limit was " + memoryLimitInKb + " kb. "
  31.                 + "If the file is not corrupt, consider increasing the memory limit.";
  32.     }

  33.     /** A long instead of int to account for overflow for corrupt files. */
  34.     private final long memoryNeededInKb;

  35.     private final int memoryLimitInKb;

  36.     public MemoryLimitException(final long memoryNeededInKb, final int memoryLimitInKb) {
  37.         super(buildMessage(memoryNeededInKb, memoryLimitInKb));
  38.         this.memoryNeededInKb = memoryNeededInKb;
  39.         this.memoryLimitInKb = memoryLimitInKb;
  40.     }

  41.     public MemoryLimitException(final long memoryNeededInKb, final int memoryLimitInKb, final Exception e) {
  42.         super(buildMessage(memoryNeededInKb, memoryLimitInKb), e);
  43.         this.memoryNeededInKb = memoryNeededInKb;
  44.         this.memoryLimitInKb = memoryLimitInKb;
  45.     }

  46.     public int getMemoryLimitInKb() {
  47.         return memoryLimitInKb;
  48.     }

  49.     public long getMemoryNeededInKb() {
  50.         return memoryNeededInKb;
  51.     }
  52. }