Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "JSDT/Debug"

(Development)
(Development)
Line 44: Line 44:
 
is loading scripts on demand. [[/Using_Rhino_Console|This page]] describes how to launch with the Rhino console and some common usage scenarios.
 
is loading scripts on demand. [[/Using_Rhino_Console|This page]] describes how to launch with the Rhino console and some common usage scenarios.
  
=== Using the Crossfire Debugger ===
+
==== Using the Crossfire Debugger ====
  
 
An alternative debugger that interacts with Firebug using Crossfire is under development.  [[/Using_Crossfire_Debugger|This page]] describes how to try and get the experimental version of the debugger up and running.
 
An alternative debugger that interacts with Firebug using Crossfire is under development.  [[/Using_Crossfire_Debugger|This page]] describes how to try and get the experimental version of the debugger up and running.
 +
 +
==== Using the Google Chrome Debugger ====
 +
 +
Another alternative debugger that can be tested is using v8 for Google Chrome. [[/Using_Google_Chrome_Debugger|This page]] describes how to try and get the experimental version up and running.
  
 
== Testing ==
 
== Testing ==

Revision as of 16:23, 20 July 2010

JSDT Debug
Website
Download
Community
Mailing ListForumsIRCmattermost
Issues
OpenHelp WantedBug Day
Contribute
Browse SourceProject Set File

The JSDT debug project brings a variety of JavaScript debugging support to the JSDT using a common UI and communicating using a common protocol - JavaScript Debug Interface (JSDI). The common interface for the debugger emulates that of the platform and JDT debugger to allow a smooth transition and ease of use for the JSDT debugger.

Currently we have debugging support for Rhino and an incubation version of Crossfire / Firebug support.

Bundles

The entire JSDT debugger is comprised of several bundles:

  • org.eclipse.wst.jsdt.debug.core - contains the JSDI specification and debug model elements.
  • org.eclipse.wst.jsdt.debug.crossfire (incubation) - contains a Crossfire implementation of the debugger.
  • org.eclipse.wst.jsdt.debug.rhino - contains a Rhino implementation of the debugger.
  • org.eclipse.wst.jsdt.debug.rhino.debugger - contains the Rhino debug hooks to connect to the Rhino interpreter.
  • org.eclipse.wst.jsdt.debug.ui - contains the shared UI presentation for the debugger implementations.
  • org.eclipse.wst.jsdt.debug.core.tests - contains related test cases for the debug core.
  • org.eclipse.wst.jsdt.debug.rhino.tests - contains Rhino specific tests.

All of the bundles required for development of the JSDT debugger can be acquired using the team project set file here.

Planning

JSDT Debug follows directly the project plan for JSDT.

Development

Rhino Debug Wire Protocol

To provide support for the Rhino interpreter, we had to create both sides of the coin - the debugger and the client. To facilitate communication between the debugger and the client we created an adapted version of v8 (JSON-based) packet communication. The complete specification for the RDWP can be found here.

JavaScript Debug Interface (JSDI)

The JSDI is used to provide a common way for our models and UI to communicate with a variety of debugger back-ends - write one UI + model and provide additional debuggers. The complete specification for the JSDI can be found here.

Embedding the Rhino Debugger

To use the Rhino debug support it must be linked to a running Rhino interpreter. This page describes how to do this.

Using the Rhino Debug Console

Launching the Rhino debugger with the Rhino console available is a very powerful tool that allows developers to perform many operations, one notable operation is loading scripts on demand. This page describes how to launch with the Rhino console and some common usage scenarios.

Using the Crossfire Debugger

An alternative debugger that interacts with Firebug using Crossfire is under development. This page describes how to try and get the experimental version of the debugger up and running.

Using the Google Chrome Debugger

Another alternative debugger that can be tested is using v8 for Google Chrome. This page describes how to try and get the experimental version up and running.

Testing

Smoke Tests, scenarios, example scripts and more to aid testing.

Back to the top