File Coverage

blib/lib/Time/DeltaString.pm
Criterion Covered Total %
statement 50 56 89.2
branch 10 16 62.5
condition n/a
subroutine 11 12 91.6
pod 7 7 100.0
total 78 91 85.7


line stmt bran cond sub pod time code
1             package Time::DeltaString;
2              
3 7     7   52493 use strict;
  7         18  
  7         281  
4 7     7   38 no warnings;
  7         17  
  7         338  
5 7     7   37 use base 'Exporter';
  7         13  
  7         1087  
6 7     7   37 use Carp;
  7         25  
  7         10598  
7              
8             our %EXPORT_TAGS = ( 'all' => [ qw(delta_string default_conversions nomonth_conversions weeklargest_conversions daysmallest_conversions interval2seconds rev) ] );
9             our @EXPORT_OK = ( @{ $EXPORT_TAGS{'all'} } );
10             our @EXPORT;
11             our $VERSION = '1.4300';
12              
13             our @conversions;
14              
15             # sidereal_conversions() {{{
16             sub sidereal_conversions() {
17 0     0 1 0 my $sidereal_year = 365.256_363_051 * 24 * 60 * 60;
18 0         0 my $sidereal_month = $sidereal_year / 12;
19              
20 0         0 @conversions = (
21             [ y => $sidereal_year ],
22             [ mo => $sidereal_month ],
23              
24             [ w => 7*24*60*60 ],
25             [ d => 24*60*60 ],
26             [ h => 60*60 ],
27             [ m => 60 ],
28             );
29              
30 0         0 return;
31             }
32             # }}}
33             # daysmallest_conversions() {{{
34             sub daysmallest_conversions() {
35 1     1 1 8 @conversions = (
36             [ y => 365*24*60*60 ],
37             [ mo => 30*24*60*60 ],
38             [ w => 7*24*60*60 ],
39             [ d => 24*60*60 ],
40             );
41              
42 1         3 return;
43             }
44             # }}}
45             # default_conversions() {{{
46             sub default_conversions() {
47 7     7 1 41 @conversions = (
48             [ y => 365*24*60*60 ],
49             [ mo => 30*24*60*60 ],
50             [ w => 7*24*60*60 ],
51             [ d => 24*60*60 ],
52             [ h => 60*60 ],
53             [ m => 60 ],
54             [ s => 1 ],
55             );
56              
57 7         17 return;
58             }
59             # }}}
60             # nomonth_conversions() {{{
61             sub nomonth_conversions() {
62 1     1 1 1548 @conversions = (
63             [ y => 365*24*60*60 ],
64             [ w => 7*24*60*60 ],
65             [ d => 24*60*60 ],
66             [ h => 60*60 ],
67             [ m => 60 ],
68             [ s => 1 ],
69             );
70              
71 1         3 return;
72             }
73             # }}}
74             # weeklargest_conversions() {{{
75             sub weeklargest_conversions() {
76 1     1 1 1655 @conversions = (
77             [ w => 7*24*60*60 ],
78             [ d => 24*60*60 ],
79             [ h => 60*60 ],
80             [ m => 60 ],
81             [ s => 1 ],
82             );
83              
84 1         5 return;
85             }
86             # }}}
87              
88             default_conversions();
89              
90             # _to_secs {{{
91             sub _to_secs {
92 4     4   7 my $time = shift;
93              
94 4         4 my ($H,$M,$S);
95              
96 4 100       33 if ( ($H, $M, $S) = $time =~ m/^(\d+):(\d{2}):(\d{2})$/ ) {
    50          
    0          
97 3         14 return $S
98             + $M * 60
99             + $H * 60 * 60;
100              
101             } elsif ( ($M, $S) = $time =~ m/^(\d+):(\d{2})$/ ) {
102 1         6 return $S + $M * 60;
103              
104             } elsif( $time =~ m/^\d+$/ ) {
105 0         0 return $time;
106             }
107              
108 0         0 croak "time format not understood";
109             }
110             # }}}
111             # delta_string($) {{{
112             sub delta_string($) {
113 29     29 1 9362 my $s = shift;
114              
115 29 100       104 if ( $s =~ m/:/ ) {
116 4         6 $s = eval { _to_secs($s) };
  4         13  
117              
118 4 50       17 croak $@ if $@;
119             }
120              
121 175         170 my @res = map {
122 29         54 my @r;
123              
124 175 100       403 if( my $v = int( $s / $_->[1] ) ) {
125 78         111 $s -= $v * $_->[1];
126 78         171 @r = "$v$_->[0]";
127             }
128              
129 175         301 @r } @conversions;
130              
131 29         51 local $" = "";
132 29 50       198 return @res ? "@res" : "0s";
133             }
134             # }}}
135             # {{{ sub rev($)
136             sub rev($) {
137 1     1 1 1290 my $td = shift;
138              
139 1         3 my %conversions = map {(@$_)} @conversions;
  7         19  
140 1         3 my $conversions = do { local $" = "|"; my @c = keys %conversions; qr/(?:@c)/ };
  1         4  
  1         4  
  1         39  
141              
142 1 50       34 croak "interval format not understood" unless $td =~ m/^(?:\d+$conversions)*$/;
143 1         3 my $s = 0;
144              
145 1         21 while( $td =~ m/(\d+)($conversions)/g ) {
146 3         18 $s += $1 * $conversions{$2};
147             }
148              
149 1         6 return $s;
150             }
151              
152             *interval2seconds = \&rev;
153              
154             # }}}
155              
156             1;