.\" Automatically generated by Pod::Man 4.14 (Pod::Simple 3.40) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .nr rF 0 .if \n(.g .if rF .nr rF 1 .if (\n(rF:(\n(.g==0)) \{\ . if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} . \} .\} .rr rF .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "WeekCalculator 3pm" .TH WeekCalculator 3pm "2020-07-07" "Lire 2.1.1" "LogReport's Lire Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" Lire::WeekCalculator \- handle different weeknumbering schemes .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 1 \& use Lire::WeekCalculator; \& \& my $week_calc = new Lire::WeekCalculator(); \& my $week_no = $week_calc\->week_number( $time ); .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" We support three values for \s-1LR_WEEK_NUMBERING: ISO\s0 (strftime's \f(CW%V\fR): week starts on monday; W (week starts on monday) and U (week starts on sunday). See \fBstrftime\fR\|(1). .SH "CONSTRUCTOR" .IX Header "CONSTRUCTOR" .ie n .SS "new( %params )" .el .SS "new( \f(CW%params\fP )" .IX Subsection "new( %params )" Creates a new week calculator. The style of week numbering is selected using the \f(CW\*(C`style\*(C'\fR parameter. If that parameter is omitted, it defaults to the style set in 'lr_week_numbering' configuration variable. .SS "\fBstyle()\fP" .IX Subsection "style()" Returns the week numbering style used. This will be either \f(CW\*(C`U\*(C'\fR, \f(CW\*(C`W\*(C'\fR or \f(CW\*(C`ISO\*(C'\fR. .ie n .SS "week_number( $time )" .el .SS "week_number( \f(CW$time\fP )" .IX Subsection "week_number( $time )" Returns the week number of \f(CW$time\fR according the current week numbering scheme. The week number returned is between 1 and 53. .ie n .SS "week_idx( $time )" .el .SS "week_idx( \f(CW$time\fP )" .IX Subsection "week_idx( $time )" Returns the week index of \f(CW$time\fR according to the week numbering scheme. The week index is Lire specific and is used to normalise computations between different scheme in regards of the first incomplete week of the year. In the \s-1ISO\s0 case, the week index is always equals to \fBweek_number()\fR \- 1, for the other style, the week index of the week 0 will be one less than the last week number of the previous year. .SS "last_week_of_year($year)" .IX Subsection "last_week_of_year($year)" Returns the week number of the last week in the year \f(CW$year\fR. .ie n .SS "week_start( $year, $week_no )" .el .SS "week_start( \f(CW$year\fP, \f(CW$week_no\fP )" .IX Subsection "week_start( $year, $week_no )" Returns the epoch time of the first day of week \f(CW$week_no\fR in year \f(CW$year\fR when calculated using current style. .SS "find_year_week1_start_date($year)" .IX Subsection "find_year_week1_start_date($year)" Returns the date (epoch) at which the first day of the first week of the year \f(CW$year\fR starts. .SS "\fBstrformat()\fP" .IX Subsection "strformat()" Returns a string that can be used as the format specificier in calls to strftime to print the week number of this style. .SS "\fBstrfdate()\fP" .IX Subsection "strfdate()" Emulates \fBPOSIX::strftime()\fR but picks up the \f(CW%V\fR if the system strftime doesn't support it. Should be called whenever you use format strings that may contain week-of-the-year-codes. .SH "AUTHORS" .IX Header "AUTHORS" .Vb 3 \& Joost van Baal , \& Francis J. Lacoste , \& Wessel Dankers .Ve .SH "VERSION" .IX Header "VERSION" \&\f(CW$Id:\fR WeekCalculator.pm,v 1.16 2006/07/23 13:16:30 vanbaal Exp $ .SH "COPYRIGHT" .IX Header "COPYRIGHT" Copyright (C) 2002 Stichting LogReport Foundation LogReport@LogReport.org .PP This file is part of Lire. .PP Lire is free software; you can redistribute it and/or modify it under the terms of the \s-1GNU\s0 General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. .PP This program is distributed in the hope that it will be useful, but \s-1WITHOUT ANY WARRANTY\s0; without even the implied warranty of \&\s-1MERCHANTABILITY\s0 or \s-1FITNESS FOR A PARTICULAR PURPOSE.\s0 See the \&\s-1GNU\s0 General Public License for more details. .PP You should have received a copy of the \s-1GNU\s0 General Public License along with this program (see \s-1COPYING\s0); if not, check with http://www.gnu.org/copyleft/gpl.html.