Turing Debugger Guide

Introduction

Turing supports a number of tools to enable users to debug their programs and examine program execution. Some of the available tools are: As of May 2002, the Turing 4.1 software does not contain the following feature: This feature will be implemented as time and developer resources permit.

Displaying The Debugger Menu

In order to use any of the debugger commands, you need to have the Debugger menu showing in the Editor window. By default, the Debugger menu is hidden in order to simplify the Turing environment for the majority of students not using the debugger.

There are two ways that the Debugger menu can be displayed. You can select the Show Debugger Menu command in the Run menu.


Show Debugger Menu command in the Run menu

If you are consistenly using the debugger, then you should change the Preferences so that the Debugger menu is always displayed. This can be done by bringing up the Editor Window pane of the Preferences dialog box and setting the Always Show 'Debugger' Menu check box.


Always Show 'Debugger' Menu in the Editor Window Pane

Using The Debugger Menu


Show Debugger Menu command in the Run menu

The Debugger menu gives you access to all the debugging features in Turing 4.0. The following menu options are available:

Turing Execution

The rest of this document will use some terms that must be understood properly.

Stepping a Program

Stepping a program consists of executing a Turing program a line at a time. After each step command, execution pauses, highlighting the next line to be executed. To step a program, the program must not be running. The Debugger controls in the Editor window must be visible. To step the program, the user clicks one of the three buttons in the Debugger Controls:

Tracing a Program

Tracing a program is simply executing a program slowly with each line of code in the program being highlighted as it is executed. Tracing allows users to see how control constructs operate. Unlike stepping, with tracing, execution continues until it is paused or halted in some other fashion.

To start a program tracing, the Debugger Controls must be visible. The user then clicks the Trace Execution check box. When the program is next running, each time a statement is executed, the line in the source code will be highlighted. The speed at which the tracing occurs is controlled by the Trace Speed slider found in the Debugger Controls. When the slider is on the left, there is essentially no delay between execution of statements. (Note that execution will still be much slower than not tracing due to the time taken to highlight each executing statement.) When the slider is on the right, each statement will wait for about 5 seconds after executing before the next statement is executed.

Setting Breakpoints

Often only a particular section of code is of interest to the user. Breakpoints provide a mechanism for pausing a program only when execution reaches a specified statement. To set breakpoints, they need to be displayed in the Editor window. This is done with the Show Breakpoints command in the Debugger menu. Once breakpoints are visible, they can be set (and removed) by simply clicking the mouse in the breakpoint area. When the mouse is over the breakpoint area, it turns into a diamond. When the breakpoint is set, a red diamond appears in the breakpoint area. To remove the breakpoint, simply click the red diamond and the breakpoint disappears.


Window with Two Breakpoints Set

When execution reaches a line with a breakpoint on it, the program pauses and the line is highlighted. The program can then be resumed or stepped as desired. Note that it is possible to set a breakpoint on a line that is not executed. If you place a breakpoint on a blank line, it is quite likely that execution will not stop. Likewise, in lines broken over multiple lines, it is best to put the breakpoint on the last line in the statement.

To clear all the breakpoints, select Clear Breakpoints from the Debugger menu.

Viewing Open Files/Pictures/Fonts, etc.

A common error in Turing programs is to neglect to close open files (using the Close statement) or free pictures or fonts (using the Pic.Free or Font.Free procedures). The Allocated Objects window displays all allocated resources until they are freed. This window is displayed by selecting the Show Allocated Objects command from the Debugger menu. The command can be given even after a program has halted. It is a useful command to use when am open, Pic.New or Font.New has failed because of too many open files, pictures or fonts.

The window will also display just how much memory each picture takes up.


Allocated Objects Window

Clicking on the line containing the allocated object will highlight the line in the code where the object was allocated. The headings on each of the columns can be clicked allowing the objects to be sorted either by their ID, or by where in the program they were allocated.