summaryrefslogtreecommitdiff
path: root/Examples/test-suite/java/director_thread_runme.java
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2009-08-18 20:56:02 +0000
committerLorry <lorry@roadtrain.codethink.co.uk>2012-09-25 16:59:08 +0000
commit9f8a09ed743cedd9547bf0661d518647966ab114 (patch)
tree9c7803d3b27a8ec22e91792ac7f7932efa128b20 /Examples/test-suite/java/director_thread_runme.java
downloadswig-tarball-master.tar.gz
Imported from /srv/lorry/lorry-area/swig-tarball/swig-1.3.40.tar.gz.HEADswig-1.3.40master
Diffstat (limited to 'Examples/test-suite/java/director_thread_runme.java')
-rw-r--r--Examples/test-suite/java/director_thread_runme.java36
1 files changed, 36 insertions, 0 deletions
diff --git a/Examples/test-suite/java/director_thread_runme.java b/Examples/test-suite/java/director_thread_runme.java
new file mode 100644
index 0000000..c67d410
--- /dev/null
+++ b/Examples/test-suite/java/director_thread_runme.java
@@ -0,0 +1,36 @@
+
+import director_thread.*;
+import java.lang.reflect.*;
+
+public class director_thread_runme {
+
+ static {
+ try {
+ System.loadLibrary("director_thread");
+ } catch (UnsatisfiedLinkError e) {
+ System.err.println("Native code library failed to load. See the chapter on Dynamic Linking Problems in the SWIG Java documentation for help.\n" + e);
+ System.exit(1);
+ }
+ }
+
+ public static void main(String argv[]) {
+ // This test used to hang the process. The solution is to call DetachCurrentThread in ~JNIEnvWrapper, however it causes seg faults in other JNI calls on older JDKs on Solaris. See SWIG_JAVA_NO_DETACH_CURRENT_THREAD in director.swg.
+ director_thread_Derived d = new director_thread_Derived();
+ d.run();
+
+ if (d.getVal() >= 0) {
+ throw new RuntimeException("Failed. Val: " + d.getVal());
+ }
+ }
+}
+
+class director_thread_Derived extends Foo {
+ director_thread_Derived() {
+ super();
+ }
+
+ public void do_foo() {
+ setVal(getVal() - 1);
+ }
+}
+