Rightly or wrongly, I use the debugger. I use it all the time to step through code that I have inherited. Along the way I have run across a few debugger idioms that have been invaluable to my code archiology.
Please respond and share your debugger idioms!
- Write intermediate data to a file
In some cases, while debugging, it is helpful to capture an intermediate data structure for reference. I find this particularly useful for dumping out xml content that is generated.
Step into an expression
DB<3> open FH, ">/tmp/foo.txt";
DB<4> print FH "THIS IS AN EXAMPLE";
DB<5> print FH $user_id;
DB<6> close FH
You can evaluate any valid perl expression with x while in the debugger. However you can also step into that expression using s. For example:
DB<6> s $profile->to_xml()
At this point, you will be stepping through the expression that was entered on the previous line.
break the debugger from code
Put the following expression somewhere in your code, run it in the debugger and the debugger will stop on the line immediately following it.
$DB::single = 1;
There are many more debugger idioms out there, what are yours?
Hazah! I'm Employed! (But still looking...)
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.
| & || & |
| < || < |
| > || > |
| [ || [ |
| ] || ] ||