/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* This source code is provided to illustrate the usage of a given feature
* or technique and has been deliberately simplified. Additional steps
* required for a production-quality application, such as security checks,
* input validation and proper error handling, might not be present in
* this sample code.
*/
super(new BorderLayout());
final CommandInterpreter interpreter =
new CommandInterpreter(env);
// Establish handler for incoming commands.
public void actionPerformed(ActionEvent e) {
}
});
// Establish ourselves as the listener for VM diagnostics.
new TypeScriptOutputListener(script, true);
// Establish ourselves as the shared debugger typescript.
// Handle VM events.
//### remove listeners on exit!
}
private class TTYDebugListener implements
this.diagnostics = diagnostics;
}
// JDIListener
setThread(e);
locationString(e));
}
}
if (context.getVerboseFlag()) {
}
}
if (context.getVerboseFlag()) {
" unloaded.");
}
}
setThread(e);
}
setThread(e);
if (evt instanceof BreakpointEvent) {
} else if (evt instanceof MethodEntryEvent) {
} else if (evt instanceof MethodExitEvent) {
} else {
}
}
}
setThread(e);
locationString(e));
}
}
if (context.getVerboseFlag()) {
" ended.");
}
}
if (context.getVerboseFlag()) {
" started.");
}
}
}
}
}
// SessionListener
}
}
// SpecListener
}
spec + " when its class is loaded.");
}
}
}
spec + " could not be resolved:" +
e.getReason());
}
//### Add info for watchpoints and exceptions
}
}
}
}
}
}
}
}
}
}
// ContextListener.
// If the user selects a new current thread or frame, update prompt.
// Update prompt only if affect thread is current.
}
}
}
}
if (!e.suspendedNone()) {
//### Current thread should be set elsewhere, e.g.,
//### in ContextManager
//### context.setCurrentThread(thread);
}
}
return DEFAULT_CMD_PROMPT;
} else {
// Frame indices are presented to user as indexed from 1.
}
}
}