From bcf98e48ef4b9eeee82ca6505153216d4b55a22b Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Wed, 6 Sep 2000 21:20:45 +0000 Subject: 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 --- libjava/java/lang/reflect/natMethod.cc | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'libjava/java') diff --git a/libjava/java/lang/reflect/natMethod.cc b/libjava/java/lang/reflect/natMethod.cc index ef6ab53..8972852 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) \ -- cgit v1.1