src/debug.c - Parrot debugging
This file implements Parrot debugging and is used by parrot_debugger
,
the Parrot debugger,
and the debug
ops.
static void chop_newline
If the C string argument end with a newline,
delete it.
static const char *nextarg
Returns the position just past the current argument in the PASM instruction command
.
This is not the same as skip_command()
,
which is intended for debugger commands.
This function is used for eval
.
static const char *skip_command
Returns the pointer past the current debugger command.
(This is an alternative to the skip_command()
macro above.)
static const char *parse_int
Parse an int
out of a string and return a pointer to just after the int
.
The output parameter intP
contains the parsed value.
static const char *parse_string
Parse a double-quoted string out of a C string and return a pointer to just after the string.
The parsed string is converted to a Parrot STRING
and placed in the output parameter strP
.
static const char *parse_key
Parse an aggregate key out of a string and return a pointer to just after the key.
Currently only string and integer keys are allowed.
static const char *parse_command
Convert the command at the beginning of a string into a numeric value that can be used as a switch key for fast lookup.
static void debugger_cmdline
Debugger command line.Gets and executes commands,
looping until the debugger state is changed,
either to exit or to start executing code.
static void close_script_file
Close the script file,
returning to command prompt mode.
void Parrot_debugger_init
Initializes the Parrot debugger,
if it's not already initialized.
void Parrot_debugger_destroy
Destroy the current Parrot debugger instance.
void Parrot_debugger_load
Loads a Parrot source file for the current program.
void Parrot_debugger_start
Start debugger.
void Parrot_debugger_break
Breaks execution and drops into the debugger.
If we are already into the debugger and it is the first call,
set a breakpoint.When you re run/continue the program being debugged it will pay no attention to the debug ops.RT #42377: clone the interpreter to allow people to play into the debugger and then continue the normal execution of the program.
void PDB_get_command
Get a command from the user input to execute.It saves the last command executed (in pdb->last_command
),
so it first frees the old one and updates it with the current one.Also prints the next line to run if the program is still active.The user input can't be longer than DEBUG_CMD_BUFFER_LENGTH characters.The input is saved in pdb->cur_command
.
void PDB_script_file
Interprets the contents of a file as user input commands
int PDB_run_command
Run a command.Hash the command to make a simple switch calling the correct handler.
void PDB_next
Execute the next N operation(s).Inits the program if needed,
runs the next N >= 1 operations and stops.
void PDB_trace
Execute the next N operations; if no number is specified,
it defaults to 1.
PDB_condition_t *PDB_cond
Analyzes a condition from the user input.
void PDB_watchpoint
Set a watchpoint.
void PDB_set_break
Set a break point,
the source code file must be loaded.
void PDB_init
Init the program.
void PDB_continue
Continue running the program.
If a number is specified,
skip that many breakpoints.
PDB_breakpoint_t *PDB_find_breakpoint
Find breakpoint number N; returns NULL
if the breakpoint doesn't exist or if no breakpoint was specified.
void PDB_disable_breakpoint
Disable a breakpoint; it can be reenabled with the enable command.
void PDB_enable_breakpoint
Reenable a disabled breakpoint; if the breakpoint was not disabled,
has no effect.
void PDB_delete_breakpoint
Delete a breakpoint.
void PDB_delete_condition
Delete a condition associated with a breakpoint.
void PDB_skip_breakpoint
Skip i
times all breakpoints.
char PDB_program_end
End the program.
char PDB_check_condition
Returns true if the condition was met.
static PDB_breakpoint_t *current_breakpoint
>
Returns a pointer to the breakpoint at the current position,
or NULL if there is none.
char PDB_break
Returns true if we have to stop running.
char *PDB_escape
Escapes "
,
\r
,
\n
,
\t
,
\a
and \\
.The returned string must be freed.
int PDB_unescape
Do inplace unescape of \r
,
\n
,
\t
,
\a
and \\
.
size_t PDB_disassemble_op
Disassembles op
.
void PDB_disassemble
Disassemble the bytecode.
long PDB_add_label
Add a label to the label list.
void PDB_free_file
Frees any allocated source files.
void PDB_load_source
Load a source code file.
char PDB_hasinstruction
Return true if the line has an instruction.RT #46129:
- This should take the line,
get an instruction,
get the opcode for that instruction and check that is the correct one.
- Decide what to do with macros if anything.
void PDB_list
Show lines from the source code file.
void PDB_eval
eval
s an instruction.
opcode_t *PDB_compile
Compiles instructions with the PASM compiler.Appends an end
op.This may be called from PDB_eval
above or from the compile opcode which generates a malloced string.
static void dump_string
Dumps the buflen,
flags,
bufused,
strlen,
and offset associated with a string and the string itself.
void PDB_print
Print interp registers.
void PDB_info
Print the interpreter info.
void PDB_help
Print the help text.
"Help" with no arguments prints a list of commands.
"Help xxx" prints information on command xxx.
void PDB_backtrace
Prints a backtrace of the interp's call chain.
static const char *GDB_print_reg
Used by GDB_P to convert register values for display.
Takes register type and number as arguments.Returns a pointer to the start of the string,
(except for PMCs,
which print directly and return "").
static const char *GDB_P
Used by PDB_print to print register values.
Takes a pointer to the register name(s).Returns "" or error message.
static int GDB_B
Inserts a break-point into a table (which it creates if necessary).
Takes an instruction counter (?).Currently unused.Returns break-point count,
or -1 if point is out of bounds.
include/parrot/debugger.h,
src/pdb.c and ops/debug.ops.
- Initial version by Daniel Grunblatt on 2002.5.19.
- Start of rewrite - leo 2005.02.16
The debugger now uses its own interpreter.
User code is run in Interp *debugee.
We have:
debug_interp->pdb->debugee->debugger
^ |
| v
+------------- := -----------+
Debug commands are mostly run inside the debugger
. User code runs of course in the debugee
.