From 0cf2e90d174aae96e4b030faca0bd4474c510b31 Mon Sep 17 00:00:00 2001 From: Dmitry Samersoff Date: Fri, 27 May 2016 19:31:17 +0300 Subject: [PATCH] 8152950: BasicLauncherTest.java fails due to type error Better handle js engine initialization error Reviewed-by: jbachorik --- .../sun/jvm/hotspot/CommandProcessor.java | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/CommandProcessor.java b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/CommandProcessor.java index 5374a5a40e6..916cb445387 100644 --- a/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/CommandProcessor.java +++ b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/CommandProcessor.java @@ -1712,7 +1712,8 @@ public class CommandProcessor { // called after debuggee attach private void postAttach() { // create JavaScript engine and start it - jsengine = new JSJavaScriptEngine() { + try { + jsengine = new JSJavaScriptEngine() { private ObjectReader reader = new ObjectReader(); private JSJavaFactory factory = new JSJavaFactoryImpl(); public ObjectReader getObjectReader() { @@ -1735,17 +1736,24 @@ public class CommandProcessor { return err; } }; - try { - jsengine.defineFunction(this, + try { + jsengine.defineFunction(this, this.getClass().getMethod("registerCommand", new Class[] { String.class, String.class, String.class })); - } catch (NoSuchMethodException exp) { - // should not happen, see below...!! - exp.printStackTrace(); + } catch (NoSuchMethodException exp) { + // should not happen, see below...!! + exp.printStackTrace(); + } + jsengine.start(); + } + catch (Exception ex) { + System.out.println("Warning! JS Engine can't start, some commands will not be available."); + if (verboseExceptions) { + ex.printStackTrace(out); + } } - jsengine.start(); } public void registerCommand(String cmd, String usage, final String func) {