/**
* date.php
*
- * Copyright (c) 1999-2001 The SquirrelMail Development Team
+ * Copyright (c) 1999-2003 The SquirrelMail Project Team
* Licensed under the GNU GPL. For full terms see the file COPYING.
*
* Takes a date and parses it into a usable format. The form that a
* $Id$
*/
-require_once( '../functions/constants.php' );
+require_once(SM_PATH . 'functions/constants.php');
-// corrects a time stamp to be the local time
-function getGMTSeconds($stamp, $gmt) {
- global $invert_time;
- if (($gmt == 'Pacific') || ($gmt == 'PST')) {
- $gmt = '-0800';
- } else if (($gmt == 'EDT')) {
- $gmt = '-0400';
- } else if (($gmt == 'Eastern') || ($gmt == 'EST') || ($gmt == 'CDT')) {
- $gmt = '-0500';
- } else if (($gmt == 'Central') || ($gmt == 'CST') || ($gmt == 'MDT')) {
- $gmt = '-0600';
- } else if (($gmt == 'Mountain') || ($gmt == 'MST') || ($gmt == 'PDT')) {
- $gmt = '-0700';
- } else if ($gmt == 'BST') {
- $gmt = '+0100';
- } else if ($gmt == 'EET') {
- $gmt = '+0200';
- } else if ($gmt == 'GMT') {
- $gmt = '+0000';
- } else if ($gmt == 'HKT') {
- $gmt = '+0800';
- } else if ($gmt == 'IST') {
- $gmt = '+0200';
- } else if ($gmt == 'JST') {
- $gmt = '+0900';
- } else if ($gmt == 'KST') {
- $gmt = "+0900";
- } else if ($gmt == 'MET') {
- $gmt = '+0100';
- } else if ($gmt == 'MET DST' || $gmt == 'METDST') {
- $gmt = '+0200';
+/* corrects a time stamp to be the local time */
+function getGMTSeconds($stamp, $tzc) {
+ /* date couldn't be parsed */
+ if ($stamp == -1) {
+ return -1;
}
-
- if (substr($gmt, 0, 1) == '-') {
- $neg = true;
- $gmt = substr($gmt, 1, strlen($gmt));
- } else if (substr($gmt, 0, 1) == '+') {
- $neg = false;
- $gmt = substr($gmt, 1, strlen($gmt));
- } else {
- $neg = false;
+ /* timezone correction, expressed as `shhmm' */
+ switch($tzc)
+ {
+ case 'Pacific':
+ case 'PST':
+ $tzc = '-0800';
+ break;
+ case 'Mountain':
+ case 'MST':
+ case 'PDT':
+ $tzc = '-0700';
+ break;
+ case 'Central':
+ case 'CST':
+ case 'MDT':
+ $tzc = '-0600';
+ break;
+ case 'Eastern':
+ case 'EST':
+ case 'CDT':
+ $tzc = '-0500';
+ break;
+ case 'EDT':
+ $tzc = '-0400';
+ break;
+ case 'GMT':
+ $tzc = '+0000';
+ break;
+ case 'BST':
+ case 'MET':
+ case 'CET':
+ $tzc = '+0100';
+ break;
+ case 'EET':
+ case 'IST':
+ case 'MET DST':
+ case 'METDST':
+ $tzc = '+0200';
+ break;
+ case 'HKT':
+ $tzc = '+0800';
+ break;
+ case 'JST':
+ case 'KST':
+ $tzc = '+0900';
+ break;
}
-
- $gmt = substr($gmt, 0, 2);
- $gmt = $gmt * 3600;
- if ($neg == true) {
- $gmt = "-$gmt";
- } else {
- $gmt = "+$gmt";
+ $neg = false;
+ if (substr($tzc, 0, 1) == '-') {
+ $neg = true;
+ } else if (substr($tzc, 0, 1) != '+') {
+ $tzc = '+'.$tzc;
}
-
+ $hh = substr($tzc,1,2);
+ $mm = substr($tzc,3,2);
+ $iTzc = ($hh * 60 + $mm) * 60;
+ if ($neg) $iTzc = -1 * (int) $iTzc;
+ /* stamp in gmt */
+ $stamp -= $iTzc;
/** now find what the server is at **/
$current = date('Z', time());
- if ($invert_time) {
- $current = - $current;
- }
- $stamp = (int)$stamp - (int)$gmt + (int)$current;
+ /* stamp in local timezone */
+ $stamp += $current;
return $stamp;
}
/**
- Switch system has been intentionaly choosed for the
+ Switch system has been intentionaly chosen for the
internationalization of month and day names. The reason
is to make sure that _("") strings will go into the
main po.
return( $ret );
}
+function getDayAbrv( $day_number ) {
+
+ switch( $day_number ) {
+ case 0:
+ $ret = _("Sun");
+ break;
+ case 1:
+ $ret = _("Mon");
+ break;
+ case 2:
+ $ret = _("Tue");
+ break;
+ case 3:
+ $ret = _("Wed");
+ break;
+ case 4:
+ $ret = _("Thu");
+ break;
+ case 5:
+ $ret = _("Fri");
+ break;
+ case 6:
+ $ret = _("Sat");
+ break;
+ default:
+ $ret = '';
+ }
+ return( $ret );
+}
+
function getMonthName( $month_number ) {
switch( $month_number ) {
case '01':
return( $ret );
}
+function getMonthAbrv( $month_number ) {
+ switch( $month_number ) {
+ case '01':
+ $ret = _("Jan");
+ break;
+ case '02':
+ $ret = _("Feb");
+ break;
+ case '03':
+ $ret = _("Mar");
+ break;
+ case '04':
+ $ret = _("Apr");
+ break;
+ case '05':
+ $ret = _("May");
+ break;
+ case '06':
+ $ret = _("Jun");
+ break;
+ case '07':
+ $ret = _("Jul");
+ break;
+ case '08':
+ $ret = _("Aug");
+ break;
+ case '09':
+ $ret = _("Sep");
+ break;
+ case '10':
+ $ret = _("Oct");
+ break;
+ case '11':
+ $ret = _("Nov");
+ break;
+ case '12':
+ $ret = _("Dec");
+ break;
+ default:
+ $ret = '';
+ }
+ return( $ret );
+}
+
+
function date_intl( $date_format, $stamp ) {
$ret = str_replace( 'D', '$1', $date_format );
$ret = str_replace( 'F', '$2', $ret );
+ $ret = str_replace( 'l', '$4', $ret );
+ $ret = str_replace( 'M', '$5', $ret );
$ret = date( '$3'. $ret . '$3', $stamp ); // Workaround for a PHP 4.0.4 problem
- $ret = str_replace( '$1', substr( getDayName( date( 'w', $stamp ) ), 0, 3 ), $ret );
+ $ret = str_replace( '$1', getDayAbrv( date( 'w', $stamp ) ), $ret );
+ $ret = str_replace( '$5', getMonthAbrv( date( 'm', $stamp ) ), $ret );
$ret = str_replace( '$2', getMonthName( date( 'm', $stamp ) ), $ret );
+ $ret = str_replace( '$4', getDayName( date( 'w', $stamp ) ), $ret );
$ret = str_replace( '$3', '', $ret );
return( $ret );
global $hour_format;
+ if ($stamp == -1) {
+ return '';
+ }
+
if ( $hour_format == SMPREF_TIME_12HR ) {
$date_format = _("D, F j, Y g:i a");
} else {
function getDateString( $stamp ) {
global $invert_time, $hour_format;
+
+ if ( $stamp == -1 ) {
+ return '';
+ }
$now = time();
** In that case, dateParts[0] would be the <day of month>
** and everything would be bumped up one.
**/
-
+
/*
* Simply check to see if the first element in the dateParts
* array is an integer or not.
- * Since the day of week is optional, this check is needed.
- *
- * The old code used eregi('mon|tue|wed|thu|fri|sat|sun',
- * $dateParts[0], $tmp) to find if the first element was the
- * day of week or day of month. This is an expensive call
- * (processing time) to have inside a loop. Doing it this way
- * saves quite a bit of time for large mailboxes.
- *
- * It is also quicker to call explode only once rather than
- * the 3 times it was getting called by calling the functions
- * getHour, getMinute, and getSecond.
+ * Since the day of week is optional, this check is needed.
*/
+ if (count($dateParts) <2) {
+ return 0;
+ }
- if (! isset($dateParts[1])) {
- $dateParts[1] = '';
- }
- if (! isset($dateParts[2])) {
- $dateParts[2] = '';
- }
- if (! isset($dateParts[3])) {
- $dateParts[3] = '';
- }
- if (! isset($dateParts[4])) {
- $dateParts[4] = '';
+ /* remove day of week */
+ if (!is_numeric(trim($dateParts[0]))) {
+ $dataParts = array_shift($dateParts);
}
- if (! isset($dateParts[5])) {
- $dateParts[5] = '';
+ /* calculate timestamp separated from the zone and obs-zone */
+ $stamp = strtotime(implode (' ', array_splice ($dateParts,0,4)));
+ if (!isset($dateParts[0])) {
+ $dateParts[0] = '+0000';
}
- if (intval(trim($dateParts[0])) > 0) {
- $string = $dateParts[0] . ' ' . $dateParts[1] . ' ' .
- $dateParts[2] . ' ' . $dateParts[3];
- return getGMTSeconds(strtotime($string), $dateParts[4]);
- }
- $string = $dateParts[0] . ' ' . $dateParts[1] . ' ' .
- $dateParts[2] . ' ' . $dateParts[3] . ' ' . $dateParts[4];
- if (isset($dateParts[5])) {
- return getGMTSeconds(strtotime($string), $dateParts[5]);
+
+ if (!preg_match('/^[+-]{1}[0-9]{4}$/',$dateParts[0])) {
+ /* zone in obs-zone format */
+ if (preg_match('/\((.+)\)/',$dateParts[0],$regs)) {
+ $obs_zone = $regs[1];
+ } else {
+ $obs_zone = $dateParts[0];
+ }
+ return getGMTSeconds($stamp, $obs_zone);
} else {
- return getGMTSeconds(strtotime($string), '');
+ return getGMTSeconds($stamp, $dateParts[0]);
}
}