View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *      https://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package org.apache.commons.io.output;
19  
20  import java.io.IOException;
21  import java.io.Writer;
22  import java.util.Arrays;
23  
24  /**
25   * Throws an IOException on all attempts to write with {@link #close()} implemented as a noop.
26   * <p>
27   * Typically uses of this class include testing for corner cases in methods that accept a writer and acting as a sentinel value instead of a {@code null}
28   * writer.
29   * </p>
30   *
31   * @since 2.7
32   */
33  public class ClosedWriter extends Writer {
34  
35      /**
36       * The singleton instance.
37       *
38       * @since 2.12.0
39       */
40      public static final ClosedWriter INSTANCE = new ClosedWriter();
41      /**
42       * The singleton instance.
43       *
44       * @deprecated Use {@link #INSTANCE}.
45       */
46      @Deprecated
47      public static final ClosedWriter CLOSED_WRITER = INSTANCE;
48  
49      /**
50       * Construct a new instance.
51       */
52      public ClosedWriter() {
53          // empty
54      }
55  
56      @Override
57      public void close() throws IOException {
58          // noop
59      }
60  
61      /**
62       * Throws an {@link IOException} to indicate that the stream is closed.
63       *
64       * @throws IOException always thrown
65       */
66      @Override
67      public void flush() throws IOException {
68          throw new IOException("flush() failed: stream is closed");
69      }
70  
71      /**
72       * Throws an {@link IOException} to indicate that the writer is closed.
73       *
74       * @param cbuf ignored.
75       * @param off  ignored.
76       * @param len  ignored.
77       * @throws IOException always thrown.
78       */
79      @Override
80      public void write(final char[] cbuf, final int off, final int len) throws IOException {
81          throw new IOException(String.format("write(%s, %d, %d) failed: stream is closed", Arrays.toString(cbuf), off, len));
82      }
83  }