From 1808372b58b95d18ce62168ddf78c0ffbbcc6d6e Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Fri, 14 Dec 2001 21:56:29 +0000 Subject: For PR libgcj/5103: * libjava.jni/cxxtest.out: New file. * libjava.jni/cxxtest.cc: New file. * libjava.jni/cxxtest.java: New file. * libjava.jni/jni.exp (gcj_jni_test_one): If there is no .c file, assume there is a .cc file. From-SVN: r48012 --- libjava/testsuite/ChangeLog | 9 +++++++++ libjava/testsuite/libjava.jni/cxxtest.cc | 24 ++++++++++++++++++++++++ libjava/testsuite/libjava.jni/cxxtest.java | 25 +++++++++++++++++++++++++ libjava/testsuite/libjava.jni/cxxtest.out | 1 + libjava/testsuite/libjava.jni/jni.exp | 9 ++++++++- 5 files changed, 67 insertions(+), 1 deletion(-) create mode 100644 libjava/testsuite/libjava.jni/cxxtest.cc create mode 100644 libjava/testsuite/libjava.jni/cxxtest.java create mode 100644 libjava/testsuite/libjava.jni/cxxtest.out diff --git a/libjava/testsuite/ChangeLog b/libjava/testsuite/ChangeLog index 70777e8..de7df24 100644 --- a/libjava/testsuite/ChangeLog +++ b/libjava/testsuite/ChangeLog @@ -1,3 +1,12 @@ +2001-12-13 Tom Tromey + + For PR libgcj/5103: + * libjava.jni/cxxtest.out: New file. + * libjava.jni/cxxtest.cc: New file. + * libjava.jni/cxxtest.java: New file. + * libjava.jni/jni.exp (gcj_jni_test_one): If there is no .c file, + assume there is a .cc file. + 2001-12-09 Bryce McKinlay * libjava.lang/PR3731.out: Adjust output to reflect that "instanceof" diff --git a/libjava/testsuite/libjava.jni/cxxtest.cc b/libjava/testsuite/libjava.jni/cxxtest.cc new file mode 100644 index 0000000..577273b --- /dev/null +++ b/libjava/testsuite/libjava.jni/cxxtest.cc @@ -0,0 +1,24 @@ +#include +#include + +jobjectArray +Java_cxxtest_fetch (JNIEnv *env, jobject _this) +{ + jclass cls; + jfieldID fid; + jobjectArray obj; + + cls = env->GetObjectClass (_this); + if (! cls) + return 0; + + fid = env->GetFieldID (cls, "F", "[Ljava/lang/Object;"); + if (! fid) + return 0; + + obj = reinterpret_cast (env->GetObjectField (_this, fid)); + + return obj; +} + + diff --git a/libjava/testsuite/libjava.jni/cxxtest.java b/libjava/testsuite/libjava.jni/cxxtest.java new file mode 100644 index 0000000..b1c3bb9 --- /dev/null +++ b/libjava/testsuite/libjava.jni/cxxtest.java @@ -0,0 +1,25 @@ +// Test for array field lookup. + +public class cxxtest +{ + // A field for us to look up. + public Object[] F = new Object[7]; + + public native Object[] fetch (); + + public void doit () + { + System.out.println (F == fetch ()); + } + + public static void main (String[] args) + { + cxxtest q = new cxxtest (); + q.doit (); + } + + static + { + System.loadLibrary ("cxxtest"); + } +} diff --git a/libjava/testsuite/libjava.jni/cxxtest.out b/libjava/testsuite/libjava.jni/cxxtest.out new file mode 100644 index 0000000..27ba77d --- /dev/null +++ b/libjava/testsuite/libjava.jni/cxxtest.out @@ -0,0 +1 @@ +true diff --git a/libjava/testsuite/libjava.jni/jni.exp b/libjava/testsuite/libjava.jni/jni.exp index 583462b..ec59945 100644 --- a/libjava/testsuite/libjava.jni/jni.exp +++ b/libjava/testsuite/libjava.jni/jni.exp @@ -106,6 +106,13 @@ proc gcj_jni_test_one {file} { } set cfile [file rootname $file].c + set cxxflags "" + # If there is no `.c' file, assume there is a `.cc' file. + if {! [file exists $cfile]} { + set cfile [file rootname $file].cc + set cxxflags "-lstdc++" + } + if {! [gcj_jni_compile_c_to_so $cfile]} { # FIXME return 0 @@ -113,7 +120,7 @@ proc gcj_jni_test_one {file} { # We use -l$main because the .so is named the same as the main # program. - set args [list "additional_flags=-fjni -L. -l$main"] + set args [list "additional_flags=-fjni -L. -l$main $cxxflags"] if {! [gcj_link $main $main $file $args]} { # FIXME return 0 -- cgit v1.1