How can I see variable values ​​from a Perl trace?

My goal is to debug (step by step) the sample.plscript below.

Problem: I do not get the actual values ​​of the variables ($ top_number, $ x, $ total).

My question is: how to see the real integer values ​​($ top_number, $ x, $ total) from the trace output?

What needs to be changed in perl -d:Traceto get numbers, not: $ top_number, $ x, $ total?

Example from trace output:

[root@linux /tmp]# perl -d:Trace ./sample.pl 
>> ./sampl.pl:9: $top_number = 100;
>> ./sampl.pl:10: $x = 1;
>> ./sampl.pl:11: $total = 0;
>> ./sampl.pl:12: while ( $x <= $top_number ) {
>> ./sampl.pl:13:       $total = $total + $x;   # short form: $total += $x;
>> ./sampl.pl:14:       $x += 1;                # do you follow this short form?
>> ./sampl.pl:13:       $total = $total + $x;   # short form: $total += $x;
>> ./sampl.pl:14:       $x += 1;                # do you follow this short form?
>> ./sampl.pl:13:       $total = $total + $x;   # short form: $total += $x;
>> ./sampl.pl:14:       $x += 1;                # do you follow this short form?
.
.

[root@linux /tmp]#more sample.pl script

#!/usr/bin/perl 


$top_number = 100;
$x = 1;
$total = 0;
while ( $x <= $top_number ) {
    $total = $total + $x;   # short form: $total += $x;
    $x += 1;                # do you follow this short form?
}

print "The total from 1 to $top_number is $total\n";
+5
source share
2 answers

I assume that you want to see the values of variables $x, and $totaleach iteration of the loop. There is no indication from POD for Devel :: Trace that he can do this.

Devel:: DumpTrace .

perl -d:DumpTrace ./sample.pl

>>>>> hw.pl:7:      $top_number:100 = 100;
>>>>> hw.pl:8:      $x:1 = 1;
>>>>> hw.pl:9:      $total:0 = 0;
>>>>> hw.pl:10:     while ( $x:1 <= $top_number:100 ) {
>>>>> hw.pl:11:         $total:1 = $total:0 + $x:1;   # short form: $total:0 += $x:1;
>>>>> hw.pl:12:         $x:2 += 1;                # do you follow this short form?
>>>>> hw.pl:11:         $total:3 = $total:1 + $x:2;   # short form: $total:1 += $x:2;
>>>>> hw.pl:12:         $x:3 += 1;                # do you follow this short form?
>>>>> hw.pl:11:         $total:6 = $total:3 + $x:3;   # short form: $total:3 += $x:3;
+7
0

All Articles