Difference: TWikiTimeDotPm (1 vs. 4)

Revision 42014-10-05 - TWikiContributor

Line: 43 to 43
 

StaticMethod formatTime ($epochSeconds,$formatString,$outputTimeZone) -> $value

  • $epochSeconds epochSecs GMT
Changed:
<
<
  • $formatString twiki time date format, default $day $month $year - $hour:$min
  • $outputTimeZone timezone to display, gmtime or servertime, default is whatever is set in $TWiki::cfg{DisplayTimeValues}
>
>
  • $formatString twiki time date format, default $TWiki::cfg{DefaultDateFormat} - $hour:$min
  • $outputTimeZone timezone to display, gmtime or servertime, default is whatever is set in $TWiki::cfg{DisplayTimeValues}
 $formatString supports:
$seconds secs
$minutes mins

Revision 32008-01-22 - TWikiContributor

Line: 11 to 11
 
  • $sDate - date/time string

Handles the following formats:

Added:
>
>
Default TWiki format
 
  • 31 Dec 2001 - 23:59
Added:
>
>
TWiki format without time (defaults to 00:00)
  • 31 Dec 2001

Date seperated by '/', '.' or '-', time with '.' or ':' Date and time separated by ' ', '.' and/or '-'

 
  • 2001/12/31 23:59:59
  • 2001.12.31.23.59.59
  • 2001/12/31 23:59
  • 2001.12.31.23.59
Added:
>
>
  • 2001-12-31 23:59
  • 2001-12-31 - 23:59

ISO format

 
  • 2001-12-31T23:59:59
ISO dates may have a timezone specifier, either Z or a signed difference in hh:mm format. For example:

Revision 22007-01-16 - TWikiContributor

Line: 5 to 5
 
Changed:
<
<

StaticMethod parseTime ($szDate) -> $iSecs

>
>

StaticMethod parseTime ($szDate,$defaultLocal) -> $iSecs

 
Changed:
<
<
Convert string date/time to seconds since epoch.
>
>
Convert string date/time string to seconds since epoch (1970-01-01T00:00:00Z).
 
  • $sDate - date/time string

Handles the following formats:

Line: 16 to 16
 
  • 2001.12.31.23.59.59
  • 2001/12/31 23:59
  • 2001.12.31.23.59
Changed:
<
<
  • 2001-12-31T23:59:59Z
>
>
  • 2001-12-31T23:59:59
ISO dates may have a timezone specifier, either Z or a signed difference in hh:mm format. For example:
 
  • 2001-12-31T23:59:59+01:00
  • 2001-12-31T23:59Z
Changed:
<
<
  • 2001-12-31T23:59+01:00
>
>
The default timezone is Z, unless $defaultLocal is true in which case the local timezone will be assumed.
  If the date format was not recognised, will return 0.
Line: 88 to 93
 
  • 2001-01-01T00:00:00
  • 2001-12-31T23:59:59
Changed:
<
<
timezone is optional and not supported yet.
>
>
timezone is optional. Default is local time.
  If the format is not recognised, will return empty interval [0,0].

Revision 12006-02-01 - TWikiContributor

Line: 1 to 1
Added:
>
>

Package TWiki::Time

Time handling functions.

StaticMethod parseTime ($szDate) -> $iSecs

Convert string date/time to seconds since epoch.

  • $sDate - date/time string

Handles the following formats:

  • 31 Dec 2001 - 23:59
  • 2001/12/31 23:59:59
  • 2001.12.31.23.59.59
  • 2001/12/31 23:59
  • 2001.12.31.23.59
  • 2001-12-31T23:59:59Z
  • 2001-12-31T23:59:59+01:00
  • 2001-12-31T23:59Z
  • 2001-12-31T23:59+01:00

If the date format was not recognised, will return 0.

StaticMethod formatTime ($epochSeconds,$formatString,$outputTimeZone) -> $value

  • $epochSeconds epochSecs GMT
  • $formatString twiki time date format, default $day $month $year - $hour:$min
  • $outputTimeZone timezone to display, gmtime or servertime, default is whatever is set in $TWiki::cfg{DisplayTimeValues}
$formatString supports:
$seconds secs
$minutes mins
$hours hours
$day date
$wday weekday name
$dow day number (0 = Sunday)
$week week number
$month month name
$mo month number
$year 4-digit year
$ye 2-digit year
$http ful HTTP header format date/time
$email full email format date/time
$rcs full RCS format date/time
$epoch seconds since 1st January 1970

StaticMethod formatDelta ($s) -> $string

Format a time in seconds as a string. For example, "1 day, 3 hours, 2 minutes, 6 seconds"

StaticMethod parseInterval ($szInterval) -> [$iSecs,$iSecs]

Convert string representing a time interval to a pair of integers representing the amount of seconds since epoch for the start and end extremes of the time interval.

  • $szInterval - time interval string

in yacc syntax, grammar and actions:

interval ::= date                 { $$.start = fillStart($1); $$.end = fillEnd($1); }
         | date '/' date          { $$.start = fillStart($1); $$.end = fillEnd($3); }
         | 'P' duration '/' date  { $$.start = fillEnd($4)-$2; $$.end = fillEnd($4); }
         | date '/' 'P' duration  { $$.start = fillStart($1); $$.end = fillStart($1)+$4; }
         ;
an interval may be followed by a timezone specification string (this is not supported yet).

duration has the form (regular expression):

   P(<number><nameOfDuration>)+

nameOfDuration may be one of:

  • y(year), m(month), w(week), d(day), h(hour), M(minute), S(second)

date follows ISO8601 and must include hypens. (any amount of trailing elements may be omitted and will be filled in differently on the differents ends of the interval as to include the longest possible interval):

  • 2001-01-01T00:00:00
  • 2001-12-31T23:59:59

timezone is optional and not supported yet.

If the format is not recognised, will return empty interval [0,0].

TODO: timezone testing, especially on non valid strings

 
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 1999-2025 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback
Note: Please contribute updates to this topic on TWiki.org at TWiki:TWiki.TWikiTimeDotPm.