diff options
Diffstat (limited to 'Examples/test-suite/java/director_thread_runme.java')
| -rw-r--r-- | Examples/test-suite/java/director_thread_runme.java | 36 |
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); + } +} + |
