|Did you know ...||Search Documentation:|
|Title for pldoc(object(section(2,'3.5',swi('/doc/Manual/guitracer.html'))))|
SWI-Prolog offers two debuggers. One is the traditional text console-based 4-port Prolog tracer and the other is a window-based source level debugger. The window-based debugger requires XPCE installed. It operates based on the prolog_trace_interception/4 hook and other low-level functionality described in chapter B.
Window-based tracing provides a much better overview due to the eminent relation to your source code, a clear list of named variables and their bindings as well as a graphical overview of the call and choice point stack. There are some drawbacks though. Using a textual trace on the console, one can scroll back and examine the past, while the graphical debugger just presents a (much better) overview of the current state.
Whether the text-based or window-based debugger is used is controlled
using the predicates guitracer/0
Entering debug mode is controlled using the normal predicates for this: trace/0
In addition, PceEmacs prolog mode provides the command
Prolog/Break at (
Control-c b) to insert a
break-point at a specific location in the source code.
The graphical tracer is particulary useful for debugging threads. The
tracer must be loaded from the
main thread before it can be
used from a background thread.