mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 06:45:07 +02:00
8187898: PrintStream should override FilterOutputStream#write(byte[]) with a method that has no throws clause
Reviewed-by: alanb, rriggs, lancea, darcy
This commit is contained in:
parent
cebd13dbaa
commit
4d70cdac4f
2 changed files with 140 additions and 0 deletions
|
@ -415,6 +415,7 @@ public class PrintStream extends FilterOutputStream
|
||||||
*
|
*
|
||||||
* @see java.io.OutputStream#flush()
|
* @see java.io.OutputStream#flush()
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void flush() {
|
public void flush() {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
try {
|
try {
|
||||||
|
@ -435,6 +436,7 @@ public class PrintStream extends FilterOutputStream
|
||||||
*
|
*
|
||||||
* @see java.io.OutputStream#close()
|
* @see java.io.OutputStream#close()
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void close() {
|
public void close() {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
if (! closing) {
|
if (! closing) {
|
||||||
|
@ -526,6 +528,7 @@ public class PrintStream extends FilterOutputStream
|
||||||
* @see #print(char)
|
* @see #print(char)
|
||||||
* @see #println(char)
|
* @see #println(char)
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void write(int b) {
|
public void write(int b) {
|
||||||
try {
|
try {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
|
@ -557,6 +560,7 @@ public class PrintStream extends FilterOutputStream
|
||||||
* @param off Offset from which to start taking bytes
|
* @param off Offset from which to start taking bytes
|
||||||
* @param len Number of bytes to write
|
* @param len Number of bytes to write
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void write(byte buf[], int off, int len) {
|
public void write(byte buf[], int off, int len) {
|
||||||
try {
|
try {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
|
@ -574,6 +578,66 @@ public class PrintStream extends FilterOutputStream
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes all bytes from the specified byte array to this stream. If
|
||||||
|
* automatic flushing is enabled then the {@code flush} method will be
|
||||||
|
* invoked.
|
||||||
|
*
|
||||||
|
* <p> Note that the bytes will be written as given; to write characters
|
||||||
|
* that will be translated according to the platform's default character
|
||||||
|
* encoding, use the {@code print(char[])} or {@code println(char[])}
|
||||||
|
* methods.
|
||||||
|
*
|
||||||
|
* @apiNote
|
||||||
|
* Although declared to throw {@code IOException}, this method never
|
||||||
|
* actually does so. Instead, like other methods that this class
|
||||||
|
* overrides, it sets an internal flag which may be tested via the
|
||||||
|
* {@link #checkError()} method. To write an array of bytes without having
|
||||||
|
* to write a {@code catch} block for the {@code IOException}, use either
|
||||||
|
* {@link #writeBytes(byte[] buf) writeBytes(buf)} or
|
||||||
|
* {@link #write(byte[], int, int) write(buf, 0, buf.length)}.
|
||||||
|
*
|
||||||
|
* @implSpec
|
||||||
|
* This method is equivalent to
|
||||||
|
* {@link java.io.PrintStream#write(byte[],int,int)
|
||||||
|
* this.write(buf, 0, buf.length)}.
|
||||||
|
*
|
||||||
|
* @param buf A byte array
|
||||||
|
*
|
||||||
|
* @throws IOException If an I/O error occurs.
|
||||||
|
*
|
||||||
|
* @see #writeBytes(byte[])
|
||||||
|
* @see #write(byte[],int,int)
|
||||||
|
*
|
||||||
|
* @since 14
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void write(byte buf[]) throws IOException {
|
||||||
|
this.write(buf, 0, buf.length);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes all bytes from the specified byte array to this stream.
|
||||||
|
* If automatic flushing is enabled then the {@code flush} method
|
||||||
|
* will be invoked.
|
||||||
|
*
|
||||||
|
* <p> Note that the bytes will be written as given; to write characters
|
||||||
|
* that will be translated according to the platform's default character
|
||||||
|
* encoding, use the {@code print(char[])} or {@code println(char[])}
|
||||||
|
* methods.
|
||||||
|
*
|
||||||
|
* @implSpec
|
||||||
|
* This method is equivalent to
|
||||||
|
* {@link #write(byte[], int, int) this.write(buf, 0, buf.length)}.
|
||||||
|
*
|
||||||
|
* @param buf A byte array
|
||||||
|
*
|
||||||
|
* @since 14
|
||||||
|
*/
|
||||||
|
public void writeBytes(byte buf[]) {
|
||||||
|
this.write(buf, 0, buf.length);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The following private methods on the text- and character-output streams
|
* The following private methods on the text- and character-output streams
|
||||||
* always flush the stream buffers, so that writes to the underlying byte
|
* always flush the stream buffers, so that writes to the underlying byte
|
||||||
|
|
76
test/jdk/java/io/PrintStream/WriteBytes.java
Normal file
76
test/jdk/java/io/PrintStream/WriteBytes.java
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 8187898
|
||||||
|
* @summary Test of writeBytes(byte[])
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.BufferedOutputStream;
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.PrintStream;
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
public class WriteBytes {
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
|
OutputStream out = new BufferedOutputStream(baos, 512);
|
||||||
|
PrintStream ps = new PrintStream(out, false);
|
||||||
|
|
||||||
|
byte[] buf = new byte[128];
|
||||||
|
for (int i = 0; i < buf.length; i++) {
|
||||||
|
buf[i] = (byte)i;
|
||||||
|
}
|
||||||
|
|
||||||
|
ps.writeBytes(buf);
|
||||||
|
assertTrue(baos.size() == 0, "Buffer should not have been flushed");
|
||||||
|
ps.close();
|
||||||
|
assertTrue(baos.size() == buf.length, "Stream size " + baos.size() +
|
||||||
|
" but expected " + buf.length);
|
||||||
|
|
||||||
|
ps = new PrintStream(out, true);
|
||||||
|
ps.writeBytes(buf);
|
||||||
|
assertTrue(baos.size() == 2*buf.length, "Stream size " + baos.size() +
|
||||||
|
" but expected " + 2*buf.length);
|
||||||
|
|
||||||
|
byte[] arr = baos.toByteArray();
|
||||||
|
assertTrue(arr.length == 2*buf.length, "Array length " + arr.length +
|
||||||
|
" but expected " + 2*buf.length);
|
||||||
|
assertTrue(Arrays.equals(buf, 0, buf.length, arr, 0, buf.length),
|
||||||
|
"First write not equal");
|
||||||
|
assertTrue(Arrays.equals(buf, 0, buf.length, arr, buf.length,
|
||||||
|
2*buf.length), "Second write not equal");
|
||||||
|
|
||||||
|
ps.close();
|
||||||
|
ps.writeBytes(buf);
|
||||||
|
assertTrue(ps.checkError(), "Error condition should be true");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void assertTrue(boolean condition, String msg) {
|
||||||
|
if (!condition)
|
||||||
|
throw new RuntimeException(msg);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue