From: Tom Tromey Date: Wed, 6 Sep 2000 21:20:45 +0000 (+0000) Subject: natMethod.cc (_Jv_CallAnyMethodA): Accept null `args' if method takes no parameters. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=bcf98e48ef4b9eeee82ca6505153216d4b55a22b;p=gcc.git natMethod.cc (_Jv_CallAnyMethodA): Accept null `args' if method takes no parameters. * java/lang/reflect/natMethod.cc (_Jv_CallAnyMethodA): Accept null `args' if method takes no parameters. From-SVN: r36209 --- diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 1c0cbcdc055..7af3054ef3d 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,5 +1,8 @@ 2000-09-06 Tom Tromey + * java/lang/reflect/natMethod.cc (_Jv_CallAnyMethodA): Accept null + `args' if method takes no parameters. + Fix for PR java.lang/339: * java/lang/natPosixProcess.cc (fail): New function. (cleanup): New function. diff --git a/libjava/java/lang/reflect/natMethod.cc b/libjava/java/lang/reflect/natMethod.cc index ef6ab53056d..897285261da 100644 --- a/libjava/java/lang/reflect/natMethod.cc +++ b/libjava/java/lang/reflect/natMethod.cc @@ -447,13 +447,17 @@ _Jv_CallAnyMethodA (jobject obj, { // FIXME: access checks. - if (parameter_types->length != args->length) + if (parameter_types->length == 0 && args == NULL) + { + // The JDK accepts this, so we do too. + } + else if (parameter_types->length != args->length) JvThrow (new java::lang::IllegalArgumentException); int param_count = parameter_types->length; jclass *paramelts = elements (parameter_types); - jobject *argelts = elements (args); + jobject *argelts = args == NULL ? NULL : elements (args); jvalue argvals[param_count]; #define COPY(Where, What, Type) \