8297632: InputStream.transferTo() method should specify what the return value should be when the number of bytes transfered is larger than Long.MAX_VALUE
Reviewed-by: alanb, lancea
This commit is contained in:
parent
f7dee77d73
commit
5b2d430131
@ -614,7 +614,11 @@ public class BufferedInputStream extends FilterInputStream {
|
||||
out.write(buffer);
|
||||
pos = count;
|
||||
}
|
||||
return avail + getInIfOpen().transferTo(out);
|
||||
try {
|
||||
return Math.addExact(avail, getInIfOpen().transferTo(out));
|
||||
} catch (ArithmeticException ignore) {
|
||||
return Long.MAX_VALUE;
|
||||
}
|
||||
} else {
|
||||
return super.transferTo(out);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1994, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1994, 2023, 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
|
||||
@ -392,7 +392,11 @@ public class FileInputStream extends InputStream
|
||||
return transferred;
|
||||
}
|
||||
}
|
||||
return transferred + super.transferTo(out);
|
||||
try {
|
||||
return Math.addExact(transferred, super.transferTo(out));
|
||||
} catch (ArithmeticException ignore) {
|
||||
return Long.MAX_VALUE;
|
||||
}
|
||||
}
|
||||
|
||||
private long length() throws IOException {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1994, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1994, 2023, 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
|
||||
@ -769,6 +769,9 @@ public abstract class InputStream implements Closeable {
|
||||
* interrupted during the transfer, is highly input and output stream
|
||||
* specific, and therefore not specified.
|
||||
* <p>
|
||||
* If the total number of bytes transferred is greater than {@linkplain
|
||||
* Long#MAX_VALUE}, then {@code Long.MAX_VALUE} will be returned.
|
||||
* <p>
|
||||
* If an I/O error occurs reading from the input stream or writing to the
|
||||
* output stream, then it may do so after some bytes have been read or
|
||||
* written. Consequently the input stream may not be at end of stream and
|
||||
@ -789,7 +792,13 @@ public abstract class InputStream implements Closeable {
|
||||
int read;
|
||||
while ((read = this.read(buffer, 0, DEFAULT_BUFFER_SIZE)) >= 0) {
|
||||
out.write(buffer, 0, read);
|
||||
transferred += read;
|
||||
if (transferred < Long.MAX_VALUE) {
|
||||
try {
|
||||
transferred = Math.addExact(transferred, read);
|
||||
} catch (ArithmeticException ignore) {
|
||||
transferred = Long.MAX_VALUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
return transferred;
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1994, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1994, 2023, 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
|
||||
@ -421,7 +421,11 @@ public class PushbackInputStream extends FilterInputStream {
|
||||
out.write(buffer);
|
||||
pos = buffer.length;
|
||||
}
|
||||
return avail + in.transferTo(out);
|
||||
try {
|
||||
return Math.addExact(avail, in.transferTo(out));
|
||||
} catch (ArithmeticException ignore) {
|
||||
return Long.MAX_VALUE;
|
||||
}
|
||||
} else {
|
||||
return super.transferTo(out);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1996, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1996, 2023, 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
|
||||
@ -421,6 +421,9 @@ public abstract class Reader implements Readable, Closeable {
|
||||
* interrupted during the transfer, is highly reader and writer
|
||||
* specific, and therefore not specified.
|
||||
* <p>
|
||||
* If the total number of characters transferred is greater than {@linkplain
|
||||
* Long#MAX_VALUE}, then {@code Long.MAX_VALUE} will be returned.
|
||||
* <p>
|
||||
* If an I/O error occurs reading from the reader or writing to the
|
||||
* writer, then it may do so after some characters have been read or
|
||||
* written. Consequently the reader may not be at end of the stream and
|
||||
@ -441,7 +444,13 @@ public abstract class Reader implements Readable, Closeable {
|
||||
int nRead;
|
||||
while ((nRead = read(buffer, 0, TRANSFER_BUFFER_SIZE)) >= 0) {
|
||||
out.write(buffer, 0, nRead);
|
||||
transferred += nRead;
|
||||
if (transferred < Long.MAX_VALUE) {
|
||||
try {
|
||||
transferred = Math.addExact(transferred, nRead);
|
||||
} catch (ArithmeticException ignore) {
|
||||
transferred = Long.MAX_VALUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
return transferred;
|
||||
}
|
||||
|
@ -240,12 +240,18 @@ public class SequenceInputStream extends InputStream {
|
||||
public long transferTo(OutputStream out) throws IOException {
|
||||
Objects.requireNonNull(out, "out");
|
||||
if (getClass() == SequenceInputStream.class) {
|
||||
long c = 0;
|
||||
long transferred = 0;
|
||||
while (in != null) {
|
||||
c += in.transferTo(out);
|
||||
if (transferred < Long.MAX_VALUE) {
|
||||
try {
|
||||
transferred = Math.addExact(transferred, in.transferTo(out));
|
||||
} catch (ArithmeticException ignore) {
|
||||
return Long.MAX_VALUE;
|
||||
}
|
||||
}
|
||||
nextStream();
|
||||
}
|
||||
return c;
|
||||
return transferred;
|
||||
} else {
|
||||
return super.transferTo(out);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1996, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1996, 2023, 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
|
||||
@ -350,6 +350,9 @@ public class ZipInputStream extends InflaterInputStream implements ZipConstants
|
||||
* interrupted during the transfer, is highly input and output stream
|
||||
* specific, and therefore not specified.
|
||||
* <p>
|
||||
* If the total number of bytes transferred is greater than {@linkplain
|
||||
* Long#MAX_VALUE}, then {@code Long.MAX_VALUE} will be returned.
|
||||
* <p>
|
||||
* If an I/O error occurs reading from the input stream or writing to the
|
||||
* output stream, then it may do so after some bytes have been read or
|
||||
* written. Consequently, the input stream may not be at end of stream and
|
||||
|
Loading…
Reference in New Issue
Block a user