mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-28 07:14:30 +02:00
8201593: Print array length in ArrayIndexOutOfBoundsException
Reviewed-by: dholmes, mdoerr, smonteith, shade, rriggs
This commit is contained in:
parent
b812ae6e51
commit
ac3043c692
34 changed files with 675 additions and 142 deletions
|
@ -251,12 +251,34 @@ void ObjArrayKlass::copy_array(arrayOop s, int src_pos, arrayOop d,
|
|||
|
||||
// Check is all offsets and lengths are non negative
|
||||
if (src_pos < 0 || dst_pos < 0 || length < 0) {
|
||||
THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
|
||||
// Pass specific exception reason.
|
||||
ResourceMark rm;
|
||||
stringStream ss;
|
||||
if (src_pos < 0) {
|
||||
ss.print("arraycopy: source index %d out of bounds for object array[%d]",
|
||||
src_pos, s->length());
|
||||
} else if (dst_pos < 0) {
|
||||
ss.print("arraycopy: destination index %d out of bounds for object array[%d]",
|
||||
dst_pos, d->length());
|
||||
} else {
|
||||
ss.print("arraycopy: length %d is negative", length);
|
||||
}
|
||||
THROW_MSG(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
|
||||
}
|
||||
// Check if the ranges are valid
|
||||
if ( (((unsigned int) length + (unsigned int) src_pos) > (unsigned int) s->length())
|
||||
|| (((unsigned int) length + (unsigned int) dst_pos) > (unsigned int) d->length()) ) {
|
||||
THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
|
||||
if ((((unsigned int) length + (unsigned int) src_pos) > (unsigned int) s->length()) ||
|
||||
(((unsigned int) length + (unsigned int) dst_pos) > (unsigned int) d->length())) {
|
||||
// Pass specific exception reason.
|
||||
ResourceMark rm;
|
||||
stringStream ss;
|
||||
if (((unsigned int) length + (unsigned int) src_pos) > (unsigned int) s->length()) {
|
||||
ss.print("arraycopy: last source index %u out of bounds for object array[%d]",
|
||||
(unsigned int) length + (unsigned int) src_pos, s->length());
|
||||
} else {
|
||||
ss.print("arraycopy: last destination index %u out of bounds for object array[%d]",
|
||||
(unsigned int) length + (unsigned int) dst_pos, d->length());
|
||||
}
|
||||
THROW_MSG(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
|
||||
}
|
||||
|
||||
// Special case. Boundary cases must be checked first
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue