5 Debugging Programs

5.1 Debug Command Syntax

cminor debug [debug-options] PROGRAM.cminora [program-arguments]

Debugs program in virtual machine with given program-arguments. Currently programs can be debugged only by interpreting the intermediate instructions in virtual machine, not in native mode.

When the debugger starts, the debugger shell is run. The shell prints the intermediate instructions, and also corresponding source code lines in green.

For example, the following command starts debugging of the dc.cminora program:

> cminor debug assembly/debug/dc.cminora

5.2 Debugger Shell Commands

To obtain help, use the help command, or just give 'h' ENTER:

h(elp)

Debugging is automatically started when the debugger shell is run, but to start the debugging again after program is exited for example, use the following command:

start

To end the debugging session, give the exit command:

e(xit)

To run the program to the next breakpoint or to the end if no breakpoints have been set, use the run commmand:

r(un)

To single-step the program by executing the next intermediate instruction, use the step command:

s(tep)

The single-stepping goes into the called functions. To step over called functions, use the next command:

n(ext)

To print a stack trace, use the stack command:

(stac)k

To print the value of a variable that is in the current scope, use the print command:

p(rint) <name of the variable>

To print the value of a n'th local variable or parameter, use the local command:

l(ocal) <n>

The first parameter is local number 0, second parmeter local number 1, etc.. Local variables have the next indeces after the parameters.

To print the value of n'th value in the operand stack, use the operand command:

o(perand) <n>

The value on top of the stack is number 0, the next operand below it is number 1, etc.

To print value of allocation number <n>, use the allocation command:

a(llocation) <n>

To print value of field number <n> of an object number <m>, or element <n> of array number <m>, use the field command:

f(ield) <n> <m>

To list next 10 source code lines of source file <f> starting from line <n>, use the list command:

(lis)t [<f>]:<n>

To set a breakpoint at line <n> of source file <f>, use the break command:

b(reak) [<f>]:<n>

To clear a breakpoint number <n>, use the clear command:

c(lear) <n>

To show the breakpoints, use the show breakpoints command:

show breakpoints

To repeat latest command, just press ENTER.