From 2a037395306edc96338073dead70045fcf3167c6 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Thu, 29 Apr 2021 15:35:14 +0000 Subject: [PATCH] 8266014: Regression brought by optimization done with JDK-4926314 Reviewed-by: alanb, naoto --- .../share/classes/java/io/Reader.java | 4 +--- test/jdk/java/io/Reader/ReadCharBuffer.java | 18 +++++++++++++++++- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/src/java.base/share/classes/java/io/Reader.java b/src/java.base/share/classes/java/io/Reader.java index 6fe224a380e..899736e928d 100644 --- a/src/java.base/share/classes/java/io/Reader.java +++ b/src/java.base/share/classes/java/io/Reader.java @@ -188,9 +188,7 @@ public abstract class Reader implements Readable, Closeable { if (target.hasArray()) { char[] cbuf = target.array(); int pos = target.position(); - int rem = target.limit() - pos; - if (rem <= 0) - return -1; + int rem = Math.max(target.limit() - pos, 0); int off = target.arrayOffset() + pos; nread = this.read(cbuf, off, rem); if (nread > 0) diff --git a/test/jdk/java/io/Reader/ReadCharBuffer.java b/test/jdk/java/io/Reader/ReadCharBuffer.java index 1fbadd23676..c57860601fb 100644 --- a/test/jdk/java/io/Reader/ReadCharBuffer.java +++ b/test/jdk/java/io/Reader/ReadCharBuffer.java @@ -23,7 +23,7 @@ /* * @test - * @bug 4926314 + * @bug 4926314 8266014 * @summary Test for Reader#read(CharBuffer). * @run testng ReadCharBuffer */ @@ -33,7 +33,10 @@ import org.testng.annotations.Test; import java.io.IOException; +import java.io.BufferedReader; +import java.io.CharArrayReader; import java.io.Reader; +import java.io.UncheckedIOException; import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.util.Arrays; @@ -98,6 +101,19 @@ public class ReadCharBuffer { assertEquals(buffer.toString(), expected.toString()); } + @Test + public void readZeroLength() { + char[] buf = new char[] {1, 2, 3}; + BufferedReader r = new BufferedReader(new CharArrayReader(buf)); + int n = -1; + try { + n = r.read(CharBuffer.allocate(0)); + } catch (IOException e) { + throw new UncheckedIOException(e); + } + assertEquals(n, 0); + } + private void fillBuffer(CharBuffer buffer) { char[] filler = new char[buffer.remaining()]; Arrays.fill(filler, 'x');