CompressorOutputStream.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.compressors;

  20. import java.io.FilterOutputStream;
  21. import java.io.OutputStream;

  22. /**
  23.  * Abstracts all classes that compress an output stream.
  24.  *
  25.  * @param <T> The underlying OutputStream type.
  26.  */
  27. public abstract class CompressorOutputStream<T extends OutputStream> extends FilterOutputStream {

  28.     /**
  29.      * Constructs a new instance without a backing OutputStream.
  30.      * <p>
  31.      * You must initialize {@code this.out} after construction.
  32.      * </p>
  33.      */
  34.     public CompressorOutputStream() {
  35.         super(null);
  36.     }

  37.     /**
  38.      * Creates an output stream filter built on top of the specified underlying output stream.
  39.      *
  40.      * @param out the underlying output stream to be assigned to the field {@code this.out} for later use, or {@code null} if this instance is to be created
  41.      *            without an underlying stream.
  42.      * @since 1.27.0
  43.      */
  44.     public CompressorOutputStream(final T out) {
  45.         super(out);
  46.     }

  47.     /**
  48.      * Gets the underlying output stream.
  49.      *
  50.      * @return the underlying output stream.
  51.      * @since 1.27.0
  52.      */
  53.     @SuppressWarnings("unchecked")
  54.     protected T out() {
  55.         return (T) out;
  56.     }
  57. }