// Check that NullPointerExceptions thrown from library code are // caught. This detects a number of failures that can be caused by // libgcj being built incorrectly. In particular, we ensure that a // SEGV in native (i.e. C++) code in libgcj is handled correctly. // Regrettably, we cannot guarantee that Double.parseDouble() will // always be native code, or that it will never be inlined. It could // be argued that we should add a method to libgcj that will be // guaranteed forever to be native, but I'm reluctant to add to the // library for the sole purpose of performing this test. public class Throw_2 { public static Throwable obj() { return null; } public static String str() { return null; } static double d; public static void main (String[] args) { // This NullPointerException will, at the time of writing, be // thrown from Java code in libgcj. try { java.util.Vector v = new java.util.Vector (null); System.out.println ("fail: no exception thrown"); } catch (NullPointerException _) { System.out.println ("1"); } catch (Throwable _) { System.out.println ("fail: " + _); } // This one will, at the time of writing, be thrown from C++ // code in libgcj. try { d = Double.parseDouble(str()); System.out.println ("fail: no exception thrown"); } catch (NullPointerException _) { System.out.println ("2"); } catch (Throwable _) { System.out.println ("fail: " + _); } } }