NAME

Devel::Chitin::Actionable - Get and set breakpoints and actions

SYNOPSIS

my $unconditional_bp = Devel::Chitin::Breakpoint->new(
                          file => $filename, line => 123 );

my $conditional_bp = Devel::Chitin::Breakpoint->new(
                          file => $filename, $line => 123,
                          code => q($a eq 'stop'));

my $inactive_bp = Devel::Chitin::Breakpoint->new(
                          file => $filename, $line 123,
                          inactive => 1);

my @bp = Devel::Chitin::Breakpoint->get(file => $filename, line => 123);
printf("breakpoint on line %d of %s: %s\n",
          $bp[0]->line, $b[0]->file, $bp[0]->code);

DESCRIPTION

Used to manipulate breakpoints and actions in the debugged program. Breakpoints are used to stop execution of the debugged program and let the debugging system take control there. Actions are used to run arbitrary code before a line in the debugged program executes.

Breakpoints

Breakpoints are associated with a file and line number, and the same file/line combination may have more than one breakpoint. At each line with one or more breakpoints, all those breakpoints are tested by eval-ing (as a string eval) their code in the context of the debugged program. If any of these tests returns true, the debugger will stop the program before executing that line.

Constructor

my $bp = Devel::Chitin::Breakpoint->new(file => $f, line => $l,
                                      [ code => $code ],
                                      [ once => 1 ],
                                      [ inactive => 1]);

Creates a new Breakpoint object. file and line are required arguments. file must be a filename as it appears in $main::{"<_$file"}. If code is omitted, the value "1" is used as a default which creates an unconditional breakpoint. If once is a true value, then the breakpoint will delete itself after triggering. If inactive is true, the breakpoint will not trigger.

Methods

my @bp = Devel::Chitin::Breakpoint->get(file => $f, %other_params);

Retrieve breakpoints. Always returns a list of matching breakpoints. file is required, and if no other filters are used, returns all the breakpoints for that file. You may also filter by line, code and inactive.

$bp->file
$bp->line
$bp->code
$bp->once

Read-only accessors that return whatever values were used to create the breakpoint.

$bp->inactive();
$bp->inactive( 1 | 0);

Mutator that retrieves the current inactive flag, or sets it.

$bp->delete();

Remove a breakpoint. Deleted breakpoints will never trigger again.

Actions

Actions are a lot like breakpoints; they are associated with a file and line number, and they have code that runs before that line in the program is executed. The difference is that the return value from the code is ignored.

The code is evaluated in the context of the running program, so it can, for example, affect variables there or print them out.

Constructor

my $act = Devel::Chitin::Action->new(file => $f, line => $l, code => $code,
                                      [ once => 1],
                                      [ inactive => 1]);

Creates a new Action object. file, line and code are required arguments. file must be a filename as it appears in $main::{"<_$file"}. breakpoint. If once is a true value, then the action will delete itself after running. If inactive is true, the action will not run.

Methods

my @acts = Devel::Chitin::Action->get(file => $f, %other_params);

Retrieve actions. Always returns a list of matching actions. file is required, and if no other filters are used, returns all the actions for that file. You may also filter by line, code and inactive.

$act->file
$act->line
$act->code
$act->once

Read-only accessors that return whatever values were used to create the action.

$act->inactive();
$act->inactive( 1 | 0);

Mutator that retrieves the current inactive flag, or sets it.

$act->delete();

Remove an action. Deleted actions will never run again.

SEE ALSO

Devel::Chitin

AUTHOR

Anthony Brummett <brummett@cpan.org>

COPYRIGHT

Copyright 2014, Anthony Brummett. This module is free software. It may be used, redistributed and/or modified under the same terms as Perl itself.