I'm parsing time from a last output. I got an unexpected input, so getting an unexpected output shouldn't be surprising, but for the life of me I can't figure out what perl is doing.
subroutine is
sub minutes {
my $time = shift;
print "minutes handed $time " if $DEBUG_MINUTES;
if ( $time =~ /(\d+):(\d+)/ ) {
print "Interpreted as $1 hours $2 mins\n" if $DEBUG_MINUTES;
return 60 * $1 + $2;
} elsif (/(\d+)+(\d+):(\d+)/) {
print "Interpreted as $1 days, $2 hours, $3 minutes\n" if $DEBUG_M
+INUTES;
return ( 24 * $1 + $2 ) * 60 + $3;
} else {
warn "I don't understand time $time\n";
return $time;
}
}
I was processing a line
archerh Thu Jun 22 10:25 - down (-6+-1
+2:-52)
and I get
minutes handed -6+-12:-52 Interpreted as 1 days, 0 hours, 25 minutes
How does \d+ do this?
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
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:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, 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, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.