提交 e96cf10d 编写于 作者: A alanb

7199551: (bf) CharBuffer.append(CharSequence) throws BufferOverflowException for read-only buffer

Reviewed-by: iris, dxu, chegar
上级 01b3765e
...@@ -741,6 +741,8 @@ public abstract class $Type$Buffer ...@@ -741,6 +741,8 @@ public abstract class $Type$Buffer
public $Type$Buffer put($Type$Buffer src) { public $Type$Buffer put($Type$Buffer src) {
if (src == this) if (src == this)
throw new IllegalArgumentException(); throw new IllegalArgumentException();
if (isReadOnly())
throw new ReadOnlyBufferException();
int n = src.remaining(); int n = src.remaining();
if (n > remaining()) if (n > remaining())
throw new BufferOverflowException(); throw new BufferOverflowException();
...@@ -888,6 +890,8 @@ public abstract class $Type$Buffer ...@@ -888,6 +890,8 @@ public abstract class $Type$Buffer
*/ */
public $Type$Buffer put(String src, int start, int end) { public $Type$Buffer put(String src, int start, int end) {
checkBounds(start, end - start, src.length()); checkBounds(start, end - start, src.length());
if (isReadOnly())
throw new ReadOnlyBufferException();
if (end - start > remaining()) if (end - start > remaining())
throw new BufferOverflowException(); throw new BufferOverflowException();
for (int i = start; i < end; i++) for (int i = start; i < end; i++)
......
...@@ -335,7 +335,7 @@ public class Basic$Type$ ...@@ -335,7 +335,7 @@ public class Basic$Type$
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class Basic$Type$ ...@@ -350,7 +350,7 @@ public class Basic$Type$
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch($type$ [] t, Class ex, Runnable thunk) { private static void tryCatch($type$ [] t, Class<?> ex, Runnable thunk) {
tryCatch($Type$Buffer.wrap(t), ex, thunk); tryCatch($Type$Buffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class Basic$Type$ ...@@ -681,6 +681,14 @@ public class Basic$Type$
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put($Type$Buffer) should not change source position
final $Type$Buffer src = $Type$Buffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -744,6 +752,22 @@ public class Basic$Type$ ...@@ -744,6 +752,22 @@ public class Basic$Type$
#end[byte] #end[byte]
#if[char]
// 7199551
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
String s = new String(new char[rb.remaining() + 1]);
rb.put(s);
}});
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
String s = new String(new char[rb.remaining() + 1]);
rb.append(s);
}});
#end[char]
if (rb.getClass().getName().startsWith("java.nio.Heap")) { if (rb.getClass().getName().startsWith("java.nio.Heap")) {
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
* @summary Unit test for buffers * @summary Unit test for buffers
* @bug 4413135 4414911 4416536 4416562 4418782 4471053 4472779 4490253 4523725 * @bug 4413135 4414911 4416536 4416562 4418782 4471053 4472779 4490253 4523725
* 4526177 4463011 4660660 4661219 4663521 4782970 4804304 4938424 6231529 * 4526177 4463011 4660660 4661219 4663521 4782970 4804304 4938424 6231529
* 6221101 6234263 6535542 6591971 6593946 6795561 7190219 * 6221101 6234263 6535542 6591971 6593946 6795561 7190219 7199551
* @author Mark Reinhold * @author Mark Reinhold
*/ */
......
...@@ -335,7 +335,7 @@ public class BasicByte ...@@ -335,7 +335,7 @@ public class BasicByte
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicByte ...@@ -350,7 +350,7 @@ public class BasicByte
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(byte [] t, Class ex, Runnable thunk) { private static void tryCatch(byte [] t, Class<?> ex, Runnable thunk) {
tryCatch(ByteBuffer.wrap(t), ex, thunk); tryCatch(ByteBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicByte ...@@ -681,6 +681,14 @@ public class BasicByte
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(ByteBuffer) should not change source position
final ByteBuffer src = ByteBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -744,6 +752,22 @@ public class BasicByte ...@@ -744,6 +752,22 @@ public class BasicByte
if (rb.getClass().getName().startsWith("java.nio.Heap")) { if (rb.getClass().getName().startsWith("java.nio.Heap")) {
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
......
...@@ -335,7 +335,7 @@ public class BasicChar ...@@ -335,7 +335,7 @@ public class BasicChar
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicChar ...@@ -350,7 +350,7 @@ public class BasicChar
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(char [] t, Class ex, Runnable thunk) { private static void tryCatch(char [] t, Class<?> ex, Runnable thunk) {
tryCatch(CharBuffer.wrap(t), ex, thunk); tryCatch(CharBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicChar ...@@ -681,6 +681,14 @@ public class BasicChar
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(CharBuffer) should not change source position
final CharBuffer src = CharBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -741,6 +749,22 @@ public class BasicChar ...@@ -741,6 +749,22 @@ public class BasicChar
// 7199551
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
String s = new String(new char[rb.remaining() + 1]);
rb.put(s);
}});
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
String s = new String(new char[rb.remaining() + 1]);
rb.append(s);
}});
......
...@@ -335,7 +335,7 @@ public class BasicDouble ...@@ -335,7 +335,7 @@ public class BasicDouble
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicDouble ...@@ -350,7 +350,7 @@ public class BasicDouble
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(double [] t, Class ex, Runnable thunk) { private static void tryCatch(double [] t, Class<?> ex, Runnable thunk) {
tryCatch(DoubleBuffer.wrap(t), ex, thunk); tryCatch(DoubleBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicDouble ...@@ -681,6 +681,14 @@ public class BasicDouble
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(DoubleBuffer) should not change source position
final DoubleBuffer src = DoubleBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -727,6 +735,22 @@ public class BasicDouble ...@@ -727,6 +735,22 @@ public class BasicDouble
......
...@@ -335,7 +335,7 @@ public class BasicFloat ...@@ -335,7 +335,7 @@ public class BasicFloat
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicFloat ...@@ -350,7 +350,7 @@ public class BasicFloat
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(float [] t, Class ex, Runnable thunk) { private static void tryCatch(float [] t, Class<?> ex, Runnable thunk) {
tryCatch(FloatBuffer.wrap(t), ex, thunk); tryCatch(FloatBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicFloat ...@@ -681,6 +681,14 @@ public class BasicFloat
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(FloatBuffer) should not change source position
final FloatBuffer src = FloatBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -727,6 +735,22 @@ public class BasicFloat ...@@ -727,6 +735,22 @@ public class BasicFloat
......
...@@ -335,7 +335,7 @@ public class BasicInt ...@@ -335,7 +335,7 @@ public class BasicInt
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicInt ...@@ -350,7 +350,7 @@ public class BasicInt
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(int [] t, Class ex, Runnable thunk) { private static void tryCatch(int [] t, Class<?> ex, Runnable thunk) {
tryCatch(IntBuffer.wrap(t), ex, thunk); tryCatch(IntBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicInt ...@@ -681,6 +681,14 @@ public class BasicInt
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(IntBuffer) should not change source position
final IntBuffer src = IntBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -727,6 +735,22 @@ public class BasicInt ...@@ -727,6 +735,22 @@ public class BasicInt
......
...@@ -335,7 +335,7 @@ public class BasicLong ...@@ -335,7 +335,7 @@ public class BasicLong
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicLong ...@@ -350,7 +350,7 @@ public class BasicLong
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(long [] t, Class ex, Runnable thunk) { private static void tryCatch(long [] t, Class<?> ex, Runnable thunk) {
tryCatch(LongBuffer.wrap(t), ex, thunk); tryCatch(LongBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicLong ...@@ -681,6 +681,14 @@ public class BasicLong
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(LongBuffer) should not change source position
final LongBuffer src = LongBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -727,6 +735,22 @@ public class BasicLong ...@@ -727,6 +735,22 @@ public class BasicLong
......
...@@ -335,7 +335,7 @@ public class BasicShort ...@@ -335,7 +335,7 @@ public class BasicShort
fail(problem + String.format(": x=%s y=%s", x, y), xb, yb); fail(problem + String.format(": x=%s y=%s", x, y), xb, yb);
} }
private static void tryCatch(Buffer b, Class ex, Runnable thunk) { private static void tryCatch(Buffer b, Class<?> ex, Runnable thunk) {
boolean caught = false; boolean caught = false;
try { try {
thunk.run(); thunk.run();
...@@ -350,7 +350,7 @@ public class BasicShort ...@@ -350,7 +350,7 @@ public class BasicShort
fail(ex.getName() + " not thrown", b); fail(ex.getName() + " not thrown", b);
} }
private static void tryCatch(short [] t, Class ex, Runnable thunk) { private static void tryCatch(short [] t, Class<?> ex, Runnable thunk) {
tryCatch(ShortBuffer.wrap(t), ex, thunk); tryCatch(ShortBuffer.wrap(t), ex, thunk);
} }
...@@ -681,6 +681,14 @@ public class BasicShort ...@@ -681,6 +681,14 @@ public class BasicShort
bulkPutBuffer(rb); bulkPutBuffer(rb);
}}); }});
// put(ShortBuffer) should not change source position
final ShortBuffer src = ShortBuffer.allocate(1);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() {
rb.put(src);
}});
ck(src, src.position(), 0);
tryCatch(b, ReadOnlyBufferException.class, new Runnable() { tryCatch(b, ReadOnlyBufferException.class, new Runnable() {
public void run() { public void run() {
rb.compact(); rb.compact();
...@@ -727,6 +735,22 @@ public class BasicShort ...@@ -727,6 +735,22 @@ public class BasicShort
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册