!C99Shell v. 1.0 pre-release build #13!

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

E:\nuevo\php\pear\   drwxrwxrwx
Free 1.21 GB of 239.26 GB (0.51%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     Date.php (41.36 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4 foldmethod=marker: */

// {{{ Header

/**
 * Generic date handling class for PEAR
 *
 * Generic date handling class for PEAR.  Attempts to be time zone aware
 * through the Date::TimeZone class.  Supports several operations from
 * Date::Calc on Date objects.
 *
 * PHP versions 4 and 5
 *
 * LICENSE:
 *
 * Copyright (c) 1997-2006 Baba Buehler, Pierre-Alain Joye
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted under the terms of the BSD License.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 * @category   Date and Time
 * @package    Date
 * @author     Baba Buehler <baba@babaz.com>
 * @author     Pierre-Alain Joye <pajoye@php.net>
 * @author     Firman Wandayandi <firman@php.net>
 * @copyright  1997-2006 Baba Buehler, Pierre-Alain Joye
 * @license    http://www.opensource.org/licenses/bsd-license.php
 *             BSD License
 * @version    CVS: $Id: Date.php,v 1.41 2006/11/22 00:28:03 firman Exp $
 * @link       http://pear.php.net/package/Date
 */

// }}}

// {{{ Includes

/**
 * Load Date_TimeZone.
 */
require_once 'Date/TimeZone.php';

/**
 * Load Date_Calc.
 */
require_once 'Date/Calc.php';

/**
 * Load Date_Span.
 */
require_once 'Date/Span.php';

// }}}
// {{{ Constants

// {{{ Output formats Pass this to getDate().

/**
 * "YYYY-MM-DD HH:MM:SS"
 */
define('DATE_FORMAT_ISO'1);

/**
 * "YYYYMMSSTHHMMSS(Z|(+/-)HHMM)?"
 */
define('DATE_FORMAT_ISO_BASIC'2);

/**
 * "YYYY-MM-SSTHH:MM:SS(Z|(+/-)HH:MM)?"
 */
define('DATE_FORMAT_ISO_EXTENDED'3);

/**
 * "YYYY-MM-SSTHH:MM:SS(.S*)?(Z|(+/-)HH:MM)?"
 */
define('DATE_FORMAT_ISO_EXTENDED_MICROTIME'6);

/**
 * "YYYYMMDDHHMMSS"
 */
define('DATE_FORMAT_TIMESTAMP'4);

/**
 * long int, seconds since the unix epoch
 */
define('DATE_FORMAT_UNIXTIME'5);

// }}}

// }}}
// {{{ Class: Date

/**
 * Generic date handling class for PEAR
 *
 * Generic date handling class for PEAR.  Attempts to be time zone aware
 * through the Date::TimeZone class.  Supports several operations from
 * Date::Calc on Date objects.
 *
 * @author     Baba Buehler <baba@babaz.com>
 * @author     Pierre-Alain Joye <pajoye@php.net>
 * @author     Firman Wandayandi <firman@php.net>
 * @copyright  1997-2006 Baba Buehler, Pierre-Alain Joye
 * @license    http://www.opensource.org/licenses/bsd-license.php
 *             BSD License
 * @version    Release: 1.4.7
 * @link       http://pear.php.net/package/Date
 */
class Date
{
    
// {{{ Properties

    /**
     * the year
     * @var int
     */
    
var $year;

    
/**
     * the month
     * @var int
     */
    
var $month;

    
/**
     * the day
     * @var int
     */
    
var $day;

    
/**
     * the hour
     * @var int
     */
    
var $hour;

    
/**
     * the minute
     * @var int
     */
    
var $minute;

    
/**
     * the second
     * @var int
     */
    
var $second;

    
/**
     * the parts of a second
     * @var float
     */
    
var $partsecond;

    
/**
     * timezone for this date
     * @var object Date_TimeZone
     */
    
var $tz;

    
/**
     * define the default weekday abbreviation length
     * used by ::format()
     * @var int
     */
    
var $getWeekdayAbbrnameLength 3;

    
// }}}
    // {{{ Constructor

    /**
     * Constructor
     *
     * Creates a new Date Object initialized to the current date/time in the
     * system-default timezone by default.  A date optionally
     * passed in may be in the ISO 8601, TIMESTAMP or UNIXTIME format,
     * or another Date object.  If no date is passed, the current date/time
     * is used.
     *
     * @access public
     * @see setDate()
     * @param mixed $date optional - date/time to initialize
     * @return object Date the new Date object
     */
    
function Date($date null)
    {
        
$this->tz Date_TimeZone::getDefault();
        if (
is_null($date)) {
            
$this->setDate(date("Y-m-d H:i:s"));
        } elseif (
is_a($date'Date')) {
            
$this->copy($date);
        } else {
            
$this->setDate($date);
        }
    }

    
// }}}
    // {{{ setDate()

    /**
     * Set the fields of a Date object based on the input date and format
     *
     * Set the fields of a Date object based on the input date and format,
     * which is specified by the DATE_FORMAT_* constants.
     *
     * @access public
     * @param string $date input date
     * @param int $format Optional format constant (DATE_FORMAT_*) of the input date.
     *                    This parameter isn't really needed anymore, but you could
     *                    use it to force DATE_FORMAT_UNIXTIME.
     */
    
function setDate($date$format DATE_FORMAT_ISO)
    {
        if (
            
preg_match('/^(\d{4})-?(\d{2})-?(\d{2})([T\s]?(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?(Z|[\+\-]\d{2}:?\d{2})?)?$/i'$date$regs)
            && 
$format != DATE_FORMAT_UNIXTIME) {
            
// DATE_FORMAT_ISO, ISO_BASIC, ISO_EXTENDED, and TIMESTAMP
            // These formats are extremely close to each other.  This regex
            // is very loose and accepts almost any butchered format you could
            // throw at it.  e.g. 2003-10-07 19:45:15 and 2003-10071945:15
            // are the same thing in the eyes of this regex, even though the
            // latter is not a valid ISO 8601 date.
            
$this->year       $regs[1];
            
$this->month      $regs[2];
            
$this->day        $regs[3];
            
$this->hour       = isset($regs[5])?$regs[5]:0;
            
$this->minute     = isset($regs[6])?$regs[6]:0;
            
$this->second     = isset($regs[7])?$regs[7]:0;
            
$this->partsecond = isset($regs[8])?(float)$regs[8]:(float)0;

            
// if an offset is defined, convert time to UTC
            // Date currently can't set a timezone only by offset,
            // so it has to store it as UTC
            
if (isset($regs[9])) {
                
$this->toUTCbyOffset($regs[9]);
            }
        } elseif (
is_numeric($date)) {
            
// UNIXTIME
            
$this->setDate(date("Y-m-d H:i:s"$date));
        } else {
            
// unknown format
            
$this->year       0;
            
$this->month      1;
            
$this->day        1;
            
$this->hour       0;
            
$this->minute     0;
            
$this->second     0;
            
$this->partsecond = (float)0;
        }
    }

    
// }}}
    // {{{ getDate()

    /**
     * Get a string (or other) representation of this date
     *
     * Get a string (or other) representation of this date in the
     * format specified by the DATE_FORMAT_* constants.
     *
     * @access public
     * @param int $format format constant (DATE_FORMAT_*) of the output date
     * @return string the date in the requested format
     */
    
function getDate($format DATE_FORMAT_ISO)
    {
        switch (
$format) {
        case 
DATE_FORMAT_ISO:
            return 
$this->format("%Y-%m-%d %T");
            break;
        case 
DATE_FORMAT_ISO_BASIC:
            
$format "%Y%m%dT%H%M%S";
            if (
$this->tz->getID() == 'UTC') {
                
$format .= "Z";
            }
            return 
$this->format($format);
            break;
        case 
DATE_FORMAT_ISO_EXTENDED:
            
$format "%Y-%m-%dT%H:%M:%S";
            if (
$this->tz->getID() == 'UTC') {
                
$format .= "Z";
            }
            return 
$this->format($format);
            break;
        case 
DATE_FORMAT_ISO_EXTENDED_MICROTIME:
            
$format "%Y-%m-%dT%H:%M:%s";
            if (
$this->tz->getID() == 'UTC') {
                
$format .= "Z";
            }
            return 
$this->format($format);
            break;
        case 
DATE_FORMAT_TIMESTAMP:
            return 
$this->format("%Y%m%d%H%M%S");
            break;
        case 
DATE_FORMAT_UNIXTIME:
            return 
mktime($this->hour$this->minute$this->second$this->month$this->day$this->year);
            break;
        }
    }

    
// }}}
    // {{{ copy()

    /**
     * Copy values from another Date object
     *
     * Makes this Date a copy of another Date object.
     *
     * @access public
     * @param object Date $date Date to copy from
     */
    
function copy($date)
    {
        
$this->year $date->year;
        
$this->month $date->month;
        
$this->day $date->day;
        
$this->hour $date->hour;
        
$this->minute $date->minute;
        
$this->second $date->second;
        
$this->tz $date->tz;
    }

    
// }}}
    // {{{ format()

    /**
     *  Date pretty printing, similar to strftime()
     *
     *  Formats the date in the given format, much like
     *  strftime().  Most strftime() options are supported.<br><br>
     *
     *  formatting options:<br><br>
     *
     *  <code>%a  </code>  abbreviated weekday name (Sun, Mon, Tue) <br>
     *  <code>%A  </code>  full weekday name (Sunday, Monday, Tuesday) <br>
     *  <code>%b  </code>  abbreviated month name (Jan, Feb, Mar) <br>
     *  <code>%B  </code>  full month name (January, February, March) <br>
     *  <code>%C  </code>  century number (the year divided by 100 and truncated to an integer, range 00 to 99) <br>
     *  <code>%d  </code>  day of month (range 00 to 31) <br>
     *  <code>%D  </code>  same as "%m/%d/%y" <br>
     *  <code>%e  </code>  day of month, single digit (range 0 to 31) <br>
     *  <code>%E  </code>  number of days since unspecified epoch (integer, Date_Calc::dateToDays()) <br>
     *  <code>%H  </code>  hour as decimal number (00 to 23) <br>
     *  <code>%I  </code>  hour as decimal number on 12-hour clock (01 to 12) <br>
     *  <code>%j  </code>  day of year (range 001 to 366) <br>
     *  <code>%m  </code>  month as decimal number (range 01 to 12) <br>
     *  <code>%M  </code>  minute as a decimal number (00 to 59) <br>
     *  <code>%n  </code>  newline character (\n) <br>
     *  <code>%O  </code>  dst-corrected timezone offset expressed as "+/-HH:MM" <br>
     *  <code>%o  </code>  raw timezone offset expressed as "+/-HH:MM" <br>
     *  <code>%p  </code>  either 'am' or 'pm' depending on the time <br>
     *  <code>%P  </code>  either 'AM' or 'PM' depending on the time <br>
     *  <code>%r  </code>  time in am/pm notation, same as "%I:%M:%S %p" <br>
     *  <code>%R  </code>  time in 24-hour notation, same as "%H:%M" <br>
     *  <code>%s  </code>  seconds including the decimal representation smaller than one second <br>
     *  <code>%S  </code>  seconds as a decimal number (00 to 59) <br>
     *  <code>%t  </code>  tab character (\t) <br>
     *  <code>%T  </code>  current time, same as "%H:%M:%S" <br>
     *  <code>%w  </code>  weekday as decimal (0 = Sunday) <br>
     *  <code>%U  </code>  week number of current year, first sunday as first week <br>
     *  <code>%y  </code>  year as decimal (range 00 to 99) <br>
     *  <code>%Y  </code>  year as decimal including century (range 0000 to 9999) <br>
     *  <code>%%  </code>  literal '%' <br>
     * <br>
     *
     * @access public
     * @param string format the format string for returned date/time
     * @return string date/time in given format
     */
    
function format($format)
    {
        
$output "";

        for(
$strpos 0$strpos strlen($format); $strpos++) {
            
$char substr($format,$strpos,1);
            if (
$char == "%") {
                
$nextchar substr($format,$strpos 1,1);
                switch (
$nextchar) {
                case 
"a":
                    
$output .= Date_Calc::getWeekdayAbbrname($this->day,$this->month,$this->year$this->getWeekdayAbbrnameLength);
                    break;
                case 
"A":
                    
$output .= Date_Calc::getWeekdayFullname($this->day,$this->month,$this->year);
                    break;
                case 
"b":
                    
$output .= Date_Calc::getMonthAbbrname($this->month);
                    break;
                case 
"B":
                    
$output .= Date_Calc::getMonthFullname($this->month);
                    break;
                case 
"C":
                    
$output .= sprintf("%02d",intval($this->year/100));
                    break;
                case 
"d":
                    
$output .= sprintf("%02d",$this->day);
                    break;
                case 
"D":
                    
$output .= sprintf("%02d/%02d/%02d",$this->month,$this->day,$this->year);
                    break;
                case 
"e":
                    
$output .= $this->day 1// get rid of leading zero
                    
break;
                case 
"E":
                    
$output .= Date_Calc::dateToDays($this->day,$this->month,$this->year);
                    break;
                case 
"H":
                    
$output .= sprintf("%02d"$this->hour);
                    break;
                case 
'h':
                    
$output .= sprintf("%d"$this->hour);
                    break;
                case 
"I":
                    
$hour = ($this->hour 1) > 12 $this->hour 12 $this->hour;
                    
$output .= sprintf("%02d"$hour==12 $hour);
                    break;
                case 
"i":
                    
$hour = ($this->hour 1) > 12 $this->hour 12 $this->hour;
                    
$output .= sprintf("%d"$hour==12 $hour);
                    break;
                case 
"j":
                    
$output .= Date_Calc::julianDate($this->day,$this->month,$this->year);
                    break;
                case 
"m":
                    
$output .= sprintf("%02d",$this->month);
                    break;
                case 
"M":
                    
$output .= sprintf("%02d",$this->minute);
                    break;
                case 
"n":
                    
$output .= "\n";
                    break;
                case 
"O":
                    
$offms $this->tz->getOffset($this);
                    
$direction $offms >= "+" "-";
                    
$offmins abs($offms) / 1000 60;
                    
$hours $offmins 60;
                    
$minutes $offmins 60;
                    
$output .= sprintf("%s%02d:%02d"$direction$hours$minutes);
                    break;
                case 
"o":
                    
$offms $this->tz->getRawOffset($this);
                    
$direction $offms >= "+" "-";
                    
$offmins abs($offms) / 1000 60;
                    
$hours $offmins 60;
                    
$minutes $offmins 60;
                    
$output .= sprintf("%s%02d:%02d"$direction$hours$minutes);
                    break;
                case 
"p":
                    
$output .= $this->hour >= 12 "pm" "am";
                    break;
                case 
"P":
                    
$output .= $this->hour >= 12 "PM" "AM";
                    break;
                case 
"r":
                    
$hour = ($this->hour 1) > 12 $this->hour 12 $this->hour;
                    
$output .= sprintf("%02d:%02d:%02d %s"$hour==?  12 $hour$this->minute$this->second$this->hour >= 12 "PM" "AM");
                    break;
                case 
"R":
                    
$output .= sprintf("%02d:%02d"$this->hour$this->minute);
                    break;
                case 
"s":
                    
$output .= str_replace(',''.'sprintf("%09f", (float)((float)$this->second $this->partsecond)));
                    break;
                case 
"S":
                    
$output .= sprintf("%02d"$this->second);
                    break;
                case 
"t":
                    
$output .= "\t";
                    break;
                case 
"T":
                    
$output .= sprintf("%02d:%02d:%02d"$this->hour$this->minute$this->second);
                    break;
                case 
"w":
                    
$output .= Date_Calc::dayOfWeek($this->day,$this->month,$this->year);
                    break;
                case 
"U":
                    
$output .= Date_Calc::weekOfYear($this->day,$this->month,$this->year);
                    break;
                case 
"y":
                    
$output .= substr($this->year,2,2);
                    break;
                case 
"Y":
                    
$output .= $this->year;
                    break;
                case 
"Z":
                    
$output .= $this->tz->inDaylightTime($this) ? $this->tz->getDSTShortName() : $this->tz->getShortName();
                    break;
                case 
"%":
                    
$output .= "%";
                    break;
                default:
                    
$output .= $char.$nextchar;
                }
                
$strpos++;
            } else {
                
$output .= $char;
            }
        }
        return 
$output;

    }

    
// }}}
    // {{{ getTime()

    /**
     * Get this date/time in Unix time() format
     *
     * Get a representation of this date in Unix time() format.  This may only be
     * valid for dates from 1970 to ~2038.
     *
     * @access public
     * @return int number of seconds since the unix epoch
     */
    
function getTime()
    {
        return 
$this->getDate(DATE_FORMAT_UNIXTIME);
    }

    
// }}}
    // {{{ setTZ()

    /**
     * Sets the time zone of this Date
     *
     * Sets the time zone of this date with the given
     * Date_TimeZone object.  Does not alter the date/time,
     * only assigns a new time zone.  For conversion, use
     * convertTZ().
     *
     * @access public
     * @param object Date_TimeZone $tz the Date_TimeZone object to use, if called
     * with a paramater that is not a Date_TimeZone object, will fall through to
     * setTZbyID().
     */
    
function setTZ($tz)
    {
        if(
is_a($tz'Date_Timezone')) {
            
$this->tz $tz;
        } else {
            
$this->setTZbyID($tz);
        }
    }

    
// }}}
    // {{{ setTZbyID()

    /**
     * Sets the time zone of this date with the given time zone id
     *
     * Sets the time zone of this date with the given
     * time zone id, or to the system default if the
     * given id is invalid. Does not alter the date/time,
     * only assigns a new time zone.  For conversion, use
     * convertTZ().
     *
     * @access public
     * @param string id a time zone id
     */
    
function setTZbyID($id)
    {
        if (
Date_TimeZone::isValidID($id)) {
            
$this->tz = new Date_TimeZone($id);
        } else {
            
$this->tz Date_TimeZone::getDefault();
        }
    }

    
// }}}
    // {{{ inDaylightTime()

    /**
     * Tests if this date/time is in DST
     *
     * Returns true if daylight savings time is in effect for
     * this date in this date's time zone.  See Date_TimeZone::inDaylightTime()
     * for compatability information.
     *
     * @access public
     * @return boolean true if DST is in effect for this date
     */
    
function inDaylightTime()
    {
        return 
$this->tz->inDaylightTime($this);
    }

    
// }}}
    // {{{ toUTC()

    /**
     * Converts this date to UTC and sets this date's timezone to UTC
     *
     * Converts this date to UTC and sets this date's timezone to UTC
     *
     * @access public
     */
    
function toUTC()
    {
        if (
$this->tz->getOffset($this) > 0) {
            
$this->subtractSeconds(intval($this->tz->getOffset($this) / 1000));
        } else {
            
$this->addSeconds(intval(abs($this->tz->getOffset($this)) / 1000));
        }
        
$this->tz = new Date_TimeZone('UTC');
    }

    
// }}}
    // {{{ convertTZ()

    /**
     * Converts this date to a new time zone
     *
     * Converts this date to a new time zone.
     * WARNING: This may not work correctly if your system does not allow
     * putenv() or if localtime() does not work in your environment.  See
     * Date::TimeZone::inDaylightTime() for more information.
     *
     * @access public
     * @param object Date_TimeZone $tz the Date::TimeZone object for the conversion time zone
     */
    
function convertTZ($tz)
    {
        
// convert to UTC
        
if ($this->tz->getOffset($this) > 0) {
            
$this->subtractSeconds(intval(abs($this->tz->getOffset($this)) / 1000));
        } else {
            
$this->addSeconds(intval(abs($this->tz->getOffset($this)) / 1000));
        }
        
// convert UTC to new timezone
        
if ($tz->getOffset($this) > 0) {
            
$this->addSeconds(intval(abs($tz->getOffset($this)) / 1000));
        } else {
            
$this->subtractSeconds(intval(abs($tz->getOffset($this)) / 1000));
        }
        
$this->tz $tz;
    }

    
// }}}
    // {{{ convertTZbyID()

    /**
     * Converts this date to a new time zone, given a valid time zone ID
     *
     * Converts this date to a new time zone, given a valid time zone ID
     * WARNING: This may not work correctly if your system does not allow
     * putenv() or if localtime() does not work in your environment.  See
     * Date::TimeZone::inDaylightTime() for more information.
     *
     * @access public
     * @param string id a time zone id
     */
    
function convertTZbyID($id)
    {
       if (
Date_TimeZone::isValidID($id)) {
          
$tz = new Date_TimeZone($id);
       } else {
          
$tz Date_TimeZone::getDefault();
       }
       
$this->convertTZ($tz);
    }

    
// }}}
    // {{{ toUTCbyOffset()

    
function toUTCbyOffset($offset)
    {
        if (
$offset == "Z" || $offset == "+00:00" || $offset == "+0000") {
            
$this->toUTC();
            return 
true;
        }

        if (
preg_match('/([\+\-])(\d{2}):?(\d{2})/'$offset$regs)) {
            
// convert offset to seconds
            
$hours  = (int) isset($regs[2])?$regs[2]:0;
            
$mins   = (int) isset($regs[3])?$regs[3]:0;
            
$offset = ($hours 3600) + ($mins 60);

            if (isset(
$regs[1]) && $regs[1] == "-") {
                
$offset *= -1;
            }

            if (
$offset 0) {
                
$this->subtractSeconds(intval($offset));
            } else {
                
$this->addSeconds(intval(abs($offset)));
            }

            
$this->tz = new Date_TimeZone('UTC');
            return 
true;
        }

        return 
false;
    }

    
// }}}
    // {{{ addSeconds()

    /**
     * Adds a given number of seconds to the date
     *
     * Adds a given number of seconds to the date
     *
     * @access public
     * @param int $sec the number of seconds to add
     */
    
function addSeconds($sec)
    {
        
settype($sec'int');

        
// Negative value given.
        
if ($sec 0) {
            
$this->subtractSeconds(abs($sec));
            return;
        }

        
$this->addSpan(new Date_Span($sec));
    }

    
// }}}
    // {{{ addSpan()

    /**
     * Adds a time span to the date
     *
     * Adds a time span to the date
     *
     * @access public
     * @param object Date_Span $span the time span to add
     */
    
function addSpan($span)
    {
        if (!
is_a($span'Date_Span')) {
            return;
        }

        
$this->second += $span->second;
        if (
$this->second >= 60) {
            
$this->minute++;
            
$this->second -= 60;
        }

        
$this->minute += $span->minute;
        if (
$this->minute >= 60) {
            
$this->hour++;
            if (
$this->hour >= 24) {
                list(
$this->year$this->month$this->day) =
                    
sscanf(Date_Calc::nextDay($this->day$this->month$this->year), "%04s%02s%02s");
                
$this->hour -= 24;
            }
            
$this->minute -= 60;
        }

        
$this->hour += $span->hour;
        if (
$this->hour >= 24) {
            list(
$this->year$this->month$this->day) =
                
sscanf(Date_Calc::nextDay($this->day$this->month$this->year), "%04s%02s%02s");
            
$this->hour -= 24;
        }

        
$d Date_Calc::dateToDays($this->day$this->month$this->year);
        
$d += $span->day;

        list(
$this->year$this->month$this->day) =
            
sscanf(Date_Calc::daysToDate($d), "%04s%02s%02s");
        
$this->year  intval($this->year);
        
$this->month intval($this->month);
        
$this->day   intval($this->day);
    }

    
// }}}
    // {{{ subtractSeconds()

    /**
     * Subtracts a given number of seconds from the date
     *
     * Subtracts a given number of seconds from the date
     *
     * @access public
     * @param int $sec the number of seconds to subtract
     */
    
function subtractSeconds($sec)
    {
        
settype($sec'int');

        
// Negative value given.
        
if ($sec 0) {
            
$this->addSeconds(abs($sec));
            return;
        }

        
$this->subtractSpan(new Date_Span($sec));
    }

    
// }}}
    // {{{ subtractSpan()

    /**
     * Subtracts a time span to the date
     *
     * Subtracts a time span to the date
     *
     * @access public
     * @param object Date_Span $span the time span to subtract
     */
    
function subtractSpan($span)
    {
        if (!
is_a($span'Date_Span')) {
            return;
        }
        if (
$span->isEmpty()) {
            return;
        }

        
$this->second -= $span->second;
        if (
$this->second 0) {
            
$this->minute--;
            
$this->second += 60;
        }

        
$this->minute -= $span->minute;
        if (
$this->minute 0) {
            
$this->hour--;
            if (
$this->hour 0) {
                list(
$this->year$this->month$this->day) =
                    
sscanf(Date_Calc::prevDay($this->day$this->month$this->year), "%04s%02s%02s");
                
$this->hour += 24;
            }
            
$this->minute += 60;
        }

        
$this->hour -= $span->hour;
        if (
$this->hour 0) {
            list(
$this->year$this->month$this->day) =
                
sscanf(Date_Calc::prevDay($this->day$this->month$this->year), "%04s%02s%02s");
            
$this->hour += 24;
        }

        
$d Date_Calc::dateToDays($this->day$this->month$this->year);
        
$d -= $span->day;

        list(
$this->year$this->month$this->day) =
            
sscanf(Date_Calc::daysToDate($d), "%04s%02s%02s");
        
$this->year  intval($this->year);
        
$this->month intval($this->month);
        
$this->day   intval($this->day);
    }

    
// }}}
    // {{{ compare()

    /**
     * Compares two dates
     *
     * Compares two dates.  Suitable for use
     * in sorting functions.
     *
     * @access public
     * @param object Date $d1 the first date
     * @param object Date $d2 the second date
     * @return int 0 if the dates are equal, -1 if d1 is before d2, 1 if d1 is after d2
     */
    
function compare($d1$d2)
    {
        
$d1->convertTZ(new Date_TimeZone('UTC'));
        
$d2->convertTZ(new Date_TimeZone('UTC'));
        
$days1 Date_Calc::dateToDays($d1->day$d1->month$d1->year);
        
$days2 Date_Calc::dateToDays($d2->day$d2->month$d2->year);
        if (
$days1 $days2) return -1;
        if (
$days1 $days2) return 1;
        if (
$d1->hour $d2->hour) return -1;
        if (
$d1->hour $d2->hour) return 1;
        if (
$d1->minute $d2->minute) return -1;
        if (
$d1->minute $d2->minute) return 1;
        if (
$d1->second $d2->second) return -1;
        if (
$d1->second $d2->second) return 1;
        return 
0;
    }

    
// }}}
    // {{{ before()

    /**
     * Test if this date/time is before a certain date/time
     *
     * Test if this date/time is before a certain date/time
     *
     * @access public
     * @param object Date $when the date to test against
     * @return boolean true if this date is before $when
     */
    
function before($when)
    {
        if (
Date::compare($this,$when) == -1) {
            return 
true;
        } else {
            return 
false;
        }
    }

    
// }}}
    // {{{ after()

    /**
     * Test if this date/time is after a certian date/time
     *
     * Test if this date/time is after a certian date/time
     *
     * @access public
     * @param object Date $when the date to test against
     * @return boolean true if this date is after $when
     */
    
function after($when)
    {
        if (
Date::compare($this,$when) == 1) {
            return 
true;
        } else {
            return 
false;
        }
    }

    
// }}}
    // {{{ equals()

    /**
     * Test if this date/time is exactly equal to a certian date/time
     *
     * Test if this date/time is exactly equal to a certian date/time
     *
     * @access public
     * @param object Date $when the date to test against
     * @return boolean true if this date is exactly equal to $when
     */
    
function equals($when)
    {
        if (
Date::compare($this,$when) == 0) {
            return 
true;
        } else {
            return 
false;
        }
    }

    
// }}}
    // {{{ isFuture()

    /**
     * Determine if this date is in the future
     *
     * Determine if this date is in the future
     *
     * @access public
     * @return boolean true if this date is in the future
     */
    
function isFuture()
    {
        
$now = new Date();
        if (
$this->after($now)) {
            return 
true;
        } else {
            return 
false;
        }
    }

    
// }}}
    // {{{ isPast()

    /**
     * Determine if this date is in the past
     *
     * Determine if this date is in the past
     *
     * @access public
     * @return boolean true if this date is in the past
     */
    
function isPast()
    {
        
$now = new Date();
        if (
$this->before($now)) {
            return 
true;
        } else {
            return 
false;
        }
    }

    
// }}}
    // {{{ isLeapYear()

    /**
     * Determine if the year in this date is a leap year
     *
     * Determine if the year in this date is a leap year
     *
     * @access public
     * @return boolean true if this year is a leap year
     */
    
function isLeapYear()
    {
        return 
Date_Calc::isLeapYear($this->year);
    }

    
// }}}
    // {{{ getJulianDate()

    /**
     * Get the Julian date for this date
     *
     * Get the Julian date for this date
     *
     * @access public
     * @return int the Julian date
     */
    
function getJulianDate()
    {
        return 
Date_Calc::julianDate($this->day$this->month$this->year);
    }

    
// }}}
    // {{{ getDayOfWeek()

    /**
     * Gets the day of the week for this date
     *
     * Gets the day of the week for this date (0=Sunday)
     *
     * @access public
     * @return int the day of the week (0=Sunday)
     */
    
function getDayOfWeek()
    {
        return 
Date_Calc::dayOfWeek($this->day$this->month$this->year);
    }

    
// }}}
    // {{{ getWeekOfYear()

    /**
     * Gets the week of the year for this date
     *
     * Gets the week of the year for this date
     *
     * @access public
     * @return int the week of the year
     */
    
function getWeekOfYear()
    {
        return 
Date_Calc::weekOfYear($this->day$this->month$this->year);
    }

    
// }}}
    // {{{ getQuarterOfYear()

    /**
     * Gets the quarter of the year for this date
     *
     * Gets the quarter of the year for this date
     *
     * @access public
     * @return int the quarter of the year (1-4)
     */
    
function getQuarterOfYear()
    {
        return 
Date_Calc::quarterOfYear($this->day$this->month$this->year);
    }

    
// }}}
    // {{{ getDaysInMonth()

    /**
     * Gets number of days in the month for this date
     *
     * Gets number of days in the month for this date
     *
     * @access public
     * @return int number of days in this month
     */
    
function getDaysInMonth()
    {
        return 
Date_Calc::daysInMonth($this->month$this->year);
    }

    
// }}}
    // {{{ getWeeksInMonth()

    /**
     * Gets the number of weeks in the month for this date
     *
     * Gets the number of weeks in the month for this date
     *
     * @access public
     * @return int number of weeks in this month
     */
    
function getWeeksInMonth()
    {
        return 
Date_Calc::weeksInMonth($this->month$this->year);
    }

    
// }}}
    // {{{ getDayName()

    /**
     * Gets the full name or abbriviated name of this weekday
     *
     * Gets the full name or abbriviated name of this weekday
     *
     * @access public
     * @param boolean $abbr abbrivate the name
     * @return string name of this day
     */
    
function getDayName($abbr false$length 3)
    {
        if (
$abbr) {
            return 
Date_Calc::getWeekdayAbbrname($this->day$this->month$this->year$length);
        } else {
            return 
Date_Calc::getWeekdayFullname($this->day$this->month$this->year);
        }
    }

    
// }}}
    // {{{ getMonthName()

    /**
     * Gets the full name or abbriviated name of this month
     *
     * Gets the full name or abbriviated name of this month
     *
     * @access public
     * @param boolean $abbr abbrivate the name
     * @return string name of this month
     */
    
function getMonthName($abbr false)
    {
        if (
$abbr) {
            return 
Date_Calc::getMonthAbbrname($this->month);
        } else {
            return 
Date_Calc::getMonthFullname($this->month);
        }
    }

    
// }}}
    // {{{ getNextDay()

    /**
     * Get a Date object for the day after this one
     *
     * Get a Date object for the day after this one.
     * The time of the returned Date object is the same as this time.
     *
     * @access public
     * @return object Date Date representing the next day
     */
    
function getNextDay()
    {
        
$day Date_Calc::nextDay($this->day$this->month$this->year"%Y-%m-%d");
        
$date sprintf("%s %02d:%02d:%02d"$day$this->hour$this->minute$this->second);
        
$newDate = new Date();
        
$newDate->setDate($date);
        return 
$newDate;
    }

    
// }}}
    // {{{ getPrevDay()

    /**
     * Get a Date object for the day before this one
     *
     * Get a Date object for the day before this one.
     * The time of the returned Date object is the same as this time.
     *
     * @access public
     * @return object Date Date representing the previous day
     */
    
function getPrevDay()
    {
        
$day Date_Calc::prevDay($this->day$this->month$this->year"%Y-%m-%d");
        
$date sprintf("%s %02d:%02d:%02d"$day$this->hour$this->minute$this->second);
        
$newDate = new Date();
        
$newDate->setDate($date);
        return 
$newDate;
    }

    
// }}}
    // {{{ getNextWeekday()

    /**
     * Get a Date object for the weekday after this one
     *
     * Get a Date object for the weekday after this one.
     * The time of the returned Date object is the same as this time.
     *
     * @access public
     * @return object Date Date representing the next weekday
     */
    
function getNextWeekday()
    {
        
$day Date_Calc::nextWeekday($this->day$this->month$this->year"%Y-%m-%d");
        
$date sprintf("%s %02d:%02d:%02d"$day$this->hour$this->minute$this->second);
        
$newDate = new Date();
        
$newDate->setDate($date);
        return 
$newDate;
    }

    
// }}}
    // {{{ getPrevWeekday()

    /**
     * Get a Date object for the weekday before this one
     *
     * Get a Date object for the weekday before this one.
     * The time of the returned Date object is the same as this time.
     *
     * @access public
     * @return object Date Date representing the previous weekday
     */
    
function getPrevWeekday()
    {
        
$day Date_Calc::prevWeekday($this->day$this->month$this->year"%Y-%m-%d");
        
$date sprintf("%s %02d:%02d:%02d"$day$this->hour$this->minute$this->second);
        
$newDate = new Date();
        
$newDate->setDate($date);
        return 
$newDate;
    }

    
// }}}
    // {{{ getYear()

    /**
     * Returns the year field of the date object
     *
     * Returns the year field of the date object
     *
     * @access public
     * @return int the year
     */
    
function getYear()
    {
        return (int)
$this->year;
    }

    
// }}}
    // {{{ getMonth()

    /**
     * Returns the month field of the date object
     *
     * Returns the month field of the date object
     *
     * @access public
     * @return int the month
     */
    
function getMonth()
    {
        return (int)
$this->month;
    }

    
// }}}
    // {{{ getDay()

    /**
     * Returns the day field of the date object
     *
     * Returns the day field of the date object
     *
     * @access public
     * @return int the day
     */
    
function getDay()
    {
        return (int)
$this->day;
    }

    
// }}}
    // {{{ getHour()

    /**
     * Returns the hour field of the date object
     *
     * Returns the hour field of the date object
     *
     * @access public
     * @return int the hour
     */
    
function getHour()
    {
        return 
$this->hour;
    }

    
// }}}
    // {{{ getMinute()

    /**
     * Returns the minute field of the date object
     *
     * Returns the minute field of the date object
     *
     * @access public
     * @return int the minute
     */
    
function getMinute()
    {
        return 
$this->minute;
    }

    
// }}}
    // {{{ getSecond()

    /**
     * Returns the second field of the date object
     *
     * Returns the second field of the date object
     *
     * @access public
     * @return int the second
     */
    
function getSecond()
    {
         return 
$this->second;
    }

    
// }}}
    // {{{ setYear()

    /**
     * Set the year field of the date object
     *
     * Set the year field of the date object, invalid years (not 0-9999) are set to 0.
     *
     * @access public
     * @param int $y the year
     */
    
function setYear($y)
    {
        if (
$y || $y 9999) {
            
$this->year 0;
        } else {
            
$this->year $y;
        }
    }

    
// }}}
    // {{{ setMonth()

    /**
     * Set the month field of the date object
     *
     * Set the month field of the date object, invalid months (not 1-12) are set to 1.
     *
     * @access public
     * @param int $m the month
     */
    
function setMonth($m)
    {
        if (
$m || $m 12) {
            
$this->month 1;
        } else {
            
$this->month $m;
        }
    }

    
// }}}
    // {{{ setDay()

    /**
     * Set the day field of the date object
     *
     * Set the day field of the date object, invalid days (not 1-31) are set to 1.
     *
     * @access public
     * @param int $d the day
     */
    
function setDay($d)
    {
        if (
$d 31 || $d 1) {
            
$this->day 1;
        } else {
            
$this->day $d;
        }
    }

    
// }}}
    // {{{ setHour()

    /**
     * Set the hour field of the date object
     *
     * Set the hour field of the date object in 24-hour format.
     * Invalid hours (not 0-23) are set to 0.
     *
     * @access public
     * @param int $h the hour
     */
    
function setHour($h)
    {
        if (
$h 23 || $h 0) {
            
$this->hour 0;
        } else {
            
$this->hour $h;
        }
    }

    
// }}}
    // {{{ setMinute()

    /**
     * Set the minute field of the date object
     *
     * Set the minute field of the date object, invalid minutes (not 0-59) are set to 0.
     *
     * @access public
     * @param int $m the minute
     */
    
function setMinute($m)
    {
        if (
$m 59 || $m 0) {
            
$this->minute 0;
        } else {
            
$this->minute $m;
        }
    }

    
// }}}
    // {{{ setSecond()

    /**
     * Set the second field of the date object
     *
     * Set the second field of the date object, invalid seconds (not 0-59) are set to 0.
     *
     * @access public
     * @param int $s the second
     */
    
function setSecond($s) {
        if (
$s 59 || $s 0) {
            
$this->second 0;
        } else {
            
$this->second $s;
        }
    }

    
// }}}
}

// }}}

/*
 * Local variables:
 * mode: php
 * tab-width: 4
 * c-basic-offset: 4
 * c-hanging-comment-ender-p: nil
 * End:
 */
?>

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0312 ]--