Dmitry Thank you for your review!
Sorry, I do not have any role of OpenJDK yet. So I can't upload webrev. I will send a request for becoming Author after pushing these patches :) Thanks, Yuji 2016-01-19 2:42 GMT+09:00 Dmitry Samersoff <dmitry.samers...@oracle.com>: > Yuji > > Looks good for me. > > Are you a committer? If yes, please prepare a changeset. I'll sponsor > the push. > > -Dmitry > > On 2015-12-15 11:23, KUBOTA Yuji wrote: >> Hi all, >> >> When I ran HSDB by jhsdb on CLI i.e. without x11 display, HSDB could >> not terminate after throwing HeadlessException. >> >> HSDB starts WorkerThread before making the JFrame. If we run HSDB on >> CLI, HSDB throws HeadlessException when makes the JFrame. Thus, the >> WorkerThread has never shutdown, then HSDB can not terminate. >> >> ----- >> Exception in thread "main" java.awt.HeadlessException: >> No X11 DISPLAY variable was set, but this program performed an >> operation which requires it. >> at >> java.awt.GraphicsEnvironment.checkHeadless(GraphicsEnvironment.java:205) >> at java.awt.Window.<init>(Window.java:535) >> at java.awt.Frame.<init>(Frame.java:422) >> at javax.swing.JFrame.<init>(JFrame.java:224) >> at sun.jvm.hotspot.HSDB.run(HSDB.java:140) >> at sun.jvm.hotspot.HSDB.main(HSDB.java:53) >> at sun.jvm.hotspot.SALauncher.runHSDB(SALauncher.java:167) >> at sun.jvm.hotspot.SALauncher.main(SALauncher.java:339) >> ## Waiting for the shutdown of WorkerThread forever... ### >> ----- >> >> I have created a patch from jdk9/dev/hotspot (changeset: >> 9625:de592ea5f7ba) as below. Please review it ! >> >> diff --git a/agent/src/share/classes/sun/jvm/hotspot/HSDB.java >> b/agent/src/share/classes/sun/jvm/hotspot/HSDB.java >> --- a/agent/src/share/classes/sun/jvm/hotspot/HSDB.java >> +++ b/agent/src/share/classes/sun/jvm/hotspot/HSDB.java >> @@ -137,15 +137,16 @@ >> return; >> } >> >> + // Make frame at first, then initialize agent. >> + frame = new JFrame("HSDB - HotSpot Debugger"); >> + frame.setSize(800, 600); >> + frame.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE); >> + >> agent = new HotSpotAgent(); >> workerThread = new WorkerThread(); >> attachMenuItems = new java.util.ArrayList(); >> detachMenuItems = new java.util.ArrayList(); >> >> - frame = new JFrame("HSDB - HotSpot Debugger"); >> - frame.setSize(800, 600); >> - frame.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE); >> - >> JMenuBar menuBar = new JMenuBar(); >> >> // >> >> >> Thanks, >> Yuji >> > > > -- > Dmitry Samersoff > Oracle Java development team, Saint Petersburg, Russia > * I would love to change the world, but they won't give me the sources.