Patch: New JNI tests

Tom Tromey tromey@redhat.com
Fri Jan 26 14:41:00 GMT 2001


This adds a test for the JNI bugs that Martin found.
I'm checking this in now because, since the JNI tests aren't run
automatically, it can't possibly hurt.

2001-01-26  Tom Tromey  <tromey@redhat.com>

	* libjava.jni/martin.out: New file.
	* libjava.jni/martin.c: New file.
	* libjava.jni/martin.java: New file.

Tom

Index: libjava.jni/martin.c
===================================================================
RCS file: martin.c
diff -N martin.c
--- /dev/null	Tue May  5 13:32:27 1998
+++ martin.c	Fri Jan 26 14:39:03 2001
@@ -0,0 +1,41 @@
+#include <jni.h>
+#include "martin.h"
+#include <stdio.h>
+
+void Java_martin_myNative(JNIEnv* env, jobject this, jstring s)
+{
+  jclass cls;
+  jfieldID fid;
+  jobject obj;
+  jmethodID mid;
+
+  printf("From C\n");
+
+  cls = (*env)->FindClass(env, "java/lang/System");
+  if (cls == 0) {
+    printf("java/lang/System lookup failed\n");
+    return;
+  }
+  fid = (*env)->GetStaticFieldID(env, cls, "out", "Ljava/io/PrintStream;");
+  if (fid == 0) {
+    printf("java/lang/System::out lookup failed\n");
+    return;
+  }
+  obj = (*env)->GetStaticObjectField(env, cls, fid);
+  if (obj == 0) {
+    printf("GetStaticObjectField call failed\n");
+    return;
+  }
+  cls = (*env)->GetObjectClass(env, obj);
+  if (cls == 0) {
+    printf("GetObjectClass(out) failed\n");
+    return;
+  }
+  mid = (*env)->GetMethodID(env, cls, "println", "(Ljava/lang/String;)V");
+  if (mid == 0) {
+    printf("println method lookup failed\n");
+    return;
+  }
+  (*env)->CallVoidMethod(env, obj, mid, s);
+}
+
Index: libjava.jni/martin.java
===================================================================
RCS file: martin.java
diff -N martin.java
--- /dev/null	Tue May  5 13:32:27 1998
+++ martin.java	Fri Jan 26 14:39:03 2001
@@ -0,0 +1,21 @@
+// Test case from Martin Kahlert <martin.kahlert@infineon.com>
+
+public class martin {
+  public native void myNative(String s);
+
+  public void myJava(String s) {
+    s = s + ", Java";
+    System.out.println(s);
+  }
+
+  public static void main(String args[]) {
+    martin x = new martin();
+    x.myJava("Hello");
+    x.myNative("Hello, Java (from C)");
+    x.myJava("Goodbye");
+  }
+  
+  static {
+    System.loadLibrary("martin");
+  }
+}
Index: libjava.jni/martin.out
===================================================================
RCS file: martin.out
diff -N martin.out
--- /dev/null	Tue May  5 13:32:27 1998
+++ martin.out	Fri Jan 26 14:39:03 2001
@@ -0,0 +1,4 @@
+Hello, Java
+From C
+Hello, Java (from C)
+Goodbye, Java


More information about the Java-patches mailing list