| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
package Pinwheel::Model::DateBase; |
|
2
|
|
|
|
|
|
|
|
|
3
|
8
|
|
|
8
|
|
24574
|
use strict; |
|
|
8
|
|
|
|
|
17
|
|
|
|
8
|
|
|
|
|
313
|
|
|
4
|
8
|
|
|
8
|
|
46
|
use warnings; |
|
|
8
|
|
|
|
|
14
|
|
|
|
8
|
|
|
|
|
409
|
|
|
5
|
|
|
|
|
|
|
|
|
6
|
8
|
|
|
8
|
|
1067
|
use POSIX qw(); |
|
|
8
|
|
|
|
|
8092
|
|
|
|
8
|
|
|
|
|
29107
|
|
|
7
|
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
# Date/time values |
|
10
|
|
|
|
|
|
|
|
|
11
|
14
|
|
|
14
|
0
|
164
|
sub year { $_[0]->{t}[5] + 1900 } |
|
12
|
18
|
|
|
18
|
0
|
119
|
sub month { $_[0]->{t}[4] + 1 } |
|
13
|
82
|
|
|
82
|
0
|
870
|
sub day { $_[0]->{t}[3] } |
|
14
|
4
|
|
|
4
|
0
|
66
|
sub mm { sprintf('%02d', $_[0]->{t}[4] + 1) } |
|
15
|
4
|
|
|
4
|
0
|
34
|
sub dd { sprintf('%02d', $_[0]->{t}[3]) } |
|
16
|
7
|
|
|
7
|
0
|
37
|
sub wday { $_[0]->{t}[6] } |
|
17
|
3
|
|
|
3
|
0
|
19
|
sub yday { $_[0]->{t}[7] } |
|
18
|
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
sub bbc_year |
|
20
|
|
|
|
|
|
|
{ |
|
21
|
82
|
100
|
|
82
|
0
|
569
|
$_[0]->_calculate_bbc_week if (!$_[0]->{bbc_week}); |
|
22
|
82
|
|
|
|
|
1155
|
return $_[0]->{bbc_year}; |
|
23
|
|
|
|
|
|
|
} |
|
24
|
|
|
|
|
|
|
|
|
25
|
|
|
|
|
|
|
sub bbc_week |
|
26
|
|
|
|
|
|
|
{ |
|
27
|
82
|
100
|
|
82
|
0
|
223
|
$_[0]->_calculate_bbc_week if (!$_[0]->{bbc_week}); |
|
28
|
82
|
|
|
|
|
611
|
return $_[0]->{bbc_week}; |
|
29
|
|
|
|
|
|
|
} |
|
30
|
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
sub _calculate_bbc_week |
|
32
|
|
|
|
|
|
|
{ |
|
33
|
78
|
|
|
78
|
|
328
|
my $adjust = 3 - (($_[0]->{t}[6] + 1) % 7); |
|
34
|
78
|
|
|
|
|
474
|
my @t = gmtime($_[0]->{s} + ($adjust * 86400)); |
|
35
|
78
|
|
|
|
|
304
|
$_[0]->{bbc_year} = $t[5] + 1900; |
|
36
|
78
|
|
|
|
|
269
|
$_[0]->{bbc_week} = int($t[7] / 7) + 1; |
|
37
|
|
|
|
|
|
|
} |
|
38
|
|
|
|
|
|
|
|
|
39
|
|
|
|
|
|
|
sub iso_year |
|
40
|
|
|
|
|
|
|
{ |
|
41
|
82
|
100
|
|
82
|
0
|
579
|
$_[0]->_calculate_iso_week if (!$_[0]->{iso_week}); |
|
42
|
82
|
|
|
|
|
274
|
return $_[0]->{iso_year}; |
|
43
|
|
|
|
|
|
|
} |
|
44
|
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
sub iso_week |
|
46
|
|
|
|
|
|
|
{ |
|
47
|
82
|
100
|
|
82
|
0
|
238
|
$_[0]->_calculate_iso_week if (!$_[0]->{iso_week}); |
|
48
|
82
|
|
|
|
|
603
|
return $_[0]->{iso_week}; |
|
49
|
|
|
|
|
|
|
} |
|
50
|
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
sub iso_weekday |
|
52
|
|
|
|
|
|
|
{ |
|
53
|
18
|
|
100
|
18
|
0
|
208
|
return $_[0]->{t}[6] || 7; |
|
54
|
|
|
|
|
|
|
} |
|
55
|
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
sub _calculate_iso_week |
|
57
|
|
|
|
|
|
|
{ |
|
58
|
78
|
|
|
78
|
|
220
|
my $adjust = 3 - (($_[0]->{t}[6] - 1) % 7); |
|
59
|
78
|
|
|
|
|
341
|
my @t = gmtime($_[0]->{s} + ($adjust * 86400)); |
|
60
|
78
|
|
|
|
|
249
|
$_[0]->{iso_year} = $t[5] + 1900; |
|
61
|
78
|
|
|
|
|
281
|
$_[0]->{iso_week} = int($t[7] / 7) + 1; |
|
62
|
|
|
|
|
|
|
} |
|
63
|
|
|
|
|
|
|
|
|
64
|
|
|
|
|
|
|
sub days_in_month |
|
65
|
|
|
|
|
|
|
{ |
|
66
|
30
|
|
|
30
|
0
|
12242
|
my ($y, $m); |
|
67
|
|
|
|
|
|
|
|
|
68
|
30
|
|
|
|
|
70
|
$y = $_[0]->{t}[5] + 1900; |
|
69
|
30
|
|
|
|
|
52
|
$m = $_[0]->{t}[4]; |
|
70
|
30
|
100
|
|
|
|
169
|
return (31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31)[$m] if ($m != 1); |
|
71
|
8
|
100
|
66
|
|
|
97
|
return (!($y % 4) && (($y % 100) || !($y % 400))) ? 29 : 28; |
|
72
|
|
|
|
|
|
|
} |
|
73
|
|
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
|
|
75
|
|
|
|
|
|
|
# Formatting |
|
76
|
|
|
|
|
|
|
|
|
77
|
|
|
|
|
|
|
sub month_name |
|
78
|
|
|
|
|
|
|
{ |
|
79
|
24
|
|
|
24
|
0
|
277
|
return qw( |
|
80
|
|
|
|
|
|
|
January February March April May June July |
|
81
|
|
|
|
|
|
|
August September October November December |
|
82
|
|
|
|
|
|
|
)[$_[0]->{t}[4]]; |
|
83
|
|
|
|
|
|
|
} |
|
84
|
|
|
|
|
|
|
|
|
85
|
|
|
|
|
|
|
sub short_month_name |
|
86
|
|
|
|
|
|
|
{ |
|
87
|
34
|
|
|
34
|
0
|
266
|
return qw( |
|
88
|
|
|
|
|
|
|
Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec |
|
89
|
|
|
|
|
|
|
)[$_[0]->{t}[4]]; |
|
90
|
|
|
|
|
|
|
} |
|
91
|
|
|
|
|
|
|
|
|
92
|
|
|
|
|
|
|
sub day_name |
|
93
|
|
|
|
|
|
|
{ |
|
94
|
14
|
|
|
14
|
0
|
217
|
return qw( |
|
95
|
|
|
|
|
|
|
Sunday Monday Tuesday Wednesday Thursday Friday Saturday |
|
96
|
|
|
|
|
|
|
)[$_[0]->{t}[6]]; |
|
97
|
|
|
|
|
|
|
} |
|
98
|
|
|
|
|
|
|
|
|
99
|
|
|
|
|
|
|
sub short_day_name |
|
100
|
|
|
|
|
|
|
{ |
|
101
|
24
|
|
|
24
|
0
|
142
|
return qw(Sun Mon Tue Wed Thu Fri Sat)[$_[0]->{t}[6]]; |
|
102
|
|
|
|
|
|
|
} |
|
103
|
|
|
|
|
|
|
|
|
104
|
|
|
|
|
|
|
sub day_suffix |
|
105
|
|
|
|
|
|
|
{ |
|
106
|
124
|
|
|
124
|
0
|
801
|
my $day = $_[0]->{t}[3]; |
|
107
|
124
|
100
|
100
|
|
|
725
|
return 'th' if ($day >= 10 && $day < 20); |
|
108
|
84
|
|
|
|
|
470
|
return qw(th st nd rd th th th th th th)[$day % 10]; |
|
109
|
|
|
|
|
|
|
} |
|
110
|
|
|
|
|
|
|
|
|
111
|
|
|
|
|
|
|
sub day_ordinal |
|
112
|
|
|
|
|
|
|
{ |
|
113
|
62
|
|
|
62
|
0
|
263
|
return $_[0]->day . $_[0]->day_suffix; |
|
114
|
|
|
|
|
|
|
} |
|
115
|
|
|
|
|
|
|
|
|
116
|
|
|
|
|
|
|
sub strftime |
|
117
|
|
|
|
|
|
|
{ |
|
118
|
6
|
|
|
6
|
0
|
43
|
return POSIX::strftime($_[1], @{$_[0]->{t}}); |
|
|
6
|
|
|
|
|
434
|
|
|
119
|
|
|
|
|
|
|
} |
|
120
|
|
|
|
|
|
|
|
|
121
|
|
|
|
|
|
|
|
|
122
|
|
|
|
|
|
|
# Date/time adjustment |
|
123
|
|
|
|
|
|
|
|
|
124
|
|
|
|
|
|
|
sub replace |
|
125
|
|
|
|
|
|
|
{ |
|
126
|
37
|
|
|
37
|
0
|
225
|
my ($self, %values) = @_; |
|
127
|
37
|
|
|
|
|
50
|
my ($ss, $mm, $hh, $d, $m, $y) = @{$self->{t}}; |
|
|
37
|
|
|
|
|
104
|
|
|
128
|
|
|
|
|
|
|
|
|
129
|
37
|
100
|
|
|
|
114
|
$ss = $values{sec} if exists($values{sec}); |
|
130
|
37
|
100
|
|
|
|
81
|
$ss = 0 if $ss < 0; $ss = 59 if $ss > 59; |
|
|
37
|
100
|
|
|
|
262
|
|
|
131
|
37
|
100
|
|
|
|
80
|
$mm = $values{min} if exists($values{min}); |
|
132
|
37
|
100
|
|
|
|
74
|
$mm = 0 if $mm < 0; $mm = 59 if $mm > 59; |
|
|
37
|
100
|
|
|
|
74
|
|
|
133
|
37
|
100
|
|
|
|
85
|
$hh = $values{hour} if exists($values{hour}); |
|
134
|
37
|
100
|
|
|
|
70
|
$hh = 0 if $hh < 0; $hh = 23 if $hh > 23; |
|
|
37
|
100
|
|
|
|
76
|
|
|
135
|
|
|
|
|
|
|
|
|
136
|
37
|
100
|
|
|
|
85
|
$d = $values{day} if exists($values{day}); |
|
137
|
37
|
100
|
|
|
|
80
|
$m = $values{month} - 1 if exists($values{month}); |
|
138
|
37
|
100
|
|
|
|
76
|
$m = 0 if $m < 0; $m = 11 if $m > 11; |
|
|
37
|
100
|
|
|
|
69
|
|
|
139
|
37
|
100
|
|
|
|
94
|
$y = exists($values{year}) ? $values{year} : $y + 1900; |
|
140
|
37
|
|
|
|
|
79
|
$d = _correct_day($y, $m, $d); |
|
141
|
|
|
|
|
|
|
|
|
142
|
37
|
|
|
|
|
130
|
return $self->_derived($y, $m, $d, $hh, $mm, $ss); |
|
143
|
|
|
|
|
|
|
} |
|
144
|
|
|
|
|
|
|
|
|
145
|
|
|
|
|
|
|
sub offset |
|
146
|
|
|
|
|
|
|
{ |
|
147
|
41
|
|
|
41
|
0
|
173
|
my ($self, %deltas) = @_; |
|
148
|
41
|
|
|
|
|
60
|
my ($i, $ss, $mm, $hh, $d, $m, $y) = (undef, @{$self->{t}}); |
|
|
41
|
|
|
|
|
109
|
|
|
149
|
|
|
|
|
|
|
|
|
150
|
41
|
100
|
|
|
|
192
|
if (exists($deltas{days})) { |
|
151
|
23
|
|
|
|
|
58
|
$i = $self->{s} + ((12 - $hh) * 3600) + ($deltas{days} * 86400); |
|
152
|
23
|
|
|
|
|
99
|
($d, $m, $y) = (gmtime $i)[3 .. 5]; |
|
153
|
|
|
|
|
|
|
} |
|
154
|
41
|
100
|
|
|
|
116
|
if (exists($deltas{months})) { |
|
155
|
14
|
|
|
|
|
30
|
$i = $m + $deltas{months}; |
|
156
|
14
|
|
|
|
|
24
|
$m = $i % 12; |
|
157
|
14
|
|
|
|
|
34
|
$y += ($i - $m) / 12; |
|
158
|
|
|
|
|
|
|
} |
|
159
|
41
|
|
|
|
|
60
|
$y += 1900; |
|
160
|
41
|
100
|
|
|
|
95
|
$y += $deltas{years} if exists($deltas{years}); |
|
161
|
41
|
|
|
|
|
89
|
$d = _correct_day($y, $m, $d); |
|
162
|
41
|
|
|
|
|
152
|
return $self->_derived($y, $m, $d, $hh, $mm, $ss); |
|
163
|
|
|
|
|
|
|
} |
|
164
|
|
|
|
|
|
|
|
|
165
|
|
|
|
|
|
|
sub next_day |
|
166
|
|
|
|
|
|
|
{ |
|
167
|
2
|
|
|
2
|
0
|
38
|
return $_[0]->offset(days => 1); |
|
168
|
|
|
|
|
|
|
} |
|
169
|
|
|
|
|
|
|
|
|
170
|
|
|
|
|
|
|
sub previous_day |
|
171
|
|
|
|
|
|
|
{ |
|
172
|
2
|
|
|
2
|
0
|
13
|
return $_[0]->offset(days => -1); |
|
173
|
|
|
|
|
|
|
} |
|
174
|
|
|
|
|
|
|
|
|
175
|
|
|
|
|
|
|
sub next_week |
|
176
|
|
|
|
|
|
|
{ |
|
177
|
2
|
|
|
2
|
0
|
8
|
return $_[0]->offset(days => 7); |
|
178
|
|
|
|
|
|
|
} |
|
179
|
|
|
|
|
|
|
|
|
180
|
|
|
|
|
|
|
sub previous_week |
|
181
|
|
|
|
|
|
|
{ |
|
182
|
2
|
|
|
2
|
0
|
9
|
return $_[0]->offset(days => -7); |
|
183
|
|
|
|
|
|
|
} |
|
184
|
|
|
|
|
|
|
|
|
185
|
|
|
|
|
|
|
sub next_month |
|
186
|
|
|
|
|
|
|
{ |
|
187
|
2
|
|
|
2
|
0
|
10
|
return $_[0]->offset(months => 1); |
|
188
|
|
|
|
|
|
|
} |
|
189
|
|
|
|
|
|
|
|
|
190
|
|
|
|
|
|
|
sub previous_month |
|
191
|
|
|
|
|
|
|
{ |
|
192
|
4
|
|
|
4
|
0
|
19
|
return $_[0]->offset(months => -1); |
|
193
|
|
|
|
|
|
|
} |
|
194
|
|
|
|
|
|
|
|
|
195
|
|
|
|
|
|
|
sub last_of_month |
|
196
|
|
|
|
|
|
|
{ |
|
197
|
4
|
|
|
4
|
0
|
15
|
return $_[0]->replace(day => 31); |
|
198
|
|
|
|
|
|
|
} |
|
199
|
|
|
|
|
|
|
|
|
200
|
|
|
|
|
|
|
sub first_of_month |
|
201
|
|
|
|
|
|
|
{ |
|
202
|
2
|
|
|
2
|
0
|
34
|
return $_[0]->replace(day => 1); |
|
203
|
|
|
|
|
|
|
} |
|
204
|
|
|
|
|
|
|
|
|
205
|
|
|
|
|
|
|
sub _correct_day |
|
206
|
|
|
|
|
|
|
{ |
|
207
|
94
|
|
|
94
|
|
161
|
my ($y, $m, $d) = @_; |
|
208
|
94
|
|
|
|
|
115
|
my $i; |
|
209
|
|
|
|
|
|
|
|
|
210
|
94
|
100
|
|
|
|
209
|
return 1 if $d < 1; |
|
211
|
|
|
|
|
|
|
|
|
212
|
92
|
|
|
|
|
143
|
$i = (31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31)[$m]; |
|
213
|
92
|
100
|
|
|
|
181
|
if ($d > $i) { |
|
214
|
|
|
|
|
|
|
# XXX No year divisible by 100 and not 400 with a 32-bit time_t |
|
215
|
38
|
100
|
100
|
|
|
218
|
$i++ if ($m == 1 && !($y % 4) && (($y % 100) || !($y % 400))); |
|
|
|
|
100
|
|
|
|
|
|
|
|
|
66
|
|
|
|
|
|
216
|
38
|
100
|
|
|
|
101
|
$d = $i if $d > $i; |
|
217
|
|
|
|
|
|
|
} |
|
218
|
92
|
|
|
|
|
203
|
return $d; |
|
219
|
|
|
|
|
|
|
} |
|
220
|
|
|
|
|
|
|
|
|
221
|
|
|
|
|
|
|
|
|
222
|
|
|
|
|
|
|
1; |
|
223
|
|
|
|
|
|
|
|
|
224
|
|
|
|
|
|
|
__DATA__ |