From 19a73fe6580a1ef56d637f2a859ea408f291dc95 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Wed, 30 Dec 2015 09:57:40 +0530 Subject: [PATCH] 8146253: jjs should look for "doc string" property to print documentation on shift-tab Reviewed-by: attila --- .../classes/jdk/nashorn/tools/jjs/Main.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/Main.java b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/Main.java index d8a464ce35d..c19f5bec5ff 100644 --- a/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/Main.java +++ b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/Main.java @@ -47,10 +47,10 @@ import jdk.nashorn.internal.objects.Global; import jdk.nashorn.internal.objects.NativeJava; import jdk.nashorn.internal.runtime.Context; import jdk.nashorn.internal.runtime.NativeJavaPackage; -import jdk.nashorn.internal.runtime.JSType; import jdk.nashorn.internal.runtime.Property; import jdk.nashorn.internal.runtime.ScriptEnvironment; import jdk.nashorn.internal.runtime.ScriptFunction; +import jdk.nashorn.internal.runtime.ScriptObject; import jdk.nashorn.internal.runtime.ScriptRuntime; import jdk.nashorn.tools.Shell; @@ -60,6 +60,8 @@ import jdk.nashorn.tools.Shell; public final class Main extends Shell { private Main() {} + private static final String DOC_PROPERTY_NAME = "__doc__"; + static final boolean DEBUG = Boolean.getBoolean("nashorn.jjs.debug"); static final boolean HEADLESS = GraphicsEnvironment.isHeadless(); @@ -132,12 +134,17 @@ public final class Main extends Shell { final String pkgName = ((NativeJavaPackage)res).getName(); final String url = pkgName.replace('.', '/') + "/package-summary.html"; openBrowserForJavadoc(url); - } else if (res instanceof ScriptFunction) { - return ((ScriptFunction)res).getDocumentation(); + } else if (res instanceof ScriptObject) { + final ScriptObject sobj = (ScriptObject)res; + if (sobj.has(DOC_PROPERTY_NAME)) { + return toString(sobj.get(DOC_PROPERTY_NAME), global); + } else if (sobj instanceof ScriptFunction) { + return ((ScriptFunction)sobj).getDocumentation(); + } } // FIXME: better than toString for other cases? - return JSType.toString(res); + return toString(res, global); } } catch (Exception ignored) { } @@ -253,7 +260,7 @@ public final class Main extends Shell { try { final Object res = context.eval(global, source, global, ""); if (res != UNDEFINED) { - err.println(JSType.toString(res)); + err.println(toString(res, global)); } } catch (final Exception e) { err.println(e);