123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304 |
- <?php
- /**
- * date.php
- *
- * 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
- * date SHOULD arrive in is:
- * <Tue,> 29 Jun 1999 09:52:11 -0500 (EDT)
- * (as specified in RFC 822) -- 'Tue' is optional
- *
- * $Id$
- */
- require_once(SM_PATH . 'functions/constants.php');
- /* corrects a time stamp to be the local time */
- function getGMTSeconds($stamp, $gmt) {
- global $invert_time;
- /* date couldn't be parsed */
- if ($stamp == -1) {
- return -1;
- }
- switch($gmt)
- {
- case 'Pacific':
- case 'PST':
- $gmt = '-0800';
- break;
- case 'Mountain':
- case 'MST':
- case 'PDT':
- $gmt = '-0700';
- break;
- case 'Central':
- case 'CST':
- case 'MDT':
- $gmt = '-0600';
- break;
- case 'Eastern':
- case 'EST':
- case 'CDT':
- $gmt = '-0500';
- break;
- case 'EDT':
- $gmt = '-0400';
- break;
- case 'GMT':
- $gmt = '+0000';
- break;
- case 'BST':
- case 'MET':
- $gmt = '+0100';
- case 'EET':
- case 'IST':
- case 'MET DST':
- case 'METDST':
- $gmt = '+0200';
- break;
- case 'HKT':
- $gmt = '+0800';
- break;
- case 'JST':
- case 'KST':
- $gmt = '+0900';
- break;
- }
-
- 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;
- }
-
- $difference = substr($gmt, 2, 2);
- $gmt = substr($gmt, 0, 2);
- $gmt = ($gmt + ($difference / 60)) * 3600;
- if ($neg) {
- $gmt = "-$gmt";
- } else {
- $gmt = "+$gmt";
- }
-
- /** now find what the server is at **/
- $current = date('Z', time());
- if ($invert_time) {
- $current = - $current;
- }
- $stamp = (int)$stamp - (int)$gmt + (int)$current;
-
- return $stamp;
- }
- /**
- 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.
- **/
- function getDayName( $day_number ) {
- switch( $day_number ) {
- case 0:
- $ret = _("Sunday");
- break;
- case 1:
- $ret = _("Monday");
- break;
- case 2:
- $ret = _("Tuesday");
- break;
- case 3:
- $ret = _("Wednesday");
- break;
- case 4:
- $ret = _("Thursday");
- break;
- case 5:
- $ret = _("Friday");
- break;
- case 6:
- $ret = _("Saturday");
- break;
- default:
- $ret = '';
- }
- return( $ret );
- }
- function getMonthName( $month_number ) {
- switch( $month_number ) {
- case '01':
- $ret = _("January");
- break;
- case '02':
- $ret = _("February");
- break;
- case '03':
- $ret = _("March");
- break;
- case '04':
- $ret = _("April");
- break;
- case '05':
- $ret = _("May");
- break;
- case '06':
- $ret = _("June");
- break;
- case '07':
- $ret = _("July");
- break;
- case '08':
- $ret = _("August");
- break;
- case '09':
- $ret = _("September");
- break;
- case '10':
- $ret = _("October");
- break;
- case '11':
- $ret = _("November");
- break;
- case '12':
- $ret = _("December");
- 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( '$5', substr( getMonthName( date( 'm', $stamp ) ), 0, 3 ), $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 );
- }
- function getLongDateString( $stamp ) {
- global $hour_format;
-
- if ($stamp == -1) {
- return '';
- }
- if ( $hour_format == SMPREF_TIME_12HR ) {
- $date_format = _("D, F j, Y g:i a");
- } else {
- $date_format = _("D, F j, Y G:i");
- }
-
- return( date_intl( $date_format, $stamp ) );
- }
- function getDateString( $stamp ) {
- global $invert_time, $hour_format;
- if ( $stamp == -1 ) {
- return '';
- }
-
- $now = time();
-
- $dateZ = date('Z', $now );
- if ($invert_time) {
- $dateZ = - $dateZ;
- }
- $midnight = $now - ($now % 86400) - $dateZ;
-
- if ($midnight < $stamp) {
- /* Today */
- if ( $hour_format == SMPREF_TIME_12HR ) {
- $date_format = _("g:i a");
- } else {
- $date_format = _("G:i");
- }
- } else if ($midnight - 518400 < $stamp) {
- /* This week */
- if ( $hour_format == SMPREF_TIME_12HR ) {
- $date_format = _("D, g:i a");
- } else {
- $date_format = _("D, G:i");
- }
- } else {
- /* before this week */
- $date_format = _("M j, Y");
- }
-
- return( date_intl( $date_format, $stamp ) );
- }
- function getTimeStamp($dateParts) {
- /** $dateParts[0] == <day of week> Mon, Tue, Wed
- ** $dateParts[1] == <day of month> 23
- ** $dateParts[2] == <month> Jan, Feb, Mar
- ** $dateParts[3] == <year> 1999
- ** $dateParts[4] == <time> 18:54:23 (HH:MM:SS)
- ** $dateParts[5] == <from GMT> +0100
- ** $dateParts[6] == <zone> (EDT)
- **
- ** NOTE: In RFC 822, it states that <day of week> is optional.
- ** 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.
- */
- /* validate zone before we uses strtotime */
- if (isset($dateParts[6]) && $dateParts[6] && $dateParts[6]{0} != '(') {
- $dateParts[6] = '('.$dateParts[6].')';
- }
- $string = implode (' ', $dateParts);
- if (! isset($dateParts[4])) {
- $dateParts[4] = '';
- }
- if (! isset($dateParts[5])) {
- $dateParts[5] = '';
- }
- if (intval(trim($dateParts[0])) > 0) {
- return getGMTSeconds(strtotime($string), $dateParts[4]);
- }
- return getGMTSeconds(strtotime($string), $dateParts[5]);
- }
- /* I use this function for profiling. Should never be called in
- actual versions of squirrelmail released to public. */
- /*
- function getmicrotime() {
- $mtime = microtime();
- $mtime = explode(' ',$mtime);
- $mtime = $mtime[1] + $mtime[0];
- return ($mtime);
- }
- */
- ?>
|