The stepping debugger

Using sourcemaps

Since version 0.7, Indium uses sourcemap files by default.

For sourcemaps to work properly with Chrome/Chromium, make sure that a workspace is correctly set (see Getting up and running).


If your project uses sourcemaps, we advise you to use js-mode with js2-minor-mode instead of js2-mode. js2-mode can be extremely slow at parsing large files (like compiled JavaScript files) that the debugger might open if a stack frame source is not source-mapped. This can happen for instance when using Webpack.

Overriding sourcemap paths

Some sourcemaps cannot be used as is and need path rewriting to map to locations on disks.

Indium provides the configuration option sourceMapPathOverrides for providing custom sourcemap paths.

The default mapping works well for Webpack projects:

  "webpack:///./~/": "${root}/node_modules/",
  "webpack:///./":   "${root}/",
  "webpack:///":     "/",
  "webpack:///src/": "${root}/"

Overriding the sourceMapPathOverrides option will erase the default mapping.


If sourcemaps do not seem to work, you can see how Indium resolves sourcemap paths using M-x indium-list-sourcemap-sources.

Overriding script paths

If your application’s script URLs don’t correspond directly to where their source code is located, you can use scriptPathRegexpOverrides to tell Indium where to find the sources. It maps regular expressions to Javascript substitution strings.

For example, if your project root is /home/user/projects/foo/, and the source code for http://localhost:3000/js/app.js/1234567890 is at /home/user/projects/foo/private/js/app.js, you might set scriptPathRegexpOverrides to:

  "(/js/.*\\.js)/[0-9]+": "private$1"

This removes the trailing slash and digits, and it adds “private” to the beginning of the path below the project root.

Blackboxing scripts

The custom variable indium-debugger-blackbox-regexps holds a list of regular expression of script paths to blackbox when debugging.

Blackboxed scripts are skipped when stepping in the debugger.