2012-02-28 03:08:17 +08:00
|
|
|
# Debugger
|
|
|
|
|
2012-03-03 07:14:03 +08:00
|
|
|
Stability: 3 - Stable
|
|
|
|
|
2012-02-28 03:44:30 +08:00
|
|
|
<!-- type=misc -->
|
2010-12-31 10:46:49 +08:00
|
|
|
|
2011-02-25 08:36:43 +08:00
|
|
|
V8 comes with an extensive debugger which is accessible out-of-process via a
|
2010-12-31 10:46:49 +08:00
|
|
|
simple [TCP protocol](http://code.google.com/p/v8/wiki/DebuggerProtocol).
|
|
|
|
Node has a built-in client for this debugger. To use this, start Node with the
|
|
|
|
`debug` argument; a prompt will appear:
|
|
|
|
|
|
|
|
% node debug myscript.js
|
2011-09-25 19:10:21 +08:00
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting... ok
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:1
|
|
|
|
1 x = 5;
|
|
|
|
2 setTimeout(function () {
|
|
|
|
3 debugger;
|
2010-12-31 10:46:49 +08:00
|
|
|
debug>
|
|
|
|
|
|
|
|
Node's debugger client doesn't support the full range of commands, but
|
|
|
|
simple step and inspection is possible. By putting the statement `debugger;`
|
|
|
|
into the source code of your script, you will enable a breakpoint.
|
|
|
|
|
|
|
|
For example, suppose `myscript.js` looked like this:
|
|
|
|
|
|
|
|
// myscript.js
|
|
|
|
x = 5;
|
|
|
|
setTimeout(function () {
|
|
|
|
debugger;
|
|
|
|
console.log("world");
|
|
|
|
}, 1000);
|
|
|
|
console.log("hello");
|
|
|
|
|
|
|
|
Then once the debugger is run, it will break on line 4.
|
|
|
|
|
2011-09-25 19:10:21 +08:00
|
|
|
% node debug myscript.js
|
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting... ok
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:1
|
|
|
|
1 x = 5;
|
|
|
|
2 setTimeout(function () {
|
|
|
|
3 debugger;
|
|
|
|
debug> cont
|
|
|
|
< hello
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:3
|
|
|
|
1 x = 5;
|
|
|
|
2 setTimeout(function () {
|
|
|
|
3 debugger;
|
|
|
|
4 console.log("world");
|
|
|
|
5 }, 1000);
|
2010-12-31 10:46:49 +08:00
|
|
|
debug> next
|
2011-09-25 19:10:21 +08:00
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:4
|
|
|
|
2 setTimeout(function () {
|
|
|
|
3 debugger;
|
|
|
|
4 console.log("world");
|
|
|
|
5 }, 1000);
|
|
|
|
6 console.log("hello");
|
|
|
|
debug> repl
|
|
|
|
Press Ctrl + C to leave debug repl
|
|
|
|
> x
|
2010-12-31 10:46:49 +08:00
|
|
|
5
|
2011-09-25 19:10:21 +08:00
|
|
|
> 2+2
|
2010-12-31 10:46:49 +08:00
|
|
|
4
|
|
|
|
debug> next
|
2011-09-25 19:10:21 +08:00
|
|
|
< world
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:5
|
|
|
|
3 debugger;
|
|
|
|
4 console.log("world");
|
|
|
|
5 }, 1000);
|
|
|
|
6 console.log("hello");
|
|
|
|
7
|
2010-12-31 10:46:49 +08:00
|
|
|
debug> quit
|
|
|
|
%
|
|
|
|
|
|
|
|
|
2011-09-25 19:10:21 +08:00
|
|
|
The `repl` command allows you to evaluate code remotely. The `next` command
|
|
|
|
steps over to the next line. There are a few other commands available and more
|
2011-10-01 15:28:57 +08:00
|
|
|
to come. Type `help` to see others.
|
2010-12-31 10:46:49 +08:00
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
## Watchers
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
You can watch expression and variable values while debugging your code.
|
|
|
|
On every breakpoint each expression from the watchers list will be evaluated
|
|
|
|
in the current context and displayed just before the breakpoint's source code
|
|
|
|
listing.
|
|
|
|
|
|
|
|
To start watching an expression, type `watch("my_expression")`. `watchers`
|
|
|
|
prints the active watchers. To remove a watcher, type
|
|
|
|
`unwatch("my_expression")`.
|
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
## Commands reference
|
2011-10-01 15:28:57 +08:00
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
### Stepping
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
* `cont`, `c` - Continue execution
|
|
|
|
* `next`, `n` - Step next
|
|
|
|
* `step`, `s` - Step in
|
|
|
|
* `out`, `o` - Step out
|
2013-03-28 22:19:10 +08:00
|
|
|
* `pause` - Pause running code (like pause button in Developer Tools)
|
2011-10-01 15:28:57 +08:00
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
### Breakpoints
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
* `setBreakpoint()`, `sb()` - Set breakpoint on current line
|
2011-12-20 05:09:54 +08:00
|
|
|
* `setBreakpoint(line)`, `sb(line)` - Set breakpoint on specific line
|
2011-10-01 15:28:57 +08:00
|
|
|
* `setBreakpoint('fn()')`, `sb(...)` - Set breakpoint on a first statement in
|
|
|
|
functions body
|
|
|
|
* `setBreakpoint('script.js', 1)`, `sb(...)` - Set breakpoint on first line of
|
|
|
|
script.js
|
2014-12-17 00:27:31 +08:00
|
|
|
* `clearBreakpoint('script.js', 1)`, `cb(...)` - Clear breakpoint in script.js
|
|
|
|
on line 1
|
2011-10-01 15:28:57 +08:00
|
|
|
|
2013-04-26 14:05:33 +08:00
|
|
|
It is also possible to set a breakpoint in a file (module) that
|
|
|
|
isn't loaded yet:
|
|
|
|
|
|
|
|
% ./node debug test/fixtures/break-in-module/main.js
|
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting to port 5858... ok
|
|
|
|
break in test/fixtures/break-in-module/main.js:1
|
|
|
|
1 var mod = require('./mod.js');
|
|
|
|
2 mod.hello();
|
|
|
|
3 mod.hello();
|
|
|
|
debug> setBreakpoint('mod.js', 23)
|
|
|
|
Warning: script 'mod.js' was not loaded yet.
|
|
|
|
1 var mod = require('./mod.js');
|
|
|
|
2 mod.hello();
|
|
|
|
3 mod.hello();
|
|
|
|
debug> c
|
|
|
|
break in test/fixtures/break-in-module/mod.js:23
|
|
|
|
21
|
|
|
|
22 exports.hello = function() {
|
|
|
|
23 return 'hello from module';
|
|
|
|
24 };
|
|
|
|
25
|
|
|
|
debug>
|
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
### Info
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
* `backtrace`, `bt` - Print backtrace of current execution frame
|
|
|
|
* `list(5)` - List scripts source code with 5 line context (5 lines before and
|
|
|
|
after)
|
|
|
|
* `watch(expr)` - Add expression to watch list
|
|
|
|
* `unwatch(expr)` - Remove expression from watch list
|
|
|
|
* `watchers` - List all watchers and their values (automatically listed on each
|
|
|
|
breakpoint)
|
|
|
|
* `repl` - Open debugger's repl for evaluation in debugging script's context
|
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
### Execution control
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
* `run` - Run script (automatically runs on debugger's start)
|
|
|
|
* `restart` - Restart script
|
|
|
|
* `kill` - Kill script
|
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
### Various
|
2011-10-01 15:28:57 +08:00
|
|
|
|
|
|
|
* `scripts` - List all loaded scripts
|
|
|
|
* `version` - Display v8's version
|
2010-12-31 10:46:49 +08:00
|
|
|
|
2012-02-28 03:08:17 +08:00
|
|
|
## Advanced Usage
|
2010-12-31 10:46:49 +08:00
|
|
|
|
|
|
|
The V8 debugger can be enabled and accessed either by starting Node with
|
|
|
|
the `--debug` command-line flag or by signaling an existing Node process
|
|
|
|
with `SIGUSR1`.
|
2012-12-06 08:01:41 +08:00
|
|
|
|
|
|
|
Once a process has been set in debug mode with this it can be connected to
|
|
|
|
with the node debugger. Either connect to the `pid` or the URI to the debugger.
|
|
|
|
The syntax is:
|
|
|
|
|
|
|
|
* `node debug -p <pid>` - Connects to the process via the `pid`
|
2013-07-25 02:17:28 +08:00
|
|
|
* `node debug <URI>` - Connects to the process via the URI such as localhost:5858
|