1Date::Pcalc::Object(3)User Contributed Perl DocumentationDate::Pcalc::Object(3)
2
3
4
6 Date::Pcalc::Object - Object-oriented add-on for Date::Pcalc with
7 overloaded operators
8
10 Make frequent things easy and infrequent or hard things possible
11
13 Note that you do NOT need to ""use Date::Pcalc qw(...);"" in addition
14 to this module.
15
16 Simply
17
18 use Date::Pcalc::Object qw(...);
19
20 INSTEAD OF
21
22 use Date::Pcalc qw(...);
23
24 with the same ""qw(...)"" as you would with the "Date::Pcalc" module,
25 and then forget about "Date::Pcalc::Object" altogether.
26
27 The rest of your existing code doesn't change at all.
28
29 Note also that in order to create a new date object, you do not need to
30 use
31
32 $date_object = Date::Pcalc::Object->new(...);
33
34 (but you may), and should use
35
36 $date_object = Date::Pcalc->new(...);
37
38 instead (saves you some typing and is a trifle faster).
39
41 Export tags
42 :all - all functions from Date::Pcalc
43 :aux - auxiliary functions shift_*
44 :ALL - both :all and :aux
45
46 Functions
47 See Date::Pcalc(3) for a list of available functions.
48
49 $year = shift_year(\@_);
50 ($year,$mm,$dd) = shift_date(\@_);
51 ($hrs,$min,$sec) = shift_time(\@_);
52 ($year,$mm,$dd,$hrs,$min,$sec) = shift_datetime(\@_);
53
54 Methods
55 $old = Date::Pcalc->accurate_mode([FLAG]);
56 $old = Date::Pcalc->normalized_mode([FLAG]);
57 $old = Date::Pcalc->number_format([NUMBER|CODEREF]);
58 $old = Date::Pcalc->delta_format([NUMBER|CODEREF]); # global default
59 $old = Date::Pcalc->date_format([NUMBER|CODEREF]); # global default
60 $old = Date::Pcalc->language([LANGUAGE]); # global default - DEPRECATED
61
62 $old = $date->accurate_mode([FLAG]); # is global nevertheless!
63 $old = $date->normalized_mode([FLAG]); # is global nevertheless!
64 $old = $date->number_format([NUMBER|CODEREF]); # is global nevertheless!
65 $old = $date->delta_format([NUMBER|CODEREF]); # individual override
66 $old = $date->date_format([NUMBER|CODEREF]); # individual override
67 $old = $date->language([LANGUAGE]); # individual override
68
69 $flag = $date->is_delta();
70 $flag = $date->is_date();
71 $flag = $date->is_short(); # i.e., has no time part
72 $flag = $date->is_long(); # i.e., has time part
73 $flag = $date->is_valid();
74
75 $date = Date::Pcalc->new([TYPE]);
76 $date = Date::Pcalc->new([TYPE,]YEAR,MONTH,DAY[,HRS,MIN,SEC]);
77 $date = Date::Pcalc->new($arrayref);
78 $newdate = $somedate->new([TYPE]);
79 $newdate = $somedate->new([TYPE,]YEAR,MONTH,DAY[,HRS,MIN,SEC]);
80 $newdate = $somedate->new($arrayref);
81
82 $datecopy = $date->clone();
83 $targetdate->copy($sourcedate);
84 $targetdate->copy($arrayref);
85 $targetdate->copy(@list);
86
87 ($year,$month,$day) = $date->date([TYPE]);
88 ($year,$month,$day) = $date->date([TYPE,]YEAR,MONTH,DAY[,HRS,MIN,SEC]);
89 ($year,$month,$day) = $date->date($arrayref);
90 ([$hrs,$min,$sec]) = $date->time([TYPE]);
91 ($hrs,$min,$sec) = $date->time([TYPE,]HRS,MIN,SEC);
92 ([$hrs,$min,$sec]) = $date->time($arrayref);
93
94 ($year,$month,$day,$hrs,$min,$sec) =
95 $date->datetime([TYPE]);
96 ($year,$month,$day,$hrs,$min,$sec) =
97 $date->datetime([TYPE,]YEAR,MONTH,DAY[,HRS,MIN,SEC]);
98
99 $date = Date::Pcalc->today([FLAG]);
100 $date = Date::Pcalc->now([FLAG]); # shorthand for --+
101 $date = Date::Pcalc->today_and_now([FLAG]); # <-----+
102 $date = Date::Pcalc->gmtime([time]); # UTC/GMT
103 $date = Date::Pcalc->localtime([time]); # local time
104 $delta = Date::Pcalc->tzoffset([time]);
105 $date = Date::Pcalc->time2date([time]); # UTC/GMT
106
107 $date->today([FLAG]); # updates the date part only
108 $date->now([FLAG]); # updates the time part only
109 $date->today_and_now([FLAG]); # updates both date and time
110 $date->gmtime([time]); # updates both date and time (UTC/GMT)
111 $date->localtime([time]); # updates both date and time (local time)
112 $delta->tzoffset([time]); # updates both date and time
113 $date->time2date([time]); # updates both date and time (UTC/GMT)
114
115 $time = Date::Pcalc->mktime(); # same as "$time = CORE::time();"
116 $time = Date::Pcalc->date2time(); # same as "$time = CORE::time();"
117
118 $time = $date->mktime(); # converts into Unix time (local time)
119 $time = $date->date2time(); # converts into Unix time (UTC/GMT)
120
121 $year = $date->year([YEAR]);
122 $month = $date->month([MONTH]);
123 $day = $date->day([DAY]);
124 $hours = $date->hours([HRS]);
125 $minutes = $date->minutes([MIN]);
126 $seconds = $date->seconds([SEC]);
127
128 $number = $date->number([NUMBER|CODEREF]);
129 $string = $date->string([NUMBER|CODEREF][,LANGUAGE]);
130
131 $delta->normalize(); # renormalizes a delta vector
132
133 Overloaded Operators
134 #####################################################
135 # Scalar operands are always converted into a delta #
136 # vector with that many days, i.e., [1,0,0,SCALAR] #
137 #####################################################
138
139 Comparison Operators:
140 if ($date1 < $date2) { # compares date part only
141 if ($date1 <= $date2) { # compares date part only
142 if ($date1 > $date2) { # compares date part only
143 if ($date1 >= $date2) { # compares date part only
144 if ($date1 == $date2) { # compares date part only
145 if ($date1 != $date2) { # compares date part only
146
147 $comp = $date1 <=> $date2; # compares date part only
148
149 if ($date1 lt $date2) { # compares both date and time
150 if ($date1 le $date2) { # compares both date and time
151 if ($date1 gt $date2) { # compares both date and time
152 if ($date1 ge $date2) { # compares both date and time
153 if ($date1 eq $date2) { # compares both date and time
154 if ($date1 ne $date2) { # compares both date and time
155
156 $comp = $date1 cmp $date2; # compares both date and time
157
158 Note that you can of course also compare two deltas, but not a date and
159 a delta!
160
161 ##################################################
162 # Default TYPE for array refs in comparisons is: #
163 # Same as other operand #
164 ##################################################
165
166 if ([2000,4,1] == $date) {
167 if ($today > [2000,4,1]) {
168
169 if ($now ge [2000,3,26,2,0,0]) {
170
171 if ($delta == [18,0,0]) {
172 if ($delta == -1) {
173
174 Plus:
175 $date2 = $date1 + $delta;
176 $date2 = $delta + $date1;
177 $date += $delta;
178 $this = $date++;
179 $next = ++$date;
180
181 $delta3 = $delta1 + $delta2;
182 $delta1 += $delta2;
183 $delta += $date; # beware of implicit type change!
184 $delta++;
185 ++$delta;
186
187 #####################################################
188 # Default TYPE for array refs in '+' operations is: #
189 # Opposite of other operand #
190 #####################################################
191
192 $date2 = [2000,3,26] + $delta;
193 $date2 = $date1 + [+1,0,0];
194 $date2 = [0,0,-1] + $date1;
195 $date2 = $date1 + 1;
196 $date += [0,0,+1];
197 $date += 2;
198
199 $delta3 = [1,+1,0,-1] + $delta2;
200 $delta3 = $delta1 + [1,0,0,+1];
201 $delta3 = $delta1 + 1;
202 $delta += [1,0,+1,0];
203 $delta += [2000,3,26]; # beware of implicit type change!
204 $delta += 7;
205
206 Unary Minus:
207 $delta2 = -$delta1;
208
209 Minus:
210 $delta = $date2 - $date1;
211 $date2 = $date1 - $delta;
212 $date -= $delta;
213 $date2 -= $date1; # beware of implicit type change!
214 $this = $date--;
215 $prev = --$date;
216
217 $delta3 = $delta2 - $delta1;
218 $delta2 -= $delta1;
219 $delta--;
220 --$delta;
221
222 #####################################################
223 # Default TYPE for array refs in '-' operations is: #
224 # Always a date #
225 #####################################################
226
227 $delta = $today - [2000,3,26];
228 $delta = [2000,4,1] - $date;
229 $date2 = [2000,3,26] - $delta;
230 $date2 = $date1 - [1,0,0,+7];
231 $date2 = $date1 - 7;
232 $date -= [1,0,0,+1]; # better add [0,0,-1] instead!
233 $date2 -= [2000,3,26]; # beware of implicit type change!
234 $date2 -= 1;
235
236 $delta3 = [1,0,+1,0] - $delta1;
237 $delta3 = $delta2 - [1,0,0,-1];
238 $delta -= [1,0,0,+1];
239 $delta -= 7;
240
241 Miscellaneous Operators:
242 $string = "$date";
243 $string = "$delta";
244
245 print "$date\n";
246 print "$delta\n";
247
248 if ($date) { # date is valid
249 if ($delta) { # delta is valid
250
251 $days = abs($date);
252 $diff = abs($delta); # can be negative!
253
254 $diff = abs(abs($delta)); # always positive
255
257 • FLAG
258
259 "FLAG" is either 0 (for "false") or 1 (for "true").
260
261 In the case of ""accurate_mode()"" and ""normalized_mode()"", this
262 switches the corresponding mode on and off (see further below for an
263 explanation of what these are).
264
265 In the case of ""today()"", ""now()"" and ""today_and_now()"", a
266 "true" value indicates "GMT" (Greenwich Mean Time), as opposed to
267 local time, which is the default.
268
269 • NUMBER
270
271 "NUMBER" is a number between 0 and 2 (for "number_format()" and
272 "number()") or between 0 and 4 (for "delta_format()", "date_format()"
273 and "string()"), indicating which of the three/five predefined
274 formats, respectively, should be used for converting a date into
275 numeric representation (needed for comparing dates, for instance) or
276 string representation.
277
278 Format #0 is the default at startup and the simplest of all (and
279 should be fastest to calculate, too).
280
281 The string representation of dates in format #0 also has the
282 advantage of being sortable in chronological order (and of complying
283 with ISO 8601).
284
285 (The numeric formats are (trivially) always sortable in chronological
286 order of course.)
287
288 The other formats are (mostly) increasingly more sophisticated (in
289 terms of esthetics and computation time) with increasing number
290 (except for format #4):
291
292 Delta number formats (short):
293
294 0 13603
295 1 13603
296 2 13603
297
298 Delta string formats (short):
299
300 0 '+0+0+13603'
301 1 '+0 +0 +13603'
302 2 '+0Y +0M +13603D'
303 3 '+0 Y +0 M +13603 D'
304 4 '(0,0,13603)'
305
306 Date number formats (short):
307
308 0 20010401
309 1 730576
310 2 730576
311
312 Date string formats (short):
313
314 0 '20010401'
315 1 '01-Apr-2001'
316 2 'Sun 1-Apr-2001'
317 3 'Sunday, April 1st 2001'
318 4 '[2001,4,1]'
319
320 Delta number formats (long):
321
322 0 13603.012959
323 1 13603.012959
324 2 13603.0624884259
325
326 Delta string formats (long):
327
328 0 '+0+0+13603+1+29+59'
329 1 '+0 +0 +13603 +1 +29 +59'
330 2 '+0Y +0M +13603D +1h +29m +59s'
331 3 '+0 Y +0 M +13603 D +1 h +29 m +59 s'
332 4 '(0,0,13603,1,29,59)'
333
334 Date number formats (long):
335
336 0 20010401.082959
337 1 730576.082959
338 2 730576.354155093
339
340 Date string formats (long):
341
342 0 '20010401082959'
343 1 '01-Apr-2001 08:29:59'
344 2 'Sun 1-Apr-2001 08:29:59'
345 3 'Sunday, April 1st 2001 08:29:59'
346 4 '[2001,4,1,8,29,59]'
347
348 If a number outside of the permitted range is specified, or if the
349 value is not a code reference (see also the next section below for
350 more details), the default format #0 is used instead.
351
352 • CODEREF
353
354 "CODEREF" is the reference of a subroutine which can be passed to the
355 methods "number_format()", "delta_format()" and "date_format()" in
356 order to install a callback function which will be called
357 subsequently whenever a date (or delta) object needs to be
358 (implicitly) converted into a number or string.
359
360 This happens for instance when you compare two date objects, or when
361 you put a date object reference in a string between double quotes.
362
363 Such a "CODEREF" can also be passed to the methods "number()" and
364 "string()" for explicitly converting a date object as desired.
365
366 • LANGUAGE
367
368 "LANGUAGE" is either a number in the range "[1..Languages()]", or one
369 of the strings ""Language_to_Text(1..Languages())"" (see also
370 Date::Pcalc(3)).
371
372 • TYPE
373
374 "TYPE" is 0 for a regular date and 1 for a delta vector (a list of
375 year, month, day and optionally hours, minutes and seconds offsets).
376
377 • Storage
378
379 "Date::Pcalc" objects are implemented as two nested arrays.
380
381 The "blessed" array (whose reference is the object reference you
382 receive when calling the "new()" method) contains an anonymous array
383 at position zero and the object's data in its remaining fields.
384
385 The embedded anonymous array is used for storing the object's
386 attributes (flags).
387
388 Dates and delta vectors always comprise either 3 or 6 data values:
389 Year, month, day plus (optionally) hours, minutes and seconds.
390
391 These values are stored in the "blessed" array at positions 1..3 or
392 1..6, respectively.
393
394 An object without the time values is therefore called "short", and an
395 object having time values is called "long" throughout this manual.
396
397 Hint: Whenever possible, if you do not need the time values, omit
398 them, i.e., always use the "short" form of the object if possible,
399 this will speed up calculations a little (the short form uses
400 different (faster) functions for all calculations internally).
401
402 The embedded anonymous array contains various flags:
403
404 At position zero, it contains the "TYPE" indicator which determines
405 whether the object is a date or a delta vector.
406
407 At position 1, the object stores the "NUMBER" of one of the delta
408 vector formats, or the reference of a callback function which
409 converts the contents of the object into string representation if
410 it's a delta vector, or "undef" if the global settings apply.
411
412 At position 2, the object stores the "NUMBER" of one of the date
413 formats, or the reference of a callback function which converts the
414 contents of the object into string representation if it's a date, or
415 "undef" if the global settings apply.
416
417 At position 3, the object stores the "LANGUAGE" to be used for all
418 conversions into strings (where applicable), or "undef" if the global
419 language setting applies.
420
421 Note that your callback functions (see the section "Callback
422 Functions" further below for more details) should not pay attention
423 to this value at position 3, because they get a parameter which tells
424 them which language to use (this is necessary in order to allow
425 temporary overrides).
426
427 If your callback handlers use the "*_to_Text*" functions (or any
428 other language-dependent function) from the "Date::Pcalc" module,
429 your handlers should pass on this language parameter to these
430 functions (and not the value from position 3).
431
432 Be reminded though that you should NEVER access the object's internal
433 data directly, i.e., through their positional numbers, but ALWAYS
434 through their respective accessor methods, e.g.:
435
436 year()
437 month()
438 day()
439 hours()
440 minutes()
441 seconds()
442 date()
443 time()
444 datetime()
445 is_delta()
446 is_date()
447 is_short()
448 is_long()
449 delta_format()
450 date_format()
451 language()
452
453 And although position 4 and onward in the embedded anonymous array is
454 currently unused, it might not stay so in future releases of this
455 module.
456
457 Therefore, in case you need more attributes in a subclass of the
458 "Date::Pcalc[::Object]" class, I suggest using values starting at
459 positions a bit further up, e.g. 6, 8 or 10.
460
461 • Invalid Dates
462
463 Only "new()" allows to create objects containing possibly invalid
464 dates (needed for reading in and evaluating user input, for example).
465
466 • Usage
467
468 The methods
469
470 accurate_mode()
471 normalized_mode()
472 number_format()
473 delta_format()
474 date_format()
475 language()
476 date()
477 time()
478 datetime()
479 year()
480 month()
481 day()
482 hours()
483 minutes()
484 seconds()
485
486 are used for reading as well as for setting attributes. They simply
487 return the values in question if they are called without parameters.
488
489 The methods
490
491 accurate_mode()
492 normalized_mode()
493 number_format()
494 delta_format()
495 date_format()
496 language()
497
498 always return the previous value if a new value is set. This allows
499 you to change these values temporarily and to restore their old value
500 afterwards more easily (but you can also override the "format" and
501 "language" settings directly when calling the "number()" or
502 "string()" method).
503
504 The methods
505
506 date()
507 time()
508 datetime()
509 year()
510 month()
511 day()
512 hours()
513 minutes()
514 seconds()
515
516 always return the new values when the corresponding values have been
517 changed.
518
519 The method "date()" NEVER returns the time values (hours, minutes,
520 seconds) even if they have just been set using this method (which the
521 method optionally allows). Otherwise it would be very hard to predict
522 the exact number of values it returns, which might lead to errors
523 (wrong number of parameters) elsewhere in your program.
524
525 The method "datetime()" ALWAYS returns the time values (hours,
526 minutes, seconds) even if the object in question lacks a time part.
527 In that case, zeros are returned for hours, minutes and seconds
528 instead (but the stored time part is left unchanged, whether it
529 exists or not).
530
531 If you do not provide values for hours, minutes and seconds when
532 using the method "date()" to set the values for year, month and day,
533 the time part will not be changed (whether it exists or not).
534
535 If you do not provide values for hours, minutes and seconds when
536 using the method "datetime()" to set the values for year, month and
537 day, the time part will be filled with zeros (the time part will be
538 created if necessary).
539
540 If the object is short, i.e., if it does not have any time values,
541 the method "time()" returns an empty list.
542
543 If the object is short and the methods "hours()", "minutes()" or
544 "seconds()" are used to set any of these time values, the object is
545 automatically promoted to the "long" form, and the other two time
546 values are filled with zeros.
547
548 The following methods can also return "undef" under certain
549 circumstances:
550
551 delta_format()
552 date_format()
553 language()
554 is_delta()
555 is_date()
556 is_short()
557 is_long()
558 is_valid()
559 hours()
560 minutes()
561 seconds()
562 number()
563 string()
564
565 The methods "delta_format()", "date_format()" and "language()" return
566 "undef" when they are called as object methods and no individual
567 override has been defined for the object in question.
568
569 The "is_*()" predicate methods return "undef" if the object in
570 question does not have the expected internal structure. This can
571 happen for instance when you create an empty object with "new()".
572
573 When called without parameters, the methods "hours()", "minutes()"
574 and "seconds()" return "undef" if the object in question does not
575 have a time part.
576
577 The methods "number()" and "string()" return "undef" if the object in
578 question is not valid (i.e., if "is_valid()" returns "undef" or
579 false).
580
581 And finally, the methods
582
583 copy()
584 today()
585 now()
586 today_and_now()
587 gmtime()
588 localtime()
589 tzoffset()
590 time2date()
591 normalize()
592
593 return the object reference of the (target) object in question for
594 convenience.
595
596 • Import/Export
597
598 Note that you can import and export Unix "time" values using the
599 methods "gmtime()", "localtime()", "mktime()", "date2time()" and
600 "time2date()", both as local time or as UTC/GMT.
601
602 • Accurate Mode and Normalized Mode
603
604 The method "accurate_mode()" controls the internal flag which
605 determines which of two fundamental modes of operation is used.
606
607 When set to true (the default at startup), delta vectors are
608 calculated to give the exact difference in days between two dates.
609 The "year" and "month" entries in the resulting delta vector are
610 always zero in that case.
611
612 If "accurate mode" is switched off (when the corresponding flag is
613 set to false), delta vectors are calculated with year and month
614 differences.
615
616 E.g., the difference between "[1999,12,6]" and "[2000,6,24]" is "[+0
617 +0 +201]" (plus 201 days) in accurate mode and "[+1 -6 +18]" (plus
618 one year, minus 6 months, plus 18 days) when accurate mode is
619 switched off, and is "[+0 +6 +18]" (plus 6 months, plus 18 days) if
620 additionally, "normalized mode" is switched on.
621
622 The delta vector is calculated by simply taking the difference in
623 years, the difference in months and the difference in days (if
624 "accurate mode" is switched off and if "normalized mode" has not been
625 switched on). This is called "one-by-one" semantics or "year-month-
626 day mode"; "YMD mode" for short.
627
628 When "normalized mode" is switched on (while "accurate mode" is
629 switched off), the delta vector is calculated in a more complex way
630 involving the functions ""Add_Delta_YM()"" (for "truncation") and
631 ""Delta_Days()"".
632
633 Moreover, the result is normalized, i.e., the return values are
634 guaranteed to all have the same sign (or to be zero), and to all be
635 "minimal", i.e., not to exceed the ranges "[-11..+11]" for months,
636 "[-30..+30]" for days, "[-23..+23]" for hours and "[-59..+59]" for
637 minutes and seconds.
638
639 The rule is to add these result values to a date in a left-to-right
640 order, and to truncate invalid intermediate dates, such as e.g.
641 "[2009,2,29]", to the last valid day of that same month, e.g.
642 "[2009,2,28]". This is called "left-to-right with truncation"
643 semantics or "normalized mode"; "N_YMD mode" for short.
644
645 The method "normalized_mode()" controls the internal flag which
646 determines whether "YMD mode" is used (the default at startup, for
647 reasons of backward compatibility) or "N_YMD mode".
648
649 Note that also for reasons of backward compatibility, this flag only
650 has effect when "accurate mode" is switched off.
651
652 Both flags can be set and reset independently from each other,
653 however.
654
655 Therefore, at startup, you can for instance switch "normalized mode"
656 on, without having any immediate effect, and switch off "accurate
657 mode" later, which instantly also causes "normalized mode" to spring
658 into effect.
659
660 Because years and months have varying lengths in terms of days, the
661 "YMD" and "N_YMD" modes are less accurate than "accurate mode",
662 because these modes depend on the context of the two dates of which
663 the delta vector is the difference. Added to a different date, a
664 delta vector calculated in "YMD mode" or "N_YMD mode" may yield a
665 different offset in terms of days, i.e., the final result may
666 sometimes vary seemingly unpredictably (or in other situations may
667 give you the expected result, at the expense of actually representing
668 a varying difference in days, determined exclusively by context).
669
670 Beware also that - for the same reason - the absolute value
671 (""abs()"") of a delta vector returns a fictitious number of days if
672 the delta vector contains non-zero values for "year" and/or "month"
673 (see also the next section "Absolute Value" below for more details).
674
675 Example:
676
677 The difference between "[2000,1,1]" and "[2000,3,1]" is "[+0 +0 +60]"
678 in "accurate mode" and "[+0 +2 +0]" in "YMD mode" (in this "benign"
679 example, the result is the same in "YMD mode" and in "N_YMD mode").
680
681 When added to the date "[2000,4,1]", the "accurate" delta vector
682 yields the date "[2000,5,31]", whereas the "YMD mode" delta vector
683 yields the date "[2000,6,1]" (which is actually a difference of 61
684 days).
685
686 Moreover, when added to the date "[1999,1,1]", the "accurate" delta
687 vector yields the date "[1999,3,2]", whereas the "inaccurate" "YMD
688 Mode" delta vector yields the date "[1999,3,1]" (which is actually a
689 difference of 59 days).
690
691 Depending on what you want, either mode may suit you better.
692
693 • Absolute Value
694
695 Note that ""abs($date)"" and ""abs($delta)"" are just shorthands for
696 ""$date->number()"" and ""$delta->number()"".
697
698 The operator ""abs()"", when applied to a date or delta vector,
699 returns the corresponding number of days (see below for an exception
700 to this), with the time part (if available) represented by a fraction
701 after the decimal point.
702
703 In the case of dates, the absolute value (to the left of the decimal
704 point) is the number of days since the 1st of January 1 A.D. (by
705 extrapolating the Gregorian calendar back beyond its "natural" limit
706 of 1582 A.D.) PLUS ONE.
707
708 (I.e., the absolute value of the 1st of January 1 A.D. is 1.)
709
710 Exception:
711
712 If the "NUMBER" or "number_format()" is set to 0 (the default
713 setting), the absolute value of a date to the left of the decimal
714 point is "yyyymmdd", i.e., the number in which the uppermost four
715 digits correspond to the year, the next lower two digits to the month
716 and the lowermost two digits to the day.
717
718 In the case of delta vectors, the absolute value (to the left of the
719 decimal point) is simply the difference in days (but see also below).
720
721 Note that the absolute value of a delta vector can be negative!
722
723 If you want a positive value in all cases, apply the ""abs()""
724 operator again, i.e., ""$posdiff = abs(abs($delta));"".
725
726 If the delta vector contains non-zero values for "year" and/or
727 "month" (see also the discussion of "Accurate Mode" in the section
728 above), an exact representation in days cannot be calculated, because
729 years and months do not have fixed equivalents in days.
730
731 If nevertheless you attempt to calculate the absolute value of such a
732 delta vector, a fictitious value is returned, which is calculated by
733 simply multiplying the year difference with 12, adding the month
734 difference, multiplying this sum with 31 and finally adding the day
735 difference.
736
737 Beware that because of this, the absolute values of delta vectors are
738 not necessarily contiguous.
739
740 Moreover, since there is more than one way to express the difference
741 between two dates, comparisons of delta vectors may not always yield
742 the expected result.
743
744 Example:
745
746 The difference between the two dates "[2000,4,30]" and "[2001,5,1]"
747 can be expressed as "[+1 +1 -29]", or as "[+1 +0 +1]".
748
749 The first delta vector has an absolute value of 374, whereas the
750 latter delta vector has an absolute value of only 373 (while the true
751 difference in days between the two dates is 366).
752
753 If the date or delta vector has a time part, the time is returned as
754 a fraction of a full day after the decimal point as follows:
755
756 If the "NUMBER" or "number_format()" is set to 0 (the default
757 setting) or 1, this fraction is simply ".hhmmss", i.e., the two
758 digits after the decimal point represent the hours, the next two
759 digits the minutes and the last two digits the seconds.
760
761 Note that you cannot simply add and subtract these values to yield
762 meaningful dates or deltas again, you can only use them for
763 comparisons (equal, not equal, less than, greater than, etc.). If you
764 want to add/subtract, read on:
765
766 Only when the "NUMBER" or "number_format()" is set to 2, this
767 fraction will be the equivalent number of seconds (i.e., "(((hours *
768 60) + minutes) * 60) + seconds") divided by the number of seconds in
769 a full day (i.e., "24*60*60 = 86400"), or "0/86400", "1/86400", ... ,
770 "86399/86400".
771
772 In other words, the (mathematically correct) fraction of a day.
773
774 You can safely perform arithmetics with these values as far as the
775 internal precision of your vendor's implementation of the C run-time
776 library (on which Perl depends) will permit.
777
778 • Renormalizing Delta Vectors
779
780 When adding or subtracting delta vectors to/from one another, the
781 addition or subtraction takes place component by component.
782
783 Example:
784
785 [+0 +0 +0 +3 +29 +50] + [+0 +0 +0 +0 +55 +5] = [+0 +0 +0 +3 +84 +55]
786 [+0 +0 +0 +3 +29 +50] - [+0 +0 +0 +0 +55 +5] = [+0 +0 +0 +3 -26 +45]
787
788 This may result in time values outside the usual ranges ("[-23..+23]"
789 for hours and "[-59..+59]" for minutes and seconds).
790
791 Note that even though the delta value for days will often become
792 quite large, it is impossible to renormalize this value because there
793 is no constant conversion factor from days to months (should it be
794 28, 29, 30 or 31?).
795
796 If accurate mode (see further above for what that is) is switched
797 off, delta vectors can also contain non-zero values for years and
798 months. If you add or subtract these, the value for months can lie
799 outside the range "[-11..11]", which isn't wrong, but may seem funny.
800
801 Therefore, the "normalize()" method will also renormalize the
802 "months" value, if and only if accurate mode has been switched off.
803 (!)
804
805 (Hence, switch accurate mode ON temporarily if you DON'T want the
806 renormalization of the "months" value to happen.)
807
808 If you want to force the time values from the example above back into
809 their proper ranges, use the "normalize()" method as follows:
810
811 print "[$delta]\n";
812 $delta->normalize();
813 print "[$delta]\n";
814
815 This will print
816
817 [+0 +0 +0 +3 +84 +55]
818 [+0 +0 +0 +4 +24 +55]
819
820 for the first and
821
822 [+0 +0 +0 +3 -26 +45]
823 [+0 +0 +0 +2 +34 +45]
824
825 for the second delta vector from the example further above.
826
827 Note that the values for days, hours, minutes and seconds are
828 guaranteed to have the same sign after the renormalization.
829
830 Under "normal" circumstances, i.e., when accurate mode is on (the
831 default), this method only has an effect on the time part of the
832 delta vector.
833
834 If the delta vector in question does not have a time part, nothing
835 happens.
836
837 If accurate mode is off, the "months" value is also normalized, i.e.,
838 if it lies outside of the range "[-11..11]", integer multiples of 12
839 are added to the "years" value and subtracted from the "months"
840 value. Moreover, the "months" value is guaranteed to have the same
841 sign as the values for days, hours, minutes and seconds, unless the
842 "months" value is zero or the values for days, hours, minutes and
843 seconds are all zero.
844
845 If the object in question is a date and if warnings are enabled, the
846 message "normalizing a date is a no-op" will be printed to STDERR.
847
848 If the object in question is not a valid "Date::Pcalc" object,
849 nothing happens.
850
851 The method returns its object's reference, which allows chaining of
852 method calls, as in the following example:
853
854 @time = $delta->normalize()->time();
855
856 • Callback Functions
857
858 Note that you are not restricted to the built-in formats (numbered
859 from 0 to 2 for "number_format()" and "number()" and from 0 to 4 for
860 "delta_format()", "date_format()" and "string()") for converting a
861 date or delta object into a number or string.
862
863 You can also provide your own function(s) for doing so, in order to
864 suit your own taste or needs, by passing a subroutine reference to
865 the appropriate method, i.e., "number_format()", "number()",
866 "delta_format()", "date_format()" and "string()".
867
868 You can pass a handler to only one or more of these methods, or to
869 all of them, as you like. You can use different callback functions,
870 or the same for all.
871
872 In order to facilitate the latter, and in order to make the decoding
873 of the various cases easier for you, the callback function receives a
874 uniquely identifying function code as its second parameter:
875
876 0 = TO_NUMBER | IS_DATE | IS_SHORT (number[_format])
877 1 = TO_NUMBER | IS_DATE | IS_LONG (number[_format])
878 2 = TO_NUMBER | IS_DELTA | IS_SHORT (number[_format])
879 3 = TO_NUMBER | IS_DELTA | IS_LONG (number[_format])
880 4 = TO_STRING | IS_DATE | IS_SHORT (string|date_format)
881 5 = TO_STRING | IS_DATE | IS_LONG (string|date_format)
882 6 = TO_STRING | IS_DELTA | IS_SHORT (string|delta_format)
883 7 = TO_STRING | IS_DELTA | IS_LONG (string|delta_format)
884
885 The first parameter of the callback function is of course the
886 reference of the object in question itself (therefore, the callback
887 function can actually be an object method - but not a class method,
888 for obvious reasons).
889
890 The third parameter is the number of the language (in the range
891 "[1..Languages()]") which you should always pass along when using any
892 of the following functions from the "Date::Pcalc" module in your
893 handler:
894
895 "Decode_Month()", "Decode_Day_of_Week()", "Compressed_to_Text()",
896 "Date_to_Text()", "Date_to_Text_Long()", "Calendar()",
897 "Month_to_Text()", "Day_of_Week_to_Text()",
898 "Day_of_Week_Abbreviation()", "Decode_Date_EU()", "Decode_Date_US()",
899 "Decode_Date_EU2()", "Decode_Date_US2()", "Parse_Date()".
900
901 The callback handler should return the resulting number or string, as
902 requested.
903
904 BEWARE that you should NEVER rely upon any knowledge of the object's
905 internal structure, as this may be subject to change!
906
907 ALWAYS use the test and access methods provided by this module!
908
909 Example:
910
911 sub handler
912 {
913 my($self,$code,$lang) = @_;
914
915 if ($code == 0) # TO_NUMBER | IS_DATE | IS_SHORT
916 {
917 return Date_to_Days( $self->date() );
918 }
919 elsif ($code == 1) # TO_NUMBER | IS_DATE | IS_LONG
920 {
921 return Date_to_Days( $self->date() ) +
922 ( ( $self->hours() * 60 +
923 $self->minutes() ) * 60 +
924 $self->seconds() ) / 86400;
925 }
926 elsif ($code == 2) # TO_NUMBER | IS_DELTA | IS_SHORT
927 {
928 return ( $self->year() * 12 +
929 $self->month() ) * 31 +
930 $self->day();
931 }
932 elsif ($code == 3) # TO_NUMBER | IS_DELTA | IS_LONG
933 {
934 return ( $self->year() * 12 +
935 $self->month() ) * 31 +
936 $self->day() +
937 ( ( $self->hours() * 60 +
938 $self->minutes() ) * 60 +
939 $self->seconds() ) / 86400;
940 }
941 elsif ($code == 4) # TO_STRING | IS_DATE | IS_SHORT
942 {
943 return join( "/", $self->date() );
944 }
945 elsif ($code == 5) # TO_STRING | IS_DATE | IS_LONG
946 {
947 return join( "/", $self->date() ) . " " .
948 join( ":", $self->time() );
949 }
950 elsif ($code == 6) # TO_STRING | IS_DELTA | IS_SHORT
951 {
952 return join( "|", $self->date() );
953 }
954 elsif ($code == 7) # TO_STRING | IS_DELTA | IS_LONG
955 {
956 return join( "|", $self->datetime() );
957 }
958 else
959 {
960 die "internal error";
961 }
962 }
963
964 Date::Pcalc->number_format(\&handler);
965 Date::Pcalc->delta_format(\&handler);
966 Date::Pcalc->date_format(\&handler);
967
968 This sets our handler to take care of all automatic conversions, such
969 as needed when comparing dates or when interpolating a string in
970 double quotes which contains a date object.
971
972 To deactivate a handler, simply pass a valid format number to the
973 method in question, e.g.:
974
975 Date::Pcalc->number_format(0);
976 Date::Pcalc->delta_format(2);
977 Date::Pcalc->date_format(3);
978
979 When calling the "number()" or "string()" method explicitly, you can
980 pass a different format number (than the global setting), like this:
981
982 $number = $date->number(2);
983 $string = $date->string(1);
984
985 You can also pass a handler's reference, like so:
986
987 $number = $date->number(\&handler);
988 $string = $date->string(\&handler);
989
990 This overrides the global setting and the individual object's local
991 setting for the duration of the call of "number()" or "string()" (but
992 doesn't change the global or local settings themselves).
993
994 Moreover, you can also define individual overrides for the date and
995 the delta vector formats (but not the number format) for individual
996 objects, e.g.:
997
998 $date->delta_format(1);
999 $date->date_format(2);
1000
1001 $date->delta_format(\&handler);
1002 $date->date_format(\&handler);
1003
1004 In order to deactivate an individual handler for an object, and/or in
1005 order to deactivate any override altogether (so that the global
1006 settings apply again), you have to pass "undef" explicitly to the
1007 method in question:
1008
1009 $date->delta_format(undef);
1010 $date->date_format(undef);
1011
1012 You can also define a language for individual objects (see the next
1013 section immediately below for more details).
1014
1015 If such an individual language override has been set, it will be
1016 passed to your callback handlers as the third parameter (in the case
1017 of "string" conversions, but not in the case of "number"
1018 conversions).
1019
1020 Otherwise, the global settings as defined by "Language($lang);" or
1021 "Date::Pcalc-"language($lang);> will be passed to your handler.
1022
1023 • Languages
1024
1025 Note that this module is completely transparent to the setting of a
1026 language in "Date::Pcalc". This means that you can choose a language
1027 in "Date::Pcalc" (with the "Language()" function) and all dates
1028 subsequently printed by this module will automatically be in that
1029 language - provided that you use the built-in formats of this module,
1030 or that you pass the third parameter of the callback funtion to the
1031 funtions of the "Date::Pcalc" module which accept it.
1032
1033 However, this global language setting can be overridden for
1034 individual date (or delta) objects by using the OBJECT method
1035
1036 $oldlang = $date->language($newlang);
1037
1038 (The global setting is not altered by this in any way.)
1039
1040 In order to deactivate such an individual language setting (so that
1041 the global setting applies again), simply pass the value "undef"
1042 explicitly to the "language()" object method:
1043
1044 $date->language(undef);
1045
1046 The CLASS method
1047
1048 $oldlang = Date::Pcalc->language($newlang);
1049
1050 is just a convenient wrapper around the "Language()" function, which
1051 allows you to enter language numbers (as returned by the
1052 "Decode_Language()" function) or strings (as returned by the
1053 "Language_to_Text()" function), whatever you prefer.
1054
1055 The "language()" method (both class and object) always returns the
1056 NAME (one of ""Language_to_Text(1..Languages())"") of the current
1057 setting (and never its number).
1058
1059 BEWARE that in order to avoid possible conflicts between threads or
1060 modules running concurrently, you should NEVER use the global
1061 function "Language($lang);" or the class method
1062 "Date::Pcalc-"language($lang);> in this module!
1063
1064 The class method is retained only for backward compatibility and for
1065 convenience in stand-alone applications when it is guaranteed that no
1066 such conflicts can arise.
1067
1068 But you should probably avoid to use global settings anyway, because
1069 it may be especially troublesome to fix your code later when suddenly
1070 the need arises to use your code with threads or when your code needs
1071 to use other modules which also use "Date::Pcalc" (with different
1072 settings!).
1073
1074 By exclusively using local settings, you are making your code
1075 invulnerable against other, concurrent modules also using
1076 "Date::Pcalc" which still use global settings.
1077
1078 • Exported Functions
1079
1080 The "Date::Pcalc::Object" package imports ":all" functions exported
1081 by the "Date::Pcalc" module and re-exports them, for conveniency.
1082
1083 This allows you to write
1084
1085 use Date::Pcalc::Object qw(...);
1086
1087 instead of
1088
1089 use Date::Pcalc qw(...);
1090
1091 but with exactly the same semantics. The difference is that the
1092 object-oriented frontend is loaded additionally in the first case.
1093
1094 As with "Date::Pcalc" you can use the ":all" tag to import all of
1095 "Date::Pcalc"'s functions:
1096
1097 use Date::Pcalc::Object qw(:all);
1098
1099 In addition to the functions exported by "Date::Pcalc", the
1100 "Date::Pcalc::Object" package offers some utility functions of its
1101 own for export:
1102
1103 $year = shift_year(\@_);
1104 ($year,$mm,$dd) = shift_date(\@_);
1105 ($hrs,$min,$sec) = shift_time(\@_);
1106 ($year,$mm,$dd,$hrs,$min,$sec) = shift_datetime(\@_);
1107
1108 These functions enable your subroutines or methods to accept a
1109 "Date::Pcalc" (or subclass) date object, an (anonymous) array or a
1110 list (containing the necessary values) as parameters INTERCHANGEABLY.
1111
1112 You can import all of these auxiliary functions by using an ":aux"
1113 tag:
1114
1115 use Date::Pcalc::Object qw(:aux);
1116
1117 If you want to import both all of the "Date::Pcalc" functions as well
1118 as all these auxiliary functions, use the ":ALL" tag:
1119
1120 use Date::Pcalc::Object qw(:ALL);
1121
1122 • Subclassing
1123
1124 In case you want to subclass "Date::Pcalc" objects and to add new
1125 attributes of your own, it is recommended that you proceed as follows
1126 (the following will be considered as a part of the module's "contract
1127 of use" - which might be subject to change in the future, however):
1128
1129 Define a constant for the index of each attribute you want to add,
1130 currently starting no lower than "4", at the top of your subclass:
1131
1132 use constant ATTRIB1 => 4;
1133 use constant ATTRIB2 => 5;
1134 use constant ATTRIB3 => 6;
1135 ...
1136
1137 It is recommended that you use constants (which are easy to change),
1138 because I someday might want to require the element with index "4"
1139 for a new attribute of my own... ":-)"
1140
1141 Then access your attributes like so (e.g. after calling ""$self =
1142 SUPER->new();"" in your constructor method):
1143
1144 $self->[0][ATTRIB1] = 'value1';
1145 $self->[0][ATTRIB2] = 'value2';
1146 $self->[0][ATTRIB3] = 'value3';
1147 ...
1148
1149 Beware that if you put anything other than numbers or strings into
1150 your attributes, the methods "clone()" and "copy()" might not work as
1151 expected anymore!
1152
1153 Especially if your attributes contain references to other data
1154 structures, only the references will be copied, but not the data
1155 structures themselves.
1156
1157 This may not be what you want.
1158
1159 (You will have to override these two methods and write some of your
1160 own if not.)
1161
1162 In order for the overloaded operators and the "shift_*()" auxiliary
1163 functions from the "Date::Pcalc::Object" package to work properly
1164 (the latter of which are heavily used in the
1165 "Date::Pcalendar[::Year]" modules, for instance), the package name of
1166 your subclass (= the one your objects will be blessed into) is
1167 REQUIRED to contain a "::".
1168
1169 Note that you should ONLY subclass "Date::Pcalc", NEVER
1170 "Date::Pcalc::Object", since subclassing the latter is less efficient
1171 (because "Date::Pcalc::Object" is just an empty class which inherits
1172 from "Date::Pcalc" - subclassing "Date::Pcalc::Object" would thus
1173 just introduce an additional name space layer to search during Perl's
1174 runtime method binding process).
1175
1176 If you give your subclass a package name below/inside the "Date::"
1177 namespace, you will also benefit from the fact that all error
1178 messages produced by the "Date::Pcalc[::Object]" module (and also the
1179 "Date::Pcalendar[::Year]" modules, by the way) will appear to have
1180 originated from the place outside of all ""/^Date::/"" modules
1181 (including yours) where one of the "Date::" modules was first called
1182 - i.e., all errors are always blamed on the user, no matter how
1183 deeply nested inside the "Date::" modules they occur, and do not
1184 usually refer to places inside any of the "Date::" modules (this
1185 assumes that there are no bugs in the "Date::" modules, and that all
1186 errors are always the user's fault ":-)").
1187
1188 Moreover, your module's own error messages will behave in the same
1189 way if you ""use Carp::Clan qw(^Date::);"" at the top of your module
1190 and if you produce all error messages using "carp()" and "croak()"
1191 (instead of "warn()" and "die()", respectively).
1192
1194 1)
1195 # Switch to summer time:
1196 $now = Date::Pcalc->now();
1197 if (($now ge [2000,3,26,2,0,0]) and
1198 ($now lt [2000,3,26,3,0,0]))
1199 {
1200 $now += [0,0,0,1,0,0];
1201 }
1202
1203 2)
1204 use Date::Pcalc::Object qw(:all);
1205
1206 Date::Pcalc->date_format(3);
1207
1208 $date = 0;
1209 while (!$date)
1210 {
1211 print "Please enter the date of your birthday (day-month-year): ";
1212 $date = Date::Pcalc->new( Decode_Date_EU( scalar(<STDIN>) ) );
1213 if ($date)
1214 {
1215 $resp = 0;
1216 while ($resp !~ /^\s*[YyNn]/)
1217 {
1218 print "Your birthday is: $date\n";
1219 print "Is that correct? (yes/no) ";
1220 $resp = <STDIN>;
1221 }
1222 $date = 0 unless ($resp =~ /^\s*[Yy]/)
1223 }
1224 else
1225 {
1226 print "Unable to parse your birthday. Please try again.\n";
1227 }
1228 }
1229
1230 if ($date + [18,0,0] <= [Today()])
1231 { print "Ok, you are over 18.\n"; }
1232 else
1233 { print "Sorry, you are under 18!\n"; }
1234
1235 For more examples, see the "examples" subdirectory in this
1236 distribution, and their descriptions in the file "EXAMPLES.txt".
1237
1239 Date::Pcalc(3), Date::Calc::Util(3), Date::Pcalendar(3),
1240 Date::Pcalendar::Year(3), Date::Pcalendar::Profiles(3).
1241
1243 This man page documents "Date::Pcalc::Object" version 6.1.
1244
1246 Steffen Beyer
1247 mailto:STBEY@cpan.org
1248 http://www.engelschall.com/u/sb/download/
1249
1251 Copyright (c) 2000 - 2009 by Steffen Beyer. All rights reserved.
1252
1254 This package is free software; you can redistribute it and/or modify it
1255 under the same terms as Perl itself, i.e., under the terms of the
1256 "Artistic License" or the "GNU General Public License".
1257
1258 Please refer to the files "Artistic.txt" and "GNU_GPL.txt" in this
1259 distribution for details!
1260
1262 This package is distributed in the hope that it will be useful, but
1263 WITHOUT ANY WARRANTY; without even the implied warranty of
1264 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
1265
1266 See the "GNU General Public License" for more details.
1267
1268
1269
1270perl v5.34.0 2021-07-22 Date::Pcalc::Object(3)