FlushShieldFilterOutputStream.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.  *   https://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. import java.io.FilterOutputStream;
  21. import java.io.IOException;
  22. import java.io.OutputStream;

  23. /**
  24.  * Re-implements {@link FilterOutputStream#flush()} to do nothing.
  25.  */
  26. public class FlushShieldFilterOutputStream extends FilterOutputStream {

  27.     /**
  28.      * Creates a {@code FlushShieldFilterOutputStream} filter built on top of the specified underlying output stream.
  29.      *
  30.      * @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
  31.      *            without an underlying stream.
  32.      */
  33.     public FlushShieldFilterOutputStream(final OutputStream out) {
  34.         super(out);
  35.     }

  36.     @Override
  37.     public void flush() throws IOException {
  38.         // NO IMPLEMENTATION.
  39.     }

  40. }